diff --git a/client/dist/js/TinyMCE_ssembed.js b/client/dist/js/TinyMCE_ssembed.js index 88b1a6fbf..475285884 100644 --- a/client/dist/js/TinyMCE_ssembed.js +++ b/client/dist/js/TinyMCE_ssembed.js @@ -1 +1,684 @@ -!function(e){function t(r){if(n[r])return n[r].exports;var i=n[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,t),i.l=!0,i.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s="./client/src/entwine/TinyMCE_ssembed.js")}({"./client/src/components/InsertEmbedModal/InsertEmbedModal.js":function(e,t,n){"use strict";function r(e){return e&&e.__esModule?e:{default:e}}function i(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function o(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function a(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function s(e,t){var n=e.config.sections.find(function(e){return e.name===_}),r=t.fileAttributes?t.fileAttributes.Url:"",i=n.form.remoteEditForm.schemaUrl,o=r&&i+"/?embedurl="+encodeURIComponent(r),a=n.form.remoteCreateForm.schemaUrl;return{sectionConfig:n,schemaUrl:o||a,targetUrl:r}}function l(e){return{actions:{schema:(0,m.bindActionCreators)(C,e)}}}Object.defineProperty(t,"__esModule",{value:!0}),t.Component=void 0;var d=function(){function e(e,t){var n=[],r=!0,i=!1,o=void 0;try{for(var a,s=e[Symbol.iterator]();!(r=(a=s.next()).done)&&(n.push(a.value),!t||n.length!==t);r=!0);}catch(e){i=!0,o=e}finally{try{!r&&s.return&&s.return()}finally{if(i)throw o}}return n}return function(t,n){if(Array.isArray(t))return t;if(Symbol.iterator in Object(t))return e(t,n);throw new TypeError("Invalid attempt to destructure non-iterable instance")}}(),c=function(){function e(e,t){for(var n=0;n"+e.content+"");t.find(v).each(function(){var e=(0,o.default)(this),t=e.find("img.placeholder");if(0===t.length)return e.removeAttr("data-url"),void e.removeAttr("data-shortcode");var n=e.find(".caption").text(),r=parseInt(t.attr("width"),10),i=parseInt(t.attr("height"),10),a=e.data("url"),s={url:a,thumbnail:t.prop("src"),class:e.prop("class"),width:isNaN(r)?null:r,height:isNaN(i)?null:i,caption:n},l=p.default.serialise({name:"embed",properties:s,wrapped:!0,content:a});e.replaceWith(l)}),e.content=t.html()}),e.on("BeforeSetContent",function(e){for(var t=e.content,n=p.default.match("embed",!0,t);n;){var r=n.properties,i=(0,o.default)("
").attr("data-url",r.url||n.content).attr("data-shortcode","embed").addClass(r.class).addClass("ss-htmleditorfield-file embed"),a=(0,o.default)("").attr("src",r.thumbnail).addClass("placeholder");if(r.width&&(i.width(r.width),a.attr("width",r.width)),r.height&&a.attr("height",r.height),i.append(a),r.caption){var s=(0,o.default)("

").addClass("caption").text(r.caption);i.append(s)}t=t.replace(n.original,(0,o.default)("

").append(i).html()),n=p.default.match("embed",!0,t)}e.content=t})}};tinymce.PluginManager.add("ssembed",function(t){return e.init(t)})}(),o.default.entwine("ss",function(e){e(".js-injector-boot #insert-embed-react__dialog-wrapper").entwine({Element:null,Data:{},onunmatch:function(){this._clearModal()},_clearModal:function(){d.default.unmountComponentAtNode(this[0])},open:function(){this._renderModal(!0)},close:function(){this.setData({}),this._renderModal(!1)},_renderModal:function(e){var t=this,n=function(){return t.close()},r=function(){return t._handleInsert.apply(t,arguments)},i=function(){return t._handleCreate.apply(t,arguments)},o=function(){return t._handleLoadingError.apply(t,arguments)},a=this.getOriginalAttributes();d.default.render(s.default.createElement(b,{isOpen:e,onCreate:i,onInsert:r,onClosed:n,onLoadingError:o,bodyClassName:"modal__dialog",className:"insert-embed-react__dialog-wrapper",fileAttributes:a}),this[0])},_handleLoadingError:function(){this.setData({}),this.open()},_handleInsert:function(e){var t=this.getData();this.setData(Object.assign({Url:t.Url},e)),this.insertRemote(),this.close()},_handleCreate:function(e){this.setData(Object.assign({},this.getData(),e)),this.open()},getOriginalAttributes:function(){var t=this.getData(),n=this.getElement();if(!n)return t;var r=e(n.getEditor().getSelectedNode());if(!r.length)return t;var i=r.closest(v).add(r.filter(v));if(!i.length)return t;var o=i.find("img.placeholder");if(0===o.length)return t;var a=i.find(".caption").text(),s=parseInt(o.width(),10),l=parseInt(o.height(),10);return{Url:i.data("url")||t.Url,CaptionText:a,PreviewUrl:o.attr("src"),Width:isNaN(s)?null:s,Height:isNaN(l)?null:l,Placement:this.findPosition(i.prop("class"))}},findPosition:function(e){var t=["leftAlone","center","rightAlone","left","right"];if("string"!=typeof e)return"";var n=e.split(" ");return t.find(function(e){return n.indexOf(e)>-1})},insertRemote:function(){var t=this.getElement();if(!t)return!1;var n=t.getEditor();if(!n)return!1;var r=this.getData(),i=(0,o.default)("
").attr("data-url",r.Url).attr("data-shortcode","embed").addClass(r.Placement).addClass("ss-htmleditorfield-file embed"),a=(0,o.default)("").attr("src",r.PreviewUrl).addClass("placeholder");if(r.Width&&(i.width(r.Width),a.attr("width",r.Width)),r.Height&&a.attr("height",r.Height),i.append(a),r.CaptionText){var s=(0,o.default)("

").addClass("caption").text(r.CaptionText);i.append(s)}var l=e(n.getSelectedNode()),d=e(null);return l.length&&(d=l.filter(v),0===d.length&&(d=l.closest(v)),0===d.length&&(d=l.filter("img.placeholder"))),d.length?d.replaceWith(i):(n.repaint(),n.insertContent(e("

").append(i.clone()).html(),{skip_undo:1})),n.addUndo(),n.repaint(),!0}})})},0:function(e,t){e.exports=React},1:function(e,t){e.exports=i18n},11:function(e,t){e.exports=FormBuilderModal},16:function(e,t){e.exports=SchemaActions},2:function(e,t){e.exports=Injector},3:function(e,t){e.exports=ReactRedux},4:function(e,t){e.exports=Redux},5:function(e,t){e.exports=ReactDom},6:function(e,t){e.exports=jQuery},7:function(e,t){e.exports=ShortcodeSerialiser}}); \ No newline at end of file +/******/ (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] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = 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; +/******/ +/******/ // identity function for calling harmony imports with the correct context +/******/ __webpack_require__.i = function(value) { return value; }; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { +/******/ configurable: false, +/******/ enumerable: true, +/******/ get: getter +/******/ }); +/******/ } +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = "./client/src/entwine/TinyMCE_ssembed.js"); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "./client/src/components/InsertEmbedModal/InsertEmbedModal.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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"); } }; }(); + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _redux = __webpack_require__(4); + +var _reactRedux = __webpack_require__(3); + +var _FormBuilderModal = __webpack_require__(11); + +var _FormBuilderModal2 = _interopRequireDefault(_FormBuilderModal); + +var _SchemaActions = __webpack_require__(16); + +var schemaActions = _interopRequireWildcard(_SchemaActions); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var sectionConfigKey = 'SilverStripe\\AssetAdmin\\Controller\\AssetAdmin'; + +var InsertEmbedModal = function (_Component) { + _inherits(InsertEmbedModal, _Component); + + function InsertEmbedModal(props) { + _classCallCheck(this, InsertEmbedModal); + + var _this = _possibleConstructorReturn(this, (InsertEmbedModal.__proto__ || Object.getPrototypeOf(InsertEmbedModal)).call(this, props)); + + _this.handleSubmit = _this.handleSubmit.bind(_this); + return _this; + } + + _createClass(InsertEmbedModal, [{ + key: 'componentWillMount', + value: function componentWillMount() { + this.setOverrides(this.props); + } + }, { + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(props) { + if (props.isOpen && !this.props.isOpen) { + this.setOverrides(props); + } + } + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + this.clearOverrides(); + } + }, { + key: 'setOverrides', + value: function setOverrides(props) { + if (this.props.schemaUrl !== props.schemaUrl) { + this.clearOverrides(); + } + if (props.schemaUrl) { + var attrs = Object.assign({}, props.fileAttributes); + delete attrs.ID; + + var overrides = { + fields: Object.entries(attrs).map(function (field) { + var _field = _slicedToArray(field, 2), + name = _field[0], + value = _field[1]; + + return { name: name, value: value }; + }) + }; + + this.props.actions.schema.setSchemaStateOverrides(props.schemaUrl, overrides); + } + } + }, { + key: 'getModalProps', + value: function getModalProps() { + var props = Object.assign({ + onSubmit: this.handleSubmit, + onLoadingError: this.handleLoadingError, + showErrorMessage: true, + responseClassBad: 'alert alert-danger', + identifier: 'AssetAdmin.InsertEmbedModal' + }, this.props, { + className: 'insert-embed-modal ' + this.props.className, + size: 'lg', + onClosed: this.props.onClosed, + title: this.props.targetUrl ? _i18n2.default._t('AssetAdmin.EditTitle', 'Media from the web') : _i18n2.default._t('AssetAdmin.CreateTitle', 'Insert new media from the web') + }); + delete props.sectionConfig; + delete props.onInsert; + delete props.fileAttributes; + + return props; + } + }, { + key: 'clearOverrides', + value: function clearOverrides() { + this.props.actions.schema.setSchemaStateOverrides(this.props.schemaUrl, null); + } + }, { + key: 'handleLoadingError', + value: function handleLoadingError(error) { + if (typeof this.props.onLoadingError === 'function') { + this.props.onLoadingError(error); + } + } + }, { + key: 'handleSubmit', + value: function handleSubmit(data, action) { + switch (action) { + case 'action_addmedia': + { + this.props.onCreate(data); + break; + } + case 'action_insertmedia': + { + this.props.onInsert(data); + break; + } + case 'action_cancel': + { + this.props.onClosed(); + break; + } + default: + {} + } + + return Promise.resolve(); + } + }, { + key: 'render', + value: function render() { + return _react2.default.createElement(_FormBuilderModal2.default, this.getModalProps()); + } + }]); + + return InsertEmbedModal; +}(_react.Component); + +InsertEmbedModal.propTypes = { + sectionConfig: _react.PropTypes.shape({ + url: _react.PropTypes.string, + form: _react.PropTypes.object + }), + isOpen: _react.PropTypes.bool, + onInsert: _react.PropTypes.func.isRequired, + onCreate: _react.PropTypes.func.isRequired, + fileAttributes: _react.PropTypes.shape({ + Url: _react.PropTypes.string, + CaptionText: _react.PropTypes.string, + PreviewUrl: _react.PropTypes.string, + Placement: _react.PropTypes.string, + Width: _react.PropTypes.number, + Height: _react.PropTypes.number + }), + onClosed: _react.PropTypes.func.isRequired, + className: _react.PropTypes.string, + actions: _react.PropTypes.object, + schemaUrl: _react.PropTypes.string.isRequired, + targetUrl: _react.PropTypes.string, + onLoadingError: _react.PropTypes.func +}; + +InsertEmbedModal.defaultProps = { + className: '', + fileAttributes: {} +}; + +function mapStateToProps(state, ownProps) { + var sectionConfig = state.config.sections.find(function (section) { + return section.name === sectionConfigKey; + }); + + var targetUrl = ownProps.fileAttributes ? ownProps.fileAttributes.Url : ''; + var baseEditUrl = sectionConfig.form.remoteEditForm.schemaUrl; + + var editUrl = targetUrl && baseEditUrl + '/?embedurl=' + encodeURIComponent(targetUrl); + var createUrl = sectionConfig.form.remoteCreateForm.schemaUrl; + + var schemaUrl = editUrl || createUrl; + + return { + sectionConfig: sectionConfig, + schemaUrl: schemaUrl, + targetUrl: targetUrl + }; +} + +function mapDispatchToProps(dispatch) { + return { + actions: { + schema: (0, _redux.bindActionCreators)(schemaActions, dispatch) + } + }; +} + +exports.Component = InsertEmbedModal; +exports.default = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps)(InsertEmbedModal); + +/***/ }), + +/***/ "./client/src/entwine/TinyMCE_ssembed.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +var _jquery = __webpack_require__(6); + +var _jquery2 = _interopRequireDefault(_jquery); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactDom = __webpack_require__(5); + +var _reactDom2 = _interopRequireDefault(_reactDom); + +var _Injector = __webpack_require__(2); + +var _ShortcodeSerialiser = __webpack_require__(7); + +var _ShortcodeSerialiser2 = _interopRequireDefault(_ShortcodeSerialiser); + +var _InsertEmbedModal = __webpack_require__("./client/src/components/InsertEmbedModal/InsertEmbedModal.js"); + +var _InsertEmbedModal2 = _interopRequireDefault(_InsertEmbedModal); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var InjectableInsertEmbedModal = (0, _Injector.loadComponent)(_InsertEmbedModal2.default); +var filter = 'div[data-shortcode="embed"]'; + +(function () { + var ssembed = { + init: function init(editor) { + var title = _i18n2.default._t('AssetAdmin.INSERT_VIA_URL', 'Insert media via URL'); + editor.addButton('ssembed', { + icon: 'media', + title: title, + cmd: 'ssembed' + }); + editor.addMenuItem('ssembed', { + icon: 'media', + text: title, + cmd: 'ssembed' + }); + + editor.addCommand('ssembed', function () { + (0, _jquery2.default)('#' + editor.id).entwine('ss').openEmbedDialog(); + }); + + editor.on('BeforeExecCommand', function (e) { + var cmd = e.command; + var ui = e.ui; + var val = e.value; + if (cmd === 'mceAdvMedia' || cmd === 'mceAdvMedia') { + e.preventDefault(); + editor.execCommand('ssembed', ui, val); + } + }); + + editor.on('SaveContent', function (o) { + var content = (0, _jquery2.default)('
' + o.content + '
'); + + content.find(filter).each(function replaceWithShortCode() { + var embed = (0, _jquery2.default)(this); + + var placeholder = embed.find('img.placeholder'); + if (placeholder.length === 0) { + embed.removeAttr('data-url'); + embed.removeAttr('data-shortcode'); + return; + } + + var caption = embed.find('.caption').text(); + var width = parseInt(placeholder.attr('width'), 10); + var height = parseInt(placeholder.attr('height'), 10); + var url = embed.data('url'); + var properties = { + url: url, + thumbnail: placeholder.prop('src'), + class: embed.prop('class'), + width: isNaN(width) ? null : width, + height: isNaN(height) ? null : height, + caption: caption + }; + var shortCode = _ShortcodeSerialiser2.default.serialise({ + name: 'embed', + properties: properties, + wrapped: true, + content: url + }); + embed.replaceWith(shortCode); + }); + + o.content = content.html(); + }); + editor.on('BeforeSetContent', function (o) { + var content = o.content; + + var match = _ShortcodeSerialiser2.default.match('embed', true, content); + while (match) { + var data = match.properties; + + var base = (0, _jquery2.default)('
').attr('data-url', data.url || match.content).attr('data-shortcode', 'embed').addClass(data.class).addClass('ss-htmleditorfield-file embed'); + + var placeholder = (0, _jquery2.default)('').attr('src', data.thumbnail).addClass('placeholder'); + + if (data.width) { + base.width(data.width); + placeholder.attr('width', data.width); + } + if (data.height) { + placeholder.attr('height', data.height); + } + + base.append(placeholder); + + if (data.caption) { + var caption = (0, _jquery2.default)('

').addClass('caption').text(data.caption); + base.append(caption); + } + + content = content.replace(match.original, (0, _jquery2.default)('

').append(base).html()); + + match = _ShortcodeSerialiser2.default.match('embed', true, content); + } + + o.content = content; + }); + } + }; + + tinymce.PluginManager.add('ssembed', function (editor) { + return ssembed.init(editor); + }); +})(); + +_jquery2.default.entwine('ss', function ($) { + $('.js-injector-boot #insert-embed-react__dialog-wrapper').entwine({ + Element: null, + + Data: {}, + + onunmatch: function onunmatch() { + this._clearModal(); + }, + _clearModal: function _clearModal() { + _reactDom2.default.unmountComponentAtNode(this[0]); + }, + open: function open() { + this._renderModal(true); + }, + close: function close() { + this.setData({}); + this._renderModal(false); + }, + _renderModal: function _renderModal(isOpen) { + var _this = this; + + var handleHide = function handleHide() { + return _this.close(); + }; + + var handleInsert = function handleInsert() { + return _this._handleInsert.apply(_this, arguments); + }; + + var handleCreate = function handleCreate() { + return _this._handleCreate.apply(_this, arguments); + }; + var handleLoadingError = function handleLoadingError() { + return _this._handleLoadingError.apply(_this, arguments); + }; + var attrs = this.getOriginalAttributes(); + + _reactDom2.default.render(_react2.default.createElement(InjectableInsertEmbedModal, { + isOpen: isOpen, + onCreate: handleCreate, + onInsert: handleInsert, + onClosed: handleHide, + onLoadingError: handleLoadingError, + bodyClassName: 'modal__dialog', + className: 'insert-embed-react__dialog-wrapper', + fileAttributes: attrs + }), this[0]); + }, + _handleLoadingError: function _handleLoadingError() { + this.setData({}); + this.open(); + }, + _handleInsert: function _handleInsert(data) { + var oldData = this.getData(); + this.setData(Object.assign({ Url: oldData.Url }, data)); + this.insertRemote(); + this.close(); + }, + _handleCreate: function _handleCreate(data) { + this.setData(Object.assign({}, this.getData(), data)); + this.open(); + }, + getOriginalAttributes: function getOriginalAttributes() { + var data = this.getData(); + var $field = this.getElement(); + if (!$field) { + return data; + } + + var node = $($field.getEditor().getSelectedNode()); + if (!node.length) { + return data; + } + + var element = node.closest(filter).add(node.filter(filter)); + if (!element.length) { + return data; + } + var image = element.find('img.placeholder'); + + if (image.length === 0) { + return data; + } + + var caption = element.find('.caption').text(); + var width = parseInt(image.width(), 10); + var height = parseInt(image.height(), 10); + + return { + Url: element.data('url') || data.Url, + CaptionText: caption, + PreviewUrl: image.attr('src'), + Width: isNaN(width) ? null : width, + Height: isNaN(height) ? null : height, + Placement: this.findPosition(element.prop('class')) + }; + }, + findPosition: function findPosition(cssClass) { + var alignments = ['leftAlone', 'center', 'rightAlone', 'left', 'right']; + if (typeof cssClass !== 'string') { + return ''; + } + var classes = cssClass.split(' '); + return alignments.find(function (alignment) { + return classes.indexOf(alignment) > -1; + }); + }, + insertRemote: function insertRemote() { + var $field = this.getElement(); + if (!$field) { + return false; + } + var editor = $field.getEditor(); + if (!editor) { + return false; + } + + var data = this.getData(); + + var base = (0, _jquery2.default)('
').attr('data-url', data.Url).attr('data-shortcode', 'embed').addClass(data.Placement).addClass('ss-htmleditorfield-file embed'); + + var placeholder = (0, _jquery2.default)('').attr('src', data.PreviewUrl).addClass('placeholder'); + + if (data.Width) { + base.width(data.Width); + placeholder.attr('width', data.Width); + } + if (data.Height) { + placeholder.attr('height', data.Height); + } + + base.append(placeholder); + + if (data.CaptionText) { + var caption = (0, _jquery2.default)('

').addClass('caption').text(data.CaptionText); + base.append(caption); + } + + var node = $(editor.getSelectedNode()); + var replacee = $(null); + if (node.length) { + replacee = node.filter(filter); + + if (replacee.length === 0) { + replacee = node.closest(filter); + } + + if (replacee.length === 0) { + replacee = node.filter('img.placeholder'); + } + } + + if (replacee.length) { + replacee.replaceWith(base); + } else { + editor.repaint(); + editor.insertContent($('

').append(base.clone()).html(), { skip_undo: 1 }); + } + + editor.addUndo(); + editor.repaint(); + + return true; + } + }); +}); + +/***/ }), + +/***/ 0: +/***/ (function(module, exports) { + +module.exports = React; + +/***/ }), + +/***/ 1: +/***/ (function(module, exports) { + +module.exports = i18n; + +/***/ }), + +/***/ 11: +/***/ (function(module, exports) { + +module.exports = FormBuilderModal; + +/***/ }), + +/***/ 16: +/***/ (function(module, exports) { + +module.exports = SchemaActions; + +/***/ }), + +/***/ 2: +/***/ (function(module, exports) { + +module.exports = Injector; + +/***/ }), + +/***/ 3: +/***/ (function(module, exports) { + +module.exports = ReactRedux; + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = Redux; + +/***/ }), + +/***/ 5: +/***/ (function(module, exports) { + +module.exports = ReactDom; + +/***/ }), + +/***/ 6: +/***/ (function(module, exports) { + +module.exports = jQuery; + +/***/ }), + +/***/ 7: +/***/ (function(module, exports) { + +module.exports = ShortcodeSerialiser; + +/***/ }) + +/******/ }); +//# sourceMappingURL=TinyMCE_ssembed.js.map \ No newline at end of file diff --git a/client/dist/js/TinyMCE_sslink-file.js b/client/dist/js/TinyMCE_sslink-file.js index e080fb3da..a3831752a 100644 --- a/client/dist/js/TinyMCE_sslink-file.js +++ b/client/dist/js/TinyMCE_sslink-file.js @@ -1 +1,290 @@ -!function(e){function t(i){if(n[i])return n[i].exports;var r=n[i]={i:i,l:!1,exports:{}};return e[i].call(r.exports,r,r.exports,t),r.l=!0,r.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,i){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:i})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s="./client/src/entwine/TinyMCE_sslink-file.js")}({"./client/src/entwine/TinyMCE_sslink-file.js":function(e,t,n){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var r=n(1),o=i(r),l=n(25),a=i(l),s=n(0),u=i(s),c=n(5),d=i(c),f=n(6),p=i(f),g=n(7),_=i(g),m=n(10),k=i(m),h=n(2);a.default.addAction("sslink",{text:o.default._t("AssetAdmin.LINKLABEL_FILE","Link to a file"),onclick:function(e){return e.execCommand("sslinkfile")}}).addCommandWithUrlTest("sslinkfile",/^\[file_link/);var x={init:function(e){e.addCommand("sslinkfile",function(){(0,p.default)("#"+e.id).entwine("ss").openLinkFileDialog()})}},b="insert-link__dialog-wrapper--file",v=(0,h.loadComponent)(k.default);p.default.entwine("ss",function(e){e(".insert-link__dialog-wrapper--internal .nav-link, .insert-media-react__dialog-wrapper .breadcrumb__container a").entwine({onclick:function(e){return e.preventDefault()}}),e("textarea.htmleditor").entwine({openLinkFileDialog:function(){var t=e("#"+b);t.length||(t=e('
'),e("body").append(t)),t.addClass("insert-link__dialog-wrapper"),t.setElement(this),t.open()}}),e(".js-injector-boot #"+b).entwine({renderModal:function(e){var t=this,n=function(){return t.close()},i=function(){return t.handleInsert.apply(t,arguments)},r=this.getOriginalAttributes(),o=tinymce.activeEditor.selection,l=o.getContent()||"",a=o.getNode().tagName,s="A"!==a&&""===l.trim();d.default.render(u.default.createElement(v,{isOpen:e,type:"insert-link",onInsert:i,onClosed:n,title:!1,bodyClassName:"modal__dialog",className:"insert-link__dialog-wrapper--internal",fileAttributes:r,requireLinkText:s}),this[0])},buildAttributes:function(e){return{href:_.default.serialise({name:"file_link",properties:{id:e.ID}},!0)+(e.Anchor&&e.Anchor.length?"#"+e.Anchor:""),target:e.TargetBlank?"_blank":"",title:e.Description}},getOriginalAttributes:function(){var t=this.getElement().getEditor(),n=e(t.getSelectedNode()),i=(n.attr("href")||"").split("#");if(!i[0])return{};var r=_.default.match("file_link",!1,i[0]);return r?{ID:r.properties.id?parseInt(r.properties.id,10):0,Anchor:i[1]||"",Description:n.attr("title"),TargetBlank:!!n.attr("target")}:{}}})}),tinymce.PluginManager.add("sslinkfile",function(e){return x.init(e)}),t.default=x},0:function(e,t){e.exports=React},1:function(e,t){e.exports=i18n},10:function(e,t){e.exports=InsertMediaModal},2:function(e,t){e.exports=Injector},25:function(e,t){e.exports=TinyMCEActionRegistrar},5:function(e,t){e.exports=ReactDom},6:function(e,t){e.exports=jQuery},7:function(e,t){e.exports=ShortcodeSerialiser}}); \ No newline at end of file +/******/ (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] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = 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; +/******/ +/******/ // identity function for calling harmony imports with the correct context +/******/ __webpack_require__.i = function(value) { return value; }; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { +/******/ configurable: false, +/******/ enumerable: true, +/******/ get: getter +/******/ }); +/******/ } +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = "./client/src/entwine/TinyMCE_sslink-file.js"); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "./client/src/entwine/TinyMCE_sslink-file.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _TinyMCEActionRegistrar = __webpack_require__(25); + +var _TinyMCEActionRegistrar2 = _interopRequireDefault(_TinyMCEActionRegistrar); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactDom = __webpack_require__(5); + +var _reactDom2 = _interopRequireDefault(_reactDom); + +var _jquery = __webpack_require__(6); + +var _jquery2 = _interopRequireDefault(_jquery); + +var _ShortcodeSerialiser = __webpack_require__(7); + +var _ShortcodeSerialiser2 = _interopRequireDefault(_ShortcodeSerialiser); + +var _InsertMediaModal = __webpack_require__(10); + +var _InsertMediaModal2 = _interopRequireDefault(_InsertMediaModal); + +var _Injector = __webpack_require__(2); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var commandName = 'sslinkfile'; + +_TinyMCEActionRegistrar2.default.addAction('sslink', { + text: _i18n2.default._t('AssetAdmin.LINKLABEL_FILE', 'Link to a file'), + + onclick: function onclick(editor) { + return editor.execCommand(commandName); + } +}).addCommandWithUrlTest(commandName, /^\[file_link/); + +var plugin = { + init: function init(editor) { + editor.addCommand(commandName, function () { + var field = (0, _jquery2.default)('#' + editor.id).entwine('ss'); + + field.openLinkFileDialog(); + }); + } +}; + +var modalId = 'insert-link__dialog-wrapper--file'; +var InjectableInsertMediaModal = (0, _Injector.loadComponent)(_InsertMediaModal2.default); + +_jquery2.default.entwine('ss', function ($) { + $('.insert-link__dialog-wrapper--internal .nav-link, ' + '.insert-media-react__dialog-wrapper .breadcrumb__container a').entwine({ + onclick: function onclick(e) { + return e.preventDefault(); + } + }); + + $('textarea.htmleditor').entwine({ + openLinkFileDialog: function openLinkFileDialog() { + var dialog = $('#' + modalId); + + if (!dialog.length) { + dialog = $('
'); + $('body').append(dialog); + } + dialog.addClass('insert-link__dialog-wrapper'); + + dialog.setElement(this); + dialog.open(); + } + }); + + $('.js-injector-boot #' + modalId).entwine({ + renderModal: function renderModal(isOpen) { + var _this = this; + + var handleHide = function handleHide() { + return _this.close(); + }; + var handleInsert = function handleInsert() { + return _this.handleInsert.apply(_this, arguments); + }; + var attrs = this.getOriginalAttributes(); + var selection = tinymce.activeEditor.selection; + var selectionContent = selection.getContent() || ''; + var tagName = selection.getNode().tagName; + var requireLinkText = tagName !== 'A' && selectionContent.trim() === ''; + + _reactDom2.default.render(_react2.default.createElement(InjectableInsertMediaModal, { + isOpen: isOpen, + type: 'insert-link', + onInsert: handleInsert, + onClosed: handleHide, + title: false, + bodyClassName: 'modal__dialog', + className: 'insert-link__dialog-wrapper--internal', + fileAttributes: attrs, + requireLinkText: requireLinkText + }), this[0]); + }, + buildAttributes: function buildAttributes(data) { + var shortcode = _ShortcodeSerialiser2.default.serialise({ + name: 'file_link', + properties: { id: data.ID } + }, true); + + var anchor = data.Anchor && data.Anchor.length ? '#' + data.Anchor : ''; + var href = '' + shortcode + anchor; + + return { + href: href, + target: data.TargetBlank ? '_blank' : '', + title: data.Description + }; + }, + getOriginalAttributes: function getOriginalAttributes() { + var editor = this.getElement().getEditor(); + var node = $(editor.getSelectedNode()); + + var hrefParts = (node.attr('href') || '').split('#'); + if (!hrefParts[0]) { + return {}; + } + + var shortcode = _ShortcodeSerialiser2.default.match('file_link', false, hrefParts[0]); + if (!shortcode) { + return {}; + } + + return { + ID: shortcode.properties.id ? parseInt(shortcode.properties.id, 10) : 0, + Anchor: hrefParts[1] || '', + Description: node.attr('title'), + TargetBlank: !!node.attr('target') + }; + } + }); +}); + +tinymce.PluginManager.add(commandName, function (editor) { + return plugin.init(editor); +}); + +exports.default = plugin; + +/***/ }), + +/***/ 0: +/***/ (function(module, exports) { + +module.exports = React; + +/***/ }), + +/***/ 1: +/***/ (function(module, exports) { + +module.exports = i18n; + +/***/ }), + +/***/ 10: +/***/ (function(module, exports) { + +module.exports = InsertMediaModal; + +/***/ }), + +/***/ 2: +/***/ (function(module, exports) { + +module.exports = Injector; + +/***/ }), + +/***/ 25: +/***/ (function(module, exports) { + +module.exports = TinyMCEActionRegistrar; + +/***/ }), + +/***/ 5: +/***/ (function(module, exports) { + +module.exports = ReactDom; + +/***/ }), + +/***/ 6: +/***/ (function(module, exports) { + +module.exports = jQuery; + +/***/ }), + +/***/ 7: +/***/ (function(module, exports) { + +module.exports = ShortcodeSerialiser; + +/***/ }) + +/******/ }); +//# sourceMappingURL=TinyMCE_sslink-file.js.map \ No newline at end of file diff --git a/client/dist/js/TinyMCE_ssmedia.js b/client/dist/js/TinyMCE_ssmedia.js index b900ddd6a..aee5f207d 100644 --- a/client/dist/js/TinyMCE_ssmedia.js +++ b/client/dist/js/TinyMCE_ssmedia.js @@ -1 +1,508 @@ -!function(t){function e(n){if(i[n])return i[n].exports;var a=i[n]={i:n,l:!1,exports:{}};return t[n].call(a.exports,a,a.exports,e),a.l=!0,a.exports}var i={};e.m=t,e.c=i,e.i=function(t){return t},e.d=function(t,i,n){e.o(t,i)||Object.defineProperty(t,i,{configurable:!1,enumerable:!0,get:n})},e.n=function(t){var i=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(i,"a",i),i},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s="./client/src/entwine/TinyMCE_ssmedia.js")}({"./client/src/entwine/TinyMCE_ssmedia.js":function(t,e,i){"use strict";function n(t){return t&&t.__esModule?t:{default:t}}var a=i(6),r=n(a),o=i(1),s=n(o),d=i(0),l=n(d),c=i(5),u=n(c),f=i(2),m=i(10),p=n(m),g=i(7),h=n(g),v=(0,f.loadComponent)(p.default),_='img[data-shortcode="image"]';!function(){var t={init:function(t){var e=s.default._t("AssetAdmin.INSERT_FROM_FILES","Insert from Files");t.addButton("ssmedia",{icon:"image",title:e,cmd:"ssmedia"}),t.addMenuItem("ssmedia",{icon:"image",text:e,cmd:"ssmedia"}),t.addCommand("ssmedia",function(){(0,r.default)("#"+t.id).entwine("ss").openMediaDialog()}),t.on("BeforeExecCommand",function(e){var i=e.command,n=e.ui,a=e.value;"mceAdvImage"!==i&&"mceImage"!==i||(e.preventDefault(),t.execCommand("ssmedia",n,a))}),t.on("SaveContent",function(t){var e=(0,r.default)(t.content);e.find(_).add(e.filter(_)).each(function(){var t=(0,r.default)(this),e={src:t.attr("src"),id:t.data("id"),width:t.attr("width"),height:t.attr("height"),class:t.attr("class"),title:t.attr("title"),alt:t.attr("alt")},i=h.default.serialise({name:"image",properties:e,wrapped:!1});t.replaceWith(i)}),t.content="",e.each(function(){void 0!==this.outerHTML&&(t.content+=this.outerHTML)})}),t.on("BeforeSetContent",function(t){for(var e=t.content,i=h.default.match("image",!1,e);i;){var n=i.properties,a=(0,r.default)("").attr(Object.assign({},n,{id:void 0,"data-id":n.id,"data-shortcode":"image"})).addClass("ss-htmleditorfield-file image");e=e.replace(i.original,(0,r.default)("
").append(a).html()),i=h.default.match("image",!1,e)}t.content=e})}};tinymce.PluginManager.add("ssmedia",function(e){return t.init(e)})}(),r.default.entwine("ss",function(t){t(".insert-media-react__dialog-wrapper .nav-link, .insert-media-react__dialog-wrapper .breadcrumb__container a").entwine({onclick:function(t){return t.preventDefault()}}),t(".js-injector-boot #insert-media-react__dialog-wrapper").entwine({Element:null,Data:{},onunmatch:function(){this._clearModal()},_clearModal:function(){u.default.unmountComponentAtNode(this[0])},open:function(){this._renderModal(!0)},close:function(){this._renderModal(!1)},_renderModal:function(t){var e=this,i=function(){return e.close()},n=function(){return e._handleInsert.apply(e,arguments)},a=this.getOriginalAttributes(),r=tinymce.activeEditor.selection,o=r.getContent()||"",s=r.getNode().tagName,d="A"!==s&&("IMG"===s||""===o.trim());delete a.url,u.default.render(l.default.createElement(v,{title:!1,type:"insert-media",isOpen:t,onInsert:n,onClosed:i,bodyClassName:"modal__dialog",className:"insert-media-react__dialog-wrapper",requireLinkText:d,fileAttributes:a}),this[0])},_handleInsert:function(t,e){var i=!1;this.setData(Object.assign({},t,e));try{switch(e?e.category:"image"){case"image":i=this.insertImage();break;default:i=this.insertFile()}}catch(t){this.statusMessage(t,"bad")}return i&&this.close(),Promise.resolve()},getOriginalAttributes:function(){var e=this.getElement();if(!e)return{};var i=e.getEditor().getSelectedNode();if(!i)return{};var n=t(i),a=(n.attr("href")||"").split("#");if(a[0]){var r=h.default.match("file_link",!1,a[0]);if(r)return{ID:r.properties.id?parseInt(r.properties.id,10):0,Anchor:a[1]||"",Description:n.attr("title"),TargetBlank:!!n.attr("target")}}var o=n.parent(".captionImage").find(".caption"),s={url:n.attr("src"),AltText:n.attr("alt"),Width:n.attr("width"),Height:n.attr("height"),TitleTooltip:n.attr("title"),Alignment:this.findPosition(n.attr("class")),Caption:o.text(),ID:n.attr("data-id")};return["Width","Height","ID"].forEach(function(t){s[t]="string"==typeof s[t]?parseInt(s[t],10):null}),s},findPosition:function(t){var e=["leftAlone","center","rightAlone","left","right"];if("string"!=typeof t)return"";var i=t.split(" ");return e.find(function(t){return i.indexOf(t)>-1})},getAttributes:function(){var t=this.getData();return{src:t.url,alt:t.AltText,width:t.Width,height:t.Height,title:t.TitleTooltip,class:t.Alignment,"data-id":t.ID,"data-shortcode":"image"}},getExtraData:function(){var t=this.getData();return{CaptionText:t&&t.Caption}},insertFile:function(){var e=this.getData(),i=this.getElement().getEditor(),n=t(i.getSelectedNode()),a=h.default.serialise({name:"file_link",properties:{id:e.ID}},!0),r=tinymce.activeEditor.selection,o=r.getContent()||"",s=o||e.Text||e.filename;n.is("a")&&n.html()&&(s="");var d={href:a,target:e.TargetBlank?"_blank":"",title:e.Description};if(n.is("img")){s=e.Text||e.filename;var l=t("").attr(d).text(s);n.replaceWith(l),i.addUndo(),i.repaint()}else this.insertLinkInEditor(d,s);return!0},insertImage:function(){var e=this.getElement();if(!e)return!1;var i=e.getEditor();if(!i)return!1;var n=t(i.getSelectedNode()),a=this.getAttributes(),r=this.getExtraData(),o=n&&n.is("img,a")?n:null;o&&o.parent().is(".captionImage")&&(o=o.parent());var s=n&&n.is("img")?n:t("");s.attr(a).addClass("ss-htmleditorfield-file image");var d=s.parent(".captionImage"),l=d.find(".caption");r.CaptionText?(d.length||(d=t("
")),d.attr("class","captionImage "+a.class).removeAttr("data-mce-style").width(a.width),l.length||(l=t('

').appendTo(d)),l.attr("class","caption "+a.class).text(r.CaptionText)):(d=null,l=null);var c=d||s;return o&&o.not(c).length&&o.replaceWith(c),d&&d.prepend(s),o||(i.repaint(),i.insertContent(t("
").append(c).html(),{skip_undo:1})),i.addUndo(),i.repaint(),!0},statusMessage:function(e,i){var n=t("
").text(e).html();t.noticeAdd({text:n,type:i,stayTime:5e3,inEffect:{left:"0",opacity:"show"}})}})})},0:function(t,e){t.exports=React},1:function(t,e){t.exports=i18n},10:function(t,e){t.exports=InsertMediaModal},2:function(t,e){t.exports=Injector},5:function(t,e){t.exports=ReactDom},6:function(t,e){t.exports=jQuery},7:function(t,e){t.exports=ShortcodeSerialiser}}); \ No newline at end of file +/******/ (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] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = 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; +/******/ +/******/ // identity function for calling harmony imports with the correct context +/******/ __webpack_require__.i = function(value) { return value; }; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { +/******/ configurable: false, +/******/ enumerable: true, +/******/ get: getter +/******/ }); +/******/ } +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = "./client/src/entwine/TinyMCE_ssmedia.js"); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "./client/src/entwine/TinyMCE_ssmedia.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +var _jquery = __webpack_require__(6); + +var _jquery2 = _interopRequireDefault(_jquery); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactDom = __webpack_require__(5); + +var _reactDom2 = _interopRequireDefault(_reactDom); + +var _Injector = __webpack_require__(2); + +var _InsertMediaModal = __webpack_require__(10); + +var _InsertMediaModal2 = _interopRequireDefault(_InsertMediaModal); + +var _ShortcodeSerialiser = __webpack_require__(7); + +var _ShortcodeSerialiser2 = _interopRequireDefault(_ShortcodeSerialiser); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var InjectableInsertMediaModal = (0, _Injector.loadComponent)(_InsertMediaModal2.default); + +var filter = 'img[data-shortcode="image"]'; + +(function () { + var ssmedia = { + init: function init(ed) { + var title = _i18n2.default._t('AssetAdmin.INSERT_FROM_FILES', 'Insert from Files'); + ed.addButton('ssmedia', { + icon: 'image', + title: title, + cmd: 'ssmedia' + }); + ed.addMenuItem('ssmedia', { + icon: 'image', + text: title, + cmd: 'ssmedia' + }); + + ed.addCommand('ssmedia', function () { + (0, _jquery2.default)('#' + ed.id).entwine('ss').openMediaDialog(); + }); + + ed.on('BeforeExecCommand', function (e) { + var cmd = e.command; + var ui = e.ui; + var val = e.value; + if (cmd === 'mceAdvImage' || cmd === 'mceImage') { + e.preventDefault(); + ed.execCommand('ssmedia', ui, val); + } + }); + + ed.on('SaveContent', function (o) { + var content = (0, _jquery2.default)(o.content); + + content.find(filter).add(content.filter(filter)).each(function () { + var el = (0, _jquery2.default)(this); + var properties = { + src: el.attr('src'), + id: el.data('id'), + width: el.attr('width'), + height: el.attr('height'), + class: el.attr('class'), + + title: el.attr('title'), + alt: el.attr('alt') + }; + var shortCode = _ShortcodeSerialiser2.default.serialise({ + name: 'image', + properties: properties, + wrapped: false + }); + el.replaceWith(shortCode); + }); + + o.content = ''; + content.each(function () { + if (this.outerHTML !== undefined) { + o.content += this.outerHTML; + } + }); + }); + ed.on('BeforeSetContent', function (o) { + var content = o.content; + + var match = _ShortcodeSerialiser2.default.match('image', false, content); + while (match) { + var attrs = match.properties; + var el = (0, _jquery2.default)('').attr(Object.assign({}, attrs, { + id: undefined, + 'data-id': attrs.id, + 'data-shortcode': 'image' + })).addClass('ss-htmleditorfield-file image'); + content = content.replace(match.original, (0, _jquery2.default)('
').append(el).html()); + + match = _ShortcodeSerialiser2.default.match('image', false, content); + } + + o.content = content; + }); + } + }; + + tinymce.PluginManager.add('ssmedia', function (editor) { + return ssmedia.init(editor); + }); +})(); + +_jquery2.default.entwine('ss', function ($) { + $('.insert-media-react__dialog-wrapper .nav-link, ' + '.insert-media-react__dialog-wrapper .breadcrumb__container a').entwine({ + onclick: function onclick(e) { + return e.preventDefault(); + } + }); + + $('.js-injector-boot #insert-media-react__dialog-wrapper').entwine({ + Element: null, + + Data: {}, + + onunmatch: function onunmatch() { + this._clearModal(); + }, + _clearModal: function _clearModal() { + _reactDom2.default.unmountComponentAtNode(this[0]); + }, + open: function open() { + this._renderModal(true); + }, + close: function close() { + this._renderModal(false); + }, + _renderModal: function _renderModal(isOpen) { + var _this = this; + + var handleHide = function handleHide() { + return _this.close(); + }; + var handleInsert = function handleInsert() { + return _this._handleInsert.apply(_this, arguments); + }; + var attrs = this.getOriginalAttributes(); + var selection = tinymce.activeEditor.selection; + var selectionContent = selection.getContent() || ''; + var tagName = selection.getNode().tagName; + + var requireLinkText = tagName !== 'A' && (tagName === 'IMG' || selectionContent.trim() === ''); + + delete attrs.url; + + _reactDom2.default.render(_react2.default.createElement(InjectableInsertMediaModal, { + title: false, + type: 'insert-media', + isOpen: isOpen, + onInsert: handleInsert, + onClosed: handleHide, + bodyClassName: 'modal__dialog', + className: 'insert-media-react__dialog-wrapper', + requireLinkText: requireLinkText, + fileAttributes: attrs + }), this[0]); + }, + _handleInsert: function _handleInsert(data, file) { + var result = false; + this.setData(Object.assign({}, data, file)); + + try { + var category = null; + if (file) { + category = file.category; + } else { + category = 'image'; + } + switch (category) { + case 'image': + result = this.insertImage(); + break; + default: + result = this.insertFile(); + } + } catch (e) { + this.statusMessage(e, 'bad'); + } + + if (result) { + this.close(); + } + return Promise.resolve(); + }, + getOriginalAttributes: function getOriginalAttributes() { + var $field = this.getElement(); + if (!$field) { + return {}; + } + + var node = $field.getEditor().getSelectedNode(); + if (!node) { + return {}; + } + var $node = $(node); + + var hrefParts = ($node.attr('href') || '').split('#'); + if (hrefParts[0]) { + var shortcode = _ShortcodeSerialiser2.default.match('file_link', false, hrefParts[0]); + if (shortcode) { + return { + ID: shortcode.properties.id ? parseInt(shortcode.properties.id, 10) : 0, + Anchor: hrefParts[1] || '', + Description: $node.attr('title'), + TargetBlank: !!$node.attr('target') + }; + } + } + + var $caption = $node.parent('.captionImage').find('.caption'); + + var attr = { + url: $node.attr('src'), + AltText: $node.attr('alt'), + Width: $node.attr('width'), + Height: $node.attr('height'), + TitleTooltip: $node.attr('title'), + Alignment: this.findPosition($node.attr('class')), + Caption: $caption.text(), + ID: $node.attr('data-id') + }; + + ['Width', 'Height', 'ID'].forEach(function (item) { + attr[item] = typeof attr[item] === 'string' ? parseInt(attr[item], 10) : null; + }); + + return attr; + }, + findPosition: function findPosition(cssClass) { + var alignments = ['leftAlone', 'center', 'rightAlone', 'left', 'right']; + if (typeof cssClass !== 'string') { + return ''; + } + var classes = cssClass.split(' '); + return alignments.find(function (alignment) { + return classes.indexOf(alignment) > -1; + }); + }, + getAttributes: function getAttributes() { + var data = this.getData(); + + return { + src: data.url, + alt: data.AltText, + width: data.Width, + height: data.Height, + title: data.TitleTooltip, + class: data.Alignment, + 'data-id': data.ID, + 'data-shortcode': 'image' + }; + }, + getExtraData: function getExtraData() { + var data = this.getData(); + return { + CaptionText: data && data.Caption + }; + }, + insertFile: function insertFile() { + var data = this.getData(); + + var editor = this.getElement().getEditor(); + var $node = $(editor.getSelectedNode()); + + var shortcode = _ShortcodeSerialiser2.default.serialise({ + name: 'file_link', + properties: { id: data.ID } + }, true); + + var selection = tinymce.activeEditor.selection; + var selectionContent = selection.getContent() || ''; + var linkText = selectionContent || data.Text || data.filename; + + if ($node.is('a') && $node.html()) { + linkText = ''; + } + + var linkAttributes = { + href: shortcode, + target: data.TargetBlank ? '_blank' : '', + title: data.Description + }; + + if ($node.is('img')) { + linkText = data.Text || data.filename; + var newLink = $('').attr(linkAttributes).text(linkText); + $node.replaceWith(newLink); + editor.addUndo(); + editor.repaint(); + } else { + this.insertLinkInEditor(linkAttributes, linkText); + } + return true; + }, + insertImage: function insertImage() { + var $field = this.getElement(); + if (!$field) { + return false; + } + var editor = $field.getEditor(); + if (!editor) { + return false; + } + var node = $(editor.getSelectedNode()); + + var attrs = this.getAttributes(); + var extraData = this.getExtraData(); + + var replacee = node && node.is('img,a') ? node : null; + if (replacee && replacee.parent().is('.captionImage')) replacee = replacee.parent(); + + var img = node && node.is('img') ? node : $(''); + img.attr(attrs).addClass('ss-htmleditorfield-file image'); + + var container = img.parent('.captionImage'); + var caption = container.find('.caption'); + + if (extraData.CaptionText) { + if (!container.length) { + container = $('
'); + } + + container.attr('class', 'captionImage ' + attrs.class).removeAttr('data-mce-style').width(attrs.width); + + if (!caption.length) { + caption = $('

').appendTo(container); + } + + caption.attr('class', 'caption ' + attrs.class).text(extraData.CaptionText); + } else { + container = null; + caption = null; + } + + var replacer = container || img; + + if (replacee && replacee.not(replacer).length) { + replacee.replaceWith(replacer); + } + + if (container) { + container.prepend(img); + } + + if (!replacee) { + editor.repaint(); + editor.insertContent($('
').append(replacer).html(), { skip_undo: 1 }); + } + + editor.addUndo(); + editor.repaint(); + return true; + }, + statusMessage: function statusMessage(text, type) { + var content = $('
').text(text).html(); + $.noticeAdd({ + text: content, + type: type, + stayTime: 5000, + inEffect: { left: '0', opacity: 'show' } + }); + } + }); +}); + +/***/ }), + +/***/ 0: +/***/ (function(module, exports) { + +module.exports = React; + +/***/ }), + +/***/ 1: +/***/ (function(module, exports) { + +module.exports = i18n; + +/***/ }), + +/***/ 10: +/***/ (function(module, exports) { + +module.exports = InsertMediaModal; + +/***/ }), + +/***/ 2: +/***/ (function(module, exports) { + +module.exports = Injector; + +/***/ }), + +/***/ 5: +/***/ (function(module, exports) { + +module.exports = ReactDom; + +/***/ }), + +/***/ 6: +/***/ (function(module, exports) { + +module.exports = jQuery; + +/***/ }), + +/***/ 7: +/***/ (function(module, exports) { + +module.exports = ShortcodeSerialiser; + +/***/ }) + +/******/ }); +//# sourceMappingURL=TinyMCE_ssmedia.js.map \ No newline at end of file diff --git a/client/dist/js/bundle.js b/client/dist/js/bundle.js index 261c97d04..163a5368b 100644 --- a/client/dist/js/bundle.js +++ b/client/dist/js/bundle.js @@ -1 +1,26138 @@ -!function(e){function t(n){if(o[n])return o[n].exports;var r=o[n]={i:n,l:!1,exports:{}};return e[n].call(r.exports,r,r.exports,t),r.l=!0,r.exports}var o={};t.m=e,t.c=o,t.i=function(e){return e},t.d=function(e,o,n){t.o(e,o)||Object.defineProperty(e,o,{configurable:!1,enumerable:!0,get:n})},t.n=function(e){var o=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(o,"a",o),o},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s="./client/src/bundles/bundle.js")}({"./client/src/boot/applyTransform.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var r=o(2),s=n(r),l=o("./client/src/transforms/AssetAdmin/insertAssetModal.js"),i=n(l),a=o("./client/src/transforms/FormAction/ownerAwareUnpublish.js"),d=n(a),u=o("./client/src/transforms/TreeDropdownField/moveTreeDropdownField.js"),c=n(u),p=function(){s.default.transform("insert-media-modal",function(e){e.form.alterSchema("AssetAdmin.EditForm.fileInsertForm",i.default)}),s.default.transform("move-form-disabled",function(e){e.component("TreeDropdownField.AssetAdmin.MoveForm",c.default)}),s.default.transform("owner-unpublishing",function(e){e.component("FormAction.AssetAdmin.EditForm.action_unpublish",d.default)})};t.default=p},"./client/src/boot/index.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}var r=o(20),s=n(r),l=o(34),i=n(l),a=o("./client/src/containers/AssetAdmin/AssetAdminRouter.js"),d=n(a),u=o("./client/src/boot/applyTransform.js"),c=n(u),p=o("./client/src/boot/registerReducers.js"),f=n(p),h=o("./client/src/boot/registerComponents.js"),m=n(h),_=o("./client/src/boot/registerQueries.js"),g=n(_);document.addEventListener("DOMContentLoaded",function(){(0,m.default)(),(0,c.default)();var e=s.default.getSection("SilverStripe\\AssetAdmin\\Controller\\AssetAdmin");i.default.add({path:e.url,component:d.default,indexRoute:{component:d.default},childRoutes:[{path:"show/:folderId/:viewAction/:fileId",component:d.default},{path:"show/:folderId/:viewAction",component:d.default},{path:"show/:folderId",component:d.default}]}),(0,g.default)(),(0,f.default)()})},"./client/src/boot/registerComponents.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var r=o(2),s=n(r),l=o("./client/src/components/UploadField/UploadField.js"),i=n(l),a=o("./client/src/components/UploadField/UploadFieldItem.js"),d=n(a),u=o("./client/src/components/AssetDropzone/AssetDropzone.js"),c=n(u),p=o(10),f=n(p),h=o("./client/src/components/PreviewImageField/PreviewImageField.js"),m=n(h),_=o("./client/src/components/ProportionConstraintField/ProportionConstraintField.js"),g=n(_),y=o("./client/src/containers/HistoryList/HistoryList.js"),v=n(y),b=o("./client/src/components/GalleryToolbar/GalleryToolbar.js"),E=n(b),j=o("./client/src/components/GalleryItem/GalleryItem.js"),S=function(){s.default.component.registerMany({UploadField:i.default,UploadFieldItem:d.default,PreviewImageField:m.default,HistoryList:v.default,ProportionConstraintField:g.default,AssetDropzone:c.default,InsertMediaModal:f.default,GalleryToolbar:E.default,GalleryItemFile:j.File,GalleryItemFolder:j.Folder})};t.default=S},"./client/src/boot/registerQueries.js":function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var n=o(2),r=function(e){return e&&e.__esModule?e:{default:e}}(n),s=o("./client/src/lib/fileFragments.js"),l=function(){r.default.query.registerFragment("FileInterfaceFields",s.fileInterface),r.default.query.registerFragment("FileFields",s.file),r.default.query.registerFragment("FolderFields",s.folder)};t.default=l},"./client/src/boot/registerReducers.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var r=o(2),s=n(r),l=o(4),i=o("./client/src/state/gallery/GalleryReducer.js"),a=n(i),d=o("./client/src/state/queuedFiles/QueuedFilesReducer.js"),u=n(d),c=o("./client/src/state/uploadField/UploadFieldReducer.js"),p=n(c),f=o("./client/src/state/previewField/PreviewFieldReducer.js"),h=n(f),m=o("./client/src/state/imageLoad/ImageLoadReducer.js"),_=n(m),g=function(){s.default.reducer.register("assetAdmin",(0,l.combineReducers)({gallery:a.default,queuedFiles:u.default,uploadField:p.default,previewField:h.default,imageLoad:_.default}))};t.default=g},"./client/src/bundles/bundle.js":function(e,t,o){"use strict";o("./node_modules/expose-loader/index.js?InsertMediaModal!./client/src/containers/InsertMediaModal/InsertMediaModal.js-exposed"),o("./node_modules/expose-loader/index.js?InsertEmbedModal!./client/src/components/InsertEmbedModal/InsertEmbedModal.js-exposed"),o("./client/src/boot/index.js"),o("./client/src/entwine/UploadField/UploadFieldEntwine.js")},"./client/src/components/AssetDropzone/AssetDropzone.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,"__esModule",{value:!0});var i=Object.assign||function(e){for(var t=1;t2});return t<2?p.default.createElement(m.Button,{className:o,key:e.value,onClick:this.handleChangeValue,value:e.value},e.label):p.default.createElement(m.DropdownItem,{type:"button",className:o,key:e.value,onClick:this.handleChangeValue,value:e.value},e.label)}},{key:"render",value:function(){var e=this;if(!this.props.items.length)return null;var t=this.props.actions.filter(function(t){return!t.canApply||t.canApply(e.props.items)});if(t=t.map(this.renderChild),!t.length)return null;var o=this.props,n=o.ActionMenu,r=o.showCount,s=this.props.items.length;return p.default.createElement("div",{className:"bulk-actions fieldholder-small"},r&&p.default.createElement("div",{className:"bulk-actions-counter"},s),t.slice(0,2),t.length>2&&n?p.default.createElement(n,{id:"BulkActions",className:"bulk-actions__more-actions-menu"},t.slice(2)):t.slice(2))}}]),t}(c.Component);y.propTypes={items:c.PropTypes.array,actions:c.PropTypes.arrayOf(c.PropTypes.shape({value:c.PropTypes.string.isRequired,label:c.PropTypes.string.isRequired,className:c.PropTypes.string,destructive:c.PropTypes.bool,callback:c.PropTypes.func,canApply:c.PropTypes.func,confirm:c.PropTypes.func})),ActionMenu:c.PropTypes.oneOfType([c.PropTypes.node,c.PropTypes.func]),showCount:c.PropTypes.bool},y.defaultProps={items:[],actions:[],ActionMenu:null,total:null,showCount:!0,totalReachedMessage:u.default._t("")};var v=(0,f.connect)(i)(y);t.Component=y,t.default=(0,h.inject)(["ActionMenu"],function(e){return{ActionMenu:e}},function(){return"BulkActions"})(v)},"./client/src/components/GalleryItem/GalleryItem.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){var o={};for(var n in e)t.indexOf(n)>=0||Object.prototype.hasOwnProperty.call(e,n)&&(o[n]=e[n]);return o}function s(e,t,o){return t in e?Object.defineProperty(e,t,{value:o,enumerable:!0,configurable:!0,writable:!0}):e[t]=o,e}function l(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function i(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function a(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function d(e){return e.item.thumbnail&&"image"===e.item.category&&e.item.exists&&!e.item.queuedId&&e.sectionConfig.imageRetry.minRetry&&e.sectionConfig.imageRetry.maxRetry}function u(e,t){if(d(t)){var o=e.assetAdmin.imageLoad,n=o.files.find(function(e){return t.item.thumbnail===e.url});return{loadState:n&&n.status||L.default.NONE}}return{loadState:L.default.DISABLED}}function c(e){return{actions:{imageLoad:(0,D.bindActionCreators)(R,e)}}}Object.defineProperty(t,"__esModule",{value:!0}),t.File=t.Folder=t.Component=void 0;var p=Object.assign||function(e){for(var t=1;t0}},{key:"missing",value:function(){return!this.exists()&&this.saved()}},{key:"uploading",value:function(){return this.props.item.queuedId&&!this.saved()}},{key:"exists",value:function(){return this.props.item.exists}},{key:"isImage",value:function(){return"image"===this.props.item.category}},{key:"canBatchSelect",value:function(){return this.props.selectable&&this.props.item.canEdit}},{key:"hasError",value:function(){var e=!1;return this.props.item.message&&(e="error"===this.props.item.message.type),e}},{key:"handleActivate",value:function(e){e.stopPropagation(),"function"==typeof this.props.onActivate&&this.saved()&&this.props.onActivate(e,this.props.item)}},{key:"handleSelect",value:function(e){e.stopPropagation(),e.preventDefault(),"function"==typeof this.props.onSelect&&this.props.onSelect(e,this.props.item)}},{key:"handleKeyDown",value:function(e){E.default.SPACE_KEY_CODE===e.keyCode&&(e.preventDefault(),this.canBatchSelect()&&this.handleSelect(e)),E.default.RETURN_KEY_CODE===e.keyCode&&this.handleActivate(e)}},{key:"handleCancelUpload",value:function(e){e.stopPropagation(),e.preventDefault(),this.hasError()?this.props.onRemoveErroredUpload(this.props.item):this.props.onCancelUpload&&this.props.onCancelUpload(this.props.item)}},{key:"render",value:function(){var e=this,t=null,o=null,n=null,r=this.props.item,s=r.id,l=r.queuedId,i=s?"item-"+s:"queued-"+l;if(this.props.selectable&&(this.canBatchSelect()&&(t=this.handleSelect),o="font-icon-tick"),this.uploading())t=this.handleCancelUpload,o="font-icon-cancel";else if(this.exists()){var a=m.default._t("AssetAdmin.DETAILS","Details");n=g.default.createElement("div",{className:"gallery-item--overlay font-icon-edit"},a)}var d=this.props.badge,u={className:"gallery-item__checkbox",type:"checkbox",title:m.default._t("AssetAdmin.SELECT","Select"),tabIndex:-1,onMouseDown:U,id:i},c=["gallery-item__checkbox-label",o];this.canBatchSelect()||(u.disabled=!0,c.push("gallery-item__checkbox-label--disabled"));var f={className:c.join(" "),onClick:t};return g.default.createElement("div",{className:this.getItemClassNames(),"data-id":this.props.item.id,tabIndex:0,role:"button",onKeyDown:this.handleKeyDown,onClick:this.handleActivate},!!d&&g.default.createElement(F.default,{className:"gallery-item__badge",status:d.status,message:d.message}),g.default.createElement("div",{ref:function(t){e.thumbnail=t},className:this.getThumbnailClassNames(),style:this.getThumbnailStyles()},n,this.getStatusFlags()),this.getProgressBar(),this.getErrorMessage(),this.props.children,g.default.createElement("div",{className:"gallery-item__title",ref:function(t){e.title=t}},g.default.createElement("label",p({},f,{htmlFor:i}),g.default.createElement("input",u)),this.props.item.title))}}]),t}(_.Component);G.propTypes={sectionConfig:x.default,item:S.default,loadState:_.PropTypes.oneOf(Object.values(L.default)),highlighted:_.PropTypes.bool,selected:_.PropTypes.bool,isDropping:_.PropTypes.bool,isDragging:_.PropTypes.bool,message:_.PropTypes.shape({value:_.PropTypes.string,type:_.PropTypes.string}),selectable:_.PropTypes.bool,onActivate:_.PropTypes.func,onSelect:_.PropTypes.func,onCancelUpload:_.PropTypes.func,onRemoveErroredUpload:_.PropTypes.func,badge:_.PropTypes.shape({status:_.PropTypes.string,message:_.PropTypes.string}),updateStatusFlags:_.PropTypes.func,updateProgressBar:_.PropTypes.func,updateErrorMessage:_.PropTypes.func},G.defaultProps={item:{},sectionConfig:{imageRetry:{}},updateStatusFlags:function(e){return e},updateProgressBar:function(e){return e},updateErrorMessage:function(e){return e}};var B=(0,A.connect)(u,c)(G),H=(0,k.createSelectable)((0,P.default)("GalleryItem")(B)),q=(0,k.createSelectable)((0,T.default)("GalleryItem")(H));t.Component=G,t.Folder=q,t.File=H,t.default=B},"./client/src/components/GalleryItem/GalleryItemDragLayer.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,"__esModule",{value:!0});var i=Object.assign||function(e){for(var t=1;t1?u.default.createElement("div",{key:"1",className:"gallery-item__drag-shadow"}):null,t>2?u.default.createElement("div",{key:"2",className:"gallery-item__drag-shadow gallery-item__drag-shadow--second"}):null];return u.default.createElement("div",{className:"gallery-item__drag-layer"},u.default.createElement("div",{className:"gallery-item__drag-layer-item",style:this.getOffset()},u.default.createElement("div",{className:"gallery-item__drag-layer-preview"},o,u.default.createElement(f.default,i({},e.props,{isDragging:!0}))),t>1?u.default.createElement(m.default,{className:"gallery-item__drag-layer-count",status:"info",message:""+t}):null))}}]),t}(d.Component);_.propTypes={item:d.PropTypes.object,offset:d.PropTypes.shape({x:d.PropTypes.number.isRequired,y:d.PropTypes.number.isRequired}),isDragging:d.PropTypes.bool.isRequired};var g=function(e){return{item:e.getItem(),offset:e.getInitialClientOffset(),dragged:e.getDifferenceFromInitialOffset(),isDragging:e.isDragging()}};t.default=(0,c.DragLayer)(g)(_)},"./client/src/components/GalleryItem/draggable.js":function(e,t,o){"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function r(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function s(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function l(e){var t={canDrag:function(e){return e.canDrag},beginDrag:function(e){var t=e.item.id;"function"==typeof e.onDrag&&e.onDrag(!0,t);var o=e.selectedFiles.concat([]);return o.includes(t)||o.push(t),{selected:o,props:e}},endDrag:function(e){var t=e.item.id;"function"==typeof e.onDrag&&e.onDrag(!1,t)}},o=function(e,t){return{connectDragPreview:e.dragPreview(),connectDragSource:e.dragSource(),isDragging:t.isDragging()}},l=(0,u.DragSource)(e,t,o);return function(e){var t=function(t){function o(){return n(this,o),r(this,(o.__proto__||Object.getPrototypeOf(o)).apply(this,arguments))}return s(o,t),i(o,[{key:"componentDidMount",value:function(){this.props.connectDragPreview((0,c.getEmptyImage)(),{captureDraggingState:!0})}},{key:"render",value:function(){var t=this.props.connectDragSource,o=d.default.createElement(e,this.props);return t("string"==typeof o.type?o:d.default.createElement("div",{className:"gallery-item__draggable"},o))}}]),o}(a.Component);return t.propTypes={connectDragSource:a.PropTypes.func.isRequired,connectDragPreview:a.PropTypes.func.isRequired,item:a.PropTypes.shape({id:a.PropTypes.number.isRequired}).isRequired,onDrag:a.PropTypes.func,selectedFiles:a.PropTypes.arrayOf(a.PropTypes.number)},l(t)}}Object.defineProperty(t,"__esModule",{value:!0});var i=function(){function e(e,t){for(var o=0;o0&&r<100?f.default.createElement("div",{className:"preview-image-field__progress"},f.default.createElement("div",{className:"preview-image-field__progress-bar",style:{width:r+"%"}})):null,i=this.props.upload.message,a=null;return i?a=f.default.createElement("div",{className:"preview-image-field__message preview-image-field__message--"+i.type},i.value):100===r&&(a=f.default.createElement("div",{className:"preview-image-field__message preview-image-field__message--success"},c.default._t("AssetAdmin.REPlACE_FILE_SUCCESS","Upload successful, the file will be replaced when you Save."))),f.default.createElement("div",{className:"editor__thumbnail-container"},s||n,l,a)}},{key:"renderToolbar",value:function(){var e=this.canEdit();return this.props.data.url||e?f.default.createElement("div",{className:"preview-image-field__toolbar fill-height"},this.props.data.url?f.default.createElement("a",{href:this.props.data.url,target:"_blank",className:this.getButtonClasses("link")},"Open"):null,e?f.default.createElement("button",{id:"preview-replace-button",onClick:this.preventDefault,className:this.getButtonClasses("replace"),type:"button"},"Replace"):null,this.props.upload.progress||this.props.upload.message?f.default.createElement("button",{onClick:this.handleCancelUpload,className:this.getButtonClasses("remove"),type:"button"},"Remove"):null):null}},{key:"render",value:function(){var e=this.getDropzoneProps();if(this.canEdit())return f.default.createElement(m.default,e,this.renderImage(),this.renderToolbar());var t=["preview-image-field__container",this.props.className,this.props.extraClass];return f.default.createElement("div",{className:t.join(" ")},this.renderImage(),this.renderToolbar())}}]),t}(p.Component);O.propTypes={id:p.PropTypes.string.isRequired,name:p.PropTypes.string,className:p.PropTypes.string,extraClass:p.PropTypes.string,readOnly:p.PropTypes.bool,disabled:p.PropTypes.bool,onAutofill:p.PropTypes.func,formid:p.PropTypes.string,nameValue:p.PropTypes.string,data:p.PropTypes.shape({id:p.PropTypes.number,parentid:p.PropTypes.number,version:p.PropTypes.number,url:p.PropTypes.string,mock:p.PropTypes.bool,exists:p.PropTypes.bool,preview:p.PropTypes.string,category:p.PropTypes.string,nameField:p.PropTypes.string,uploadFileEndpoint:p.PropTypes.shape({url:p.PropTypes.string.isRequired,method:p.PropTypes.string.isRequired,payloadFormat:p.PropTypes.string}),initialValues:p.PropTypes.object}).isRequired,upload:p.PropTypes.shape({url:p.PropTypes.string,progress:p.PropTypes.number,xhr:p.PropTypes.object,category:p.PropTypes.string,message:p.PropTypes.shape({type:p.PropTypes.string.isRequired,value:p.PropTypes.string.isRequired})}),actions:p.PropTypes.object,securityID:p.PropTypes.string,confirm:p.PropTypes.func},O.defaultProps={extraClass:"",className:"",data:{},upload:{},confirm:function(e){return window.confirm(e)}},t.Component=O,t.default=(0,y.connect)(i,a)(O)},"./client/src/components/ProportionConstraintField/ProportionConstraintField.js":function(e,t,o){"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function r(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function s(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,"__esModule",{value:!0}),t.Component=void 0;var l=function(){function e(e,t){for(var o=0;o0}function a(e,t){var o=e.form.formSchemas[t.searchFormSchemaUrl];if(!o||!o.name)return{formData:{}};var n=(0,w.default)((0,I.default)(e),o.name);return{formData:n&&n.values||{}}}function d(e){return{actions:{schema:(0,y.bindActionCreators)(S,e),reduxForm:(0,y.bindActionCreators)({reset:C.reset,initialize:C.initialize},e)}}}Object.defineProperty(t,"__esModule",{value:!0}),t.hasFilters=t.Component=void 0;var u=function(){function e(e,t){for(var o=0;o1&&void 0!==arguments[1]?arguments[1]:this.props;if("function"==typeof t.onChange){var o=t.files.filter(function(e){return e.id}).map(function(e){return e.id}),n={Files:o};t.onChange(e,{id:t.id,value:n})}}},{key:"handleUploadButton",value:function(e){e.preventDefault()}},{key:"handleAddShow",value:function(e){e.preventDefault(),this.setState({selecting:!0,selectingItem:null})}},{key:"handleHide",value:function(){this.setState({selecting:!1,selectingItem:null})}},{key:"handleAddInsert",value:function(e,t,o){return this.props.actions.uploadField.addFile(this.props.id,o),this.handleHide(),Promise.resolve({})}},{key:"handleInsertMany",value:function(e,t){var o=this;if(this.state.selectingItem)return void this.handleReplace(e,null,t[0]);t.forEach(function(t){o.handleAddInsert(e,null,t)})}},{key:"handleReplace",value:function(e,t,o){var n=this.state.selectingItem,r=this.props,s=r.id,l=r.actions.uploadField,i=l.addFile,a=l.removeFile;if(!n)throw new Error("Tried to replace a file when none was selected.");return a(s,n),i(s,o),this.handleHide(),Promise.resolve({})}},{key:"canEdit",value:function(){return!this.props.disabled&&!this.props.readOnly&&(this.props.data.canUpload||this.props.data.canAttach)}},{key:"canUpload",value:function(){return this.canEdit()&&this.props.data.canUpload}},{key:"canAttach",value:function(){return this.canEdit()&&this.props.data.canAttach}},{key:"renderDropzone",value:function(){var e=this.props.AssetDropzone;if(!this.props.data.createFileEndpoint)return null;var t={height:E.default.SMALL_THUMBNAIL_HEIGHT,width:E.default.SMALL_THUMBNAIL_WIDTH},o=this.getMaxFiles(),n={url:this.props.data.createFileEndpoint.url,method:this.props.data.createFileEndpoint.method,paramName:"Upload",maxFiles:o,thumbnailWidth:E.default.SMALL_THUMBNAIL_WIDTH,thumbnailHeight:E.default.SMALL_THUMBNAIL_HEIGHT},r=["uploadfield__dropzone"];if(0===o&&r.push("uploadfield__dropzone--hidden"),!this.canEdit())return this.props.files.length?null:_.default.createElement("p",null,h.default._t("AssetAdmin.EMPTY","No files"));var s=this.props.securityId,l=[];return this.canUpload()&&l.push(_.default.createElement("button",{key:"uploadbutton",type:"button",onClick:this.handleUploadButton,className:"uploadfield__upload-button"},h.default._t("AssetAdmin.BROWSE","Browse"))),this.canAttach()&&(l.length&&l.push(_.default.createElement("span",{key:"uploadjoin",className:"uploadfield__join"},h.default._t("AssetAdmin.OR","or"))),l.push(_.default.createElement("button",{key:"attachbutton",type:"button",onClick:this.handleAddShow,className:"uploadfield__add-button"},h.default._t("AssetAdmin.ADD_FILES","Add from files")))),_.default.createElement(e,{name:this.props.name,canUpload:this.canUpload(),uploadButton:!1,uploadSelector:".uploadfield__upload-button, .uploadfield__backdrop",folderId:this.props.data.parentid,onAddedFile:this.handleAddedFile,onError:this.handleFailedUpload,onSuccess:this.handleSuccessfulUpload,onSending:this.handleSending,onUploadProgress:this.handleUploadProgress,preview:t,options:n,securityID:s,className:r.join(" ")},_.default.createElement("div",{className:"uploadfield__backdrop"}),_.default.createElement("span",{className:"uploadfield__droptext"},l))}},{key:"renderModal",value:function(){var e=this.props.InsertMediaModal,t=this.state,o=t.selecting,n=t.selectingItem,r=this.getMaxFiles(),s=this.getFolderId();return _.default.createElement(e,{title:!1,isOpen:o,onInsert:n?this.handleReplace:this.handleAddInsert,onClosed:this.handleHide,onInsertMany:this.handleInsertMany,maxFiles:n?1:r,type:"select",bodyClassName:"modal__dialog",className:"insert-media-react__dialog-wrapper",fileAttributes:n?{ID:n.id}:null,folderId:s})}},{key:"renderChild",value:function(e,t){var o=this.props.UploadFieldItem,n={key:e.id?"file-"+e.id:"queued-"+e.queuedId,item:e,name:this.props.name,onRemove:this.handleItemRemove,canEdit:this.canEdit(),onView:this.handleReplaceShow},r=this.props.getItemProps(n,t,this.props);return _.default.createElement(o,r)}},{key:"render",value:function(){return _.default.createElement("div",{className:"uploadfield"},this.renderDropzone(),this.props.files.map(this.renderChild),this.renderModal())}}]),t}(m.Component);O.propTypes={id:m.PropTypes.string.isRequired,name:m.PropTypes.string.isRequired,onChange:m.PropTypes.func,value:m.PropTypes.shape({Files:m.PropTypes.arrayOf(m.PropTypes.number)}),files:m.PropTypes.arrayOf(P.default),readOnly:m.PropTypes.bool,disabled:m.PropTypes.bool,data:m.PropTypes.shape({files:m.PropTypes.arrayOf(P.default),createFileEndpoint:m.PropTypes.shape({url:m.PropTypes.string.isRequired,method:m.PropTypes.string.isRequired,payloadFormat:m.PropTypes.string.isRequired}),multi:m.PropTypes.bool,parentid:m.PropTypes.number,canUpload:m.PropTypes.bool,canAttach:m.PropTypes.bool,maxFiles:m.PropTypes.number}),UploadFieldItem:m.PropTypes.oneOfType([m.PropTypes.node,m.PropTypes.func]),AssetDropzone:m.PropTypes.oneOfType([m.PropTypes.node,m.PropTypes.func]),InsertMediaModal:m.PropTypes.oneOfType([m.PropTypes.node,m.PropTypes.func]),getItemProps:m.PropTypes.func},O.defaultProps={value:{Files:[]},className:"",getItemProps:function(e){return e}};var F=(0,g.connect)(a,d)(O);t.Component=O,t.ConnectedUploadField=F,t.default=(0,y.compose)((0,v.inject)(["UploadFieldItem","AssetDropzone","InsertMediaModal"]),S.default)(F)},"./client/src/components/UploadField/UploadFieldItem.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,"__esModule",{value:!0});var i=function(){function e(e,t){for(var o=0;o0}},{key:"missing",value:function(){return!this.exists()&&this.saved()}},{key:"isImageSmallerThanThumbnail",value:function(){if(!this.isImage()||this.missing())return!1;var e=this.props.item.width,t=this.props.item.height;return t&&e&&t0}).length)return alert(r.default._t("AssetAdmin.BULK_ACTIONS_DELETE_FOLDER","These folders contain files which are currently in use, you must move or delete their contents before you can delete the folder.")),void o("cancelled");var n=e.filter(function(e){return"folder"!==e.type&&e.inUseCount>0}),s=r.default._t("AssetAdmin.BULK_ACTIONS_DELETE_CONFIRM","Are you sure you want to delete these files?");1===e.length&&1===n.length?s=r.default.sprintf(r.default._t("AssetAdmin.BULK_ACTIONS_DELETE_SINGLE_CONFIRM","This file is currently used in %s place(s), are you sure you want to delete it?"),e[0].inUseCount):n.length>0&&(s=r.default.sprintf(r.default._t("AssetAdmin.BULK_ACTIONS_DELETE_MULTI_CONFIRM","There are %s files currently in use, are you sure you want to delete these files?"),n.length)),n.length>0&&(s+="\n\n",s+=r.default._t("AssetAdmin.BULK_ACTIONS_DELETE_WARNING","Ensure files are removed from content areas prior to deleting them, otherwise they will appear as broken links.")),confirm(s)?t():o("cancelled")})})},{value:"edit",label:r.default._t("AssetAdmin.BULK_ACTIONS_EDIT","Edit"),className:"font-icon-edit",destructive:!1,canApply:function(e){return 1===e.length},callback:null},{value:"move",label:r.default._t("AssetAdmin.BULK_ACTIONS_MOVE","Move"),className:"font-icon-folder-move",canApply:function(e){return e.every(function(e){return e&&e.canEdit})},destructive:!1,callback:null},{value:"publish",label:r.default._t("AssetAdmin.BULK_ACTIONS_PUBLISH","Publish"),className:"font-icon-rocket",destructive:!1,callback:null,canApply:function(e){return e.some(function(e){return e&&!e.published})&&e.every(function(e){return e.canEdit&&"folder"!==e.type})},confirm:null},{value:"unpublish",label:r.default._t("AssetAdmin.BULK_ACTIONS_UNPUBLISH","Unpublish"),className:"font-icon-cancel-circled",destructive:!1,callback:null,canApply:function(e){return e.some(function(e){return e.published})&&e.every(function(e){return e.canEdit&&"folder"!==e.type})},confirm:null},{value:"insert",label:r.default._t("AssetAdmin.BULK_ACTIONS_INSERT","Insert"),className:"font-icon-plus-circled btn-primary",destructive:!1,callback:null,canApply:function(e){return e.length},confirm:null}],BULK_ACTIONS_PLACEHOLDER:r.default._t("AssetAdmin.BULK_ACTIONS_PLACEHOLDER"),SPACE_KEY_CODE:32,RETURN_KEY_CODE:13,DEFAULT_PREVIEW:"framework/client/dist/images/app_icons/generic_92.png",MODAL_MOVE:"MODAL_MOVE"}},"./client/src/containers/AssetAdmin/AssetAdmin.js":function(e,t,o){"use strict";function n(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var o in e)Object.prototype.hasOwnProperty.call(e,o)&&(t[o]=e[o]);return t.default=e,t}function r(e){return e&&e.__esModule?e:{default:e}}function s(e){if(Array.isArray(e)){for(var t=0,o=Array(e.length);t1&&void 0!==arguments[1])||arguments[1];return b.default.createEndpointFetcher(Object.assign({},e,t?{defaultData:{SecurityID:this.props.securityId}}:{}))}},{key:"handleBackButtonClick",value:function(e){e.preventDefault(),this.props.actions.gallery.deselectFiles(),this.props.folder?this.handleOpenFolder(this.props.folder.parentId||0):this.handleOpenFolder(0)}},{key:"resetFile",value:function(e){e.queuedId&&this.props.actions.queuedFiles.removeQueuedFile(e.queuedId),this.props.fileId===e.id&&(this.handleCloseFile(),this.handleOpenFile(e.id))}},{key:"handleFolderIcon",value:function(e){e.preventDefault(),this.handleOpenFile(this.getFolderId())}},{key:"handleOpenFile",value:function(e){this.handleBrowse(this.getFolderId(),e,this.props.query)}},{key:"handleSubmitEditor",value:function(e,t,o){var n=this,r=null;if("action_insert"===t&&"select"===this.props.type){var s=this.getFiles(),l=s.find(function(t){return t.id===parseInt(e.ID,10)});return this.props.onInsertMany(null,[l]),Promise.resolve()}if("function"==typeof this.props.onSubmitEditor){var i=this.findFile(this.props.fileId);r=this.props.onSubmitEditor(e,t,o,i)}else r=o();if(!r)throw new Error("Promise was not returned for submitting");return r.then(function(e){return"action_createfolder"===t&&"admin"===n.props.type&&n.handleOpenFile(e.record.id),n.props.actions.files.readFiles().then(function(){return"action_createfolder"===t&&"admin"!==n.props.type&&n.handleOpenFolder(n.getFolderId()),e})})}},{key:"handleCloseFile",value:function(){this.handleBrowse(this.getFolderId(),null,this.props.query)}},{key:"handleOpenFolder",value:function(e){var t=Object.assign({},this.props.query);delete t.page,delete t.filter,this.handleBrowse(e,null,t)}},{key:"handleDelete",value:function(e){var t=this,o=e.map(function(e){var o=t.findFile(e);if(!o)throw new Error("File selected for deletion cannot be found: "+e);return o.queuedId&&t.props.actions.queuedFiles.removeQueuedFile(o.queuedId),o}),n=o.map(function(e){return e.id}),r=this.props.folder?this.props.folder.id:0;return this.props.actions.files.deleteFiles(n).then(function(e){var o=e.data.deleteFiles;return t.handleBrowse(r,null,t.props.query),o})}},{key:"doUnpublish",value:function(e){var t=this,o=arguments.length>1&&void 0!==arguments[1]&&arguments[1],n=e.map(function(e){var o=t.findFile(e);if(!o)throw new Error("File selected for unpublishing cannot be found: "+e);if("folder"===o.type)throw new Error("Cannot unpublish folders");return o}),r=n.map(function(e){return e.id});return this.props.actions.files.unpublishFiles(r,o).then(function(e){var o=e.data.unpublishFiles,n=o.filter(function(e){return"File"===e.__typename}),r=o.filter(function(e){return"PublicationNotice"===e.__typename&&"HAS_OWNERS"===e.Type}),s=n.map(function(e){return t.resetFile(e),e}),l=r.slice(0,4),i=r.slice(5),a=l.map(function(e){return e.Message});if(i.length&&a.push(j.default.inject(j.default._t("AssetAdmin.BULK_OWNED_WARNING_REMAINING","And {count} other file(s)"),{count:i.length})),l.length){var d=[j.default.inject(j.default._t("AssetAdmin.BULK_OWNED_WARNING_HEADING","{count} file(s) are being used by other published content."),{count:r.length}),a.join("\n"),j.default._t("AssetAdmin.BULK_OWNED_WARNING_FOOTER","Unpublishing will only remove files from the published version of the content. They will remain on the draft version. Unpublish anyway?")];if(confirm(d.join("\n\n"))){var u=r.reduce(function(e,t){return e.concat(t.IDs)},[]);return t.doUnpublish(u,!0).then(function(e){return s.concat(e)})}}return s})}},{key:"handleUnpublish",value:function(e){var t=this;return this.doUnpublish(e).then(function(e){var o=t.props.fileId;t.props.actions.files.readFiles().then(function(){o&&e.find(function(e){return e.id===o})&&(t.handleCloseFile(),t.handleOpenFile(o))})})}},{key:"doPublish",value:function(e){var t=this,o=e.map(function(e){var o=t.findFile(e);if(!o)throw new Error("File selected for publishing cannot be found: "+e);if("folder"===o.type)throw new Error("Cannot publish folders");return o}),n=o.map(function(e){return e.id});return this.props.actions.files.publishFiles(n).then(function(e){return e.data.publishFiles.filter(function(e){return"File"===e.__typename}).map(function(e){return t.resetFile(e),e})})}},{key:"findFile",value:function(e){return this.getFiles().find(function(t){return t.id===parseInt(e,10)})}},{key:"handleUpload",value:function(){}},{key:"handleCreateFolder",value:function(){this.props.onBrowse(this.getFolderId(),null,this.props.query,X.default.ACTIONS.CREATE_FOLDER)}},{key:"handleMoveFilesSuccess",value:function(e,t){var o=this;this.props.queuedFiles.items.filter(function(e){return t.includes(e.id)}).forEach(function(e){e.queuedId&&o.props.actions.queuedFiles.removeQueuedFile(e.queuedId)}),this.props.actions.gallery.deselectFiles(),this.props.actions.files.readFiles()}},{key:"renderGallery",value:function(){var e=this.props.sectionConfig,t=e.createFileEndpoint.url,o=e.createFileEndpoint.method,n=this.props.query&&parseInt(this.props.query.limit||e.limit,10),r=this.props.query&&parseInt(this.props.query.page||1,10),s=this.props.query&&this.props.query.sort,l=this.props.query&&this.props.query.view,i=this.props.query.filter||{};return _.default.createElement(k.default,{files:this.getFiles(),fileId:this.props.fileId,folderId:this.getFolderId(),folder:this.props.folder,type:this.props.type,limit:n,page:r,totalCount:this.props.filesTotalCount,view:l,filters:i,graphQLErrors:this.props.graphQLErrors,createFileApiUrl:t,createFileApiMethod:o,onDelete:this.handleDelete,onInsertMany:this.props.onInsertMany,onPublish:this.doPublish,onUnpublish:this.doUnpublish,onOpenFile:this.handleOpenFile,onOpenFolder:this.handleOpenFolder,onSuccessfulUpload:this.handleUpload,onCreateFolder:this.handleCreateFolder,onMoveFilesSuccess:this.handleMoveFilesSuccess,onClearSearch:this.handleClearSearch,onSort:this.handleSort,onSetPage:this.handleSetPage,onViewChange:this.handleViewChange,sort:s,sectionConfig:e,loading:this.props.loading,maxFilesSelect:this.props.maxFiles})}},{key:"renderEditor",value:function(){var e=this.props.sectionConfig,t=d({config:e,viewAction:this.props.viewAction,folderId:this.getFolderId(),type:this.props.type,fileId:this.props.fileId}),o=t.schemaUrl,n=t.targetId;return o?_.default.createElement(A.default,{className:this.props.dialog?"editor--dialog":"",targetId:n,file:this.findFile(n),onClose:this.handleCloseFile,schemaUrl:o,schemaUrlQueries:this.props.requireLinkText?[{name:"requireLinkText",value:!0}]:[],onSubmit:this.handleSubmitEditor,onDelete:this.handleDelete,onUnpublish:this.handleUnpublish,addToCampaignSchemaUrl:e.form.addToCampaignForm.schemaUrl}):null}},{key:"render",value:function(){var e=Boolean(this.props.folderId||(0,G.hasFilters)(this.props.query.filter)),t=this.props.sectionConfig.form.fileSearchForm.schemaUrl,o=this.props.query.filter||{},n=(0,C.default)("fill-height asset-admin","select"===this.props.type&&{"asset-admin--single-select":1===this.props.maxFiles,"asset-admin--multi-select":1!==this.props.maxFiles});return _.default.createElement("div",{className:n},_.default.createElement(L.default,{showBackButton:e,onBackButtonClick:this.handleBackButtonClick},_.default.createElement(R.default,{multiline:!0}),_.default.createElement("div",{className:"asset-admin__toolbar-extra pull-xs-right fill-width vertical-align-items"},_.default.createElement(B.default,{onSearch:this.handleDoSearch,id:"AssetSearchForm",searchFormSchemaUrl:t,folderId:this.getFolderId(),filters:o}),this.props.toolbarChildren)),_.default.createElement("div",{className:"flexbox-area-grow fill-width fill-height gallery"},this.renderGallery(),this.renderEditor()))}}]),t}(m.Component);ee.propTypes={dialog:m.PropTypes.bool,sectionConfig:J.default,fileId:m.PropTypes.number,folderId:m.PropTypes.number,onBrowse:m.PropTypes.func,onReplaceUrl:m.PropTypes.func,onInsertMany:m.PropTypes.func,graphQLErrors:m.PropTypes.arrayOf(m.PropTypes.string),getUrl:m.PropTypes.func,query:m.PropTypes.shape({sort:m.PropTypes.string,limit:m.PropTypes.oneOfType([m.PropTypes.number,m.PropTypes.string]),page:m.PropTypes.oneOfType([m.PropTypes.number,m.PropTypes.string]),filter:m.PropTypes.object}),onSubmitEditor:m.PropTypes.func,type:m.PropTypes.oneOf(["insert-media","insert-link","select","admin"]),files:m.PropTypes.array,queuedFiles:m.PropTypes.shape({items:m.PropTypes.array.isRequired}),filesTotalCount:m.PropTypes.number,folder:m.PropTypes.shape({id:m.PropTypes.number,title:m.PropTypes.string,parents:m.PropTypes.array,parentId:m.PropTypes.number,canView:m.PropTypes.bool,canEdit:m.PropTypes.bool}),loading:m.PropTypes.bool,actions:m.PropTypes.object,maxFiles:m.PropTypes.number},ee.defaultProps={type:"admin",query:{sort:"",limit:null,page:0,filter:{}},maxFiles:null},t.Component=ee,t.getFormSchema=d,t.default=(0,y.compose)((0,g.connect)(c,p),q.default,V.default,K.default,$.default,function(e){return(0,U.withApollo)(e)})(ee)},"./client/src/containers/AssetAdmin/AssetAdminRouter.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function i(e){var t=e.base,o=e.folderId,n=e.fileId,r=e.query,s=e.action;if(s&&-1===C.indexOf(s))throw new Error("Invalid action provided: "+s);var l=null;return l=n?t+"/show/"+o+"/"+b.default.ACTIONS.EDIT_FILE+"/"+n:o?t+"/show/"+o:t+"/",s===b.default.ACTIONS.CREATE_FOLDER&&(l=t+"/show/"+(o||0)+"/"+s),r&&Object.keys(r).length>0&&(l=l+"?"+y.default.stringify(r)),l}function a(e){return{sectionConfig:e.config.sections.find(function(e){return e.name===S})}}Object.defineProperty(t,"__esModule",{value:!0}),t.buildUrl=t.Component=void 0;var d=function(){function e(e,t){for(var o=0;o0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:b.default.ACTIONS.EDIT_FILE,r=parseInt(e||0,10),s=parseInt(t||0,10),l=r!==this.getFolderId(),a=Object.assign({},o);return(l||a.page<=1)&&delete a.page,i({base:this.props.sectionConfig.url,folderId:r,fileId:s,query:a,action:n})}},{key:"getFolderId",value:function(){return this.props.params&&this.props.params.folderId?parseInt(this.props.params.folderId,10):0}},{key:"getFileId",value:function(){return this.props.params&&this.props.params.fileId?parseInt(this.props.params.fileId,10):0}},{key:"getViewAction",value:function(){return this.props.params&&this.props.params.viewAction?this.props.params.viewAction:b.default.ACTIONS.EDIT_FILE}},{key:"getSectionProps",value:function(){return{sectionConfig:this.props.sectionConfig,type:"admin",folderId:this.getFolderId(),viewAction:this.getViewAction(),fileId:this.getFileId(),query:this.getQuery(),getUrl:this.getUrl,onBrowse:this.handleBrowse,onReplaceUrl:this.handleReplaceUrl}}},{key:"getQuery",value:function(){return(0,_.decodeQuery)(this.props.location.search)}},{key:"handleBrowse",value:function(e,t,o,n){var r=this.getUrl(e,t,o,n);this.props.router.push(r)}},{key:"handleReplaceUrl",value:function(e,t,o,n){var r=this.getUrl(e,t,o,n);this.props.router.replace(r)}},{key:"render",value:function(){return this.props.sectionConfig?c.default.createElement(m.default,this.getSectionProps()):null}}]),t}(u.Component);P.propTypes={sectionConfig:j.default,location:u.PropTypes.shape({pathname:u.PropTypes.string,query:u.PropTypes.object,search:u.PropTypes.string}),params:u.PropTypes.object,router:u.PropTypes.object},t.Component=P,t.buildUrl=i,t.default=(0,f.withRouter)((0,p.connect)(a)(P))},"./client/src/containers/AssetAdmin/stateRouter.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function i(e){function t(t){var o=t.config.sections.find(function(e){return e.name===m});return{Component:e,sectionConfig:o}}return(0,c.connect)(t)(g)}Object.defineProperty(t,"__esModule",{value:!0}),t.AssetAdminStateRouter=void 0;var a=function(){function e(e,t){for(var o=0;o0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:h.default.ACTIONS.EDIT_FILE,r=parseInt(e||0,10),s=parseInt(t||0,10),l=this.getFolderId(),i=r!==l&&null!==l,a=Object.assign({},o);return(i||a.page<=1)&&delete a.page,(0,p.buildUrl)({base:this.props.sectionConfig.url,folderId:r,fileId:s,query:a,action:n})}},{key:"getFolderId",value:function(){return null===this.state.folderId?null:parseInt(this.state.folderId||0,10)}},{key:"getFileId",value:function(){return parseInt(this.state.fileId||this.props.fileId||0,10)}},{key:"getViewAction",value:function(){return this.state.action||h.default.ACTIONS.EDIT_FILE}},{key:"getSectionProps",value:function(){var e=Object.assign({},this.props,{folderId:this.getFolderId(),fileId:this.getFileId(),viewAction:this.getViewAction(),query:this.state.query,getUrl:this.getUrl,onBrowse:this.handleBrowse});return delete e.Component,e}},{key:"handleBrowse",value:function(e,t){var o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:h.default.ACTIONS.EDIT_FILE;if(n&&-1===Object.values(h.default.ACTIONS).indexOf(n))throw new Error("Invalid action provided: "+n);this.setState({folderId:e,fileId:t,query:o,action:n})}},{key:"render",value:function(){var e=this.getSectionProps(),t=this.props.Component;return u.default.createElement(t,e)}}]),t}(d.Component);g.propTypes={Component:d.PropTypes.oneOfType([d.PropTypes.element,d.PropTypes.func]),sectionConfig:d.PropTypes.shape({url:d.PropTypes.string.isRequired}).isRequired,fileId:d.PropTypes.number},t.AssetAdminStateRouter=g,t.default=i},"./client/src/containers/Editor/Editor.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function i(e){return{actions:{unsavedForms:(0,p.bindActionCreators)(j,e)}}}Object.defineProperty(t,"__esModule",{value:!0}),t.Component=void 0;var a=function(){function e(e,t){for(var o=0;o0&&(n=u.default.sprintf(u.default._t("AssetAdmin.BULK_ACTIONS_DELETE_SINGLE_CONFIRM","This file is currently used in %s place(s), are you sure you want to delete it?"),this.props.file.inUseCount),n+="\n\n",n+=u.default._t("AssetAdmin.BULK_ACTIONS_DELETE_WARNING","Ensure files are removed from content areas prior to deleting them, otherwise they will appear as broken links.")),confirm(n)&&(this.props.actions.unsavedForms.removeFormChanged("AssetAdmin.EditForm"),this.props.onDelete([t.ID])),e.preventDefault()}}},{key:"handleCancelKeyDown",value:function(e){e.keyCode!==_.default.SPACE_KEY_CODE&&e.keyCode!==_.default.RETURN_KEY_CODE||this.handleClose(e)}},{key:"handleSubmit",value:function(e,t,o){return"function"==typeof this.props.onSubmit?this.props.onSubmit(e,t,o):o()}},{key:"handleClose",value:function(e){this.props.onClose(),this.closeModal(),e&&e.preventDefault()}},{key:"openModal",value:function(){this.setState({openModal:!0})}},{key:"closeModal",value:function(){this.setState({openModal:!1})}},{key:"handleLoadingError",value:function(e){this.setState({loadingForm:!1,loadingError:e.errors[0]})}},{key:"handleLoadingSuccess",value:function(){this.setState({loadingForm:!1,loadingError:null})}},{key:"handleFetchingSchema",value:function(){this.setState({loadingForm:!0})}},{key:"renderCancelButton",value:function(){return h.default.createElement("a",{role:"button",tabIndex:0,className:"btn btn--close-panel btn--no-text font-icon-cancel btn--icon-xl",onClick:this.handleClose,onKeyDown:this.handleCancelKeyDown,type:"button","aria-label":u.default._t("AssetAdmin.CANCEL")})}},{key:"render",value:function(){var e=this.props.schemaUrlQueries.map(function(e){return e.name+"="+e.value}).join("&").trim();e=e?"?"+e:"";var t=this.props.schemaUrl+"/"+this.props.targetId+e,o=this.props.addToCampaignSchemaUrl+"/"+this.props.targetId,n=["panel","form--no-dividers","editor"];this.props.className&&n.push(this.props.className);var r=null;if(this.state.loadingError){var s=this.state.loadingError.value;404===this.state.loadingError.code&&(s=u.default._t("AssetAdmin.FILE_MISSING","File cannot be found")),s||(s=u.default._t("Admin.UNKNOWN_ERROR","An unknown error has occurred")),r=h.default.createElement("div",{className:"editor__file-preview-message--file-missing"},s)}var l=u.default._t("Admin.ADD_TO_CAMPAIGN","Add to campaign");return h.default.createElement("div",{className:n.join(" ")},h.default.createElement("div",{className:"editor__details fill-height"},h.default.createElement(y.default,{identifier:"AssetAdmin.EditForm",schemaUrl:t,afterMessages:this.renderCancelButton(),onSubmit:this.handleSubmit,onAction:this.handleAction,onLoadingSuccess:this.handleLoadingSuccess,onLoadingError:this.handleLoadingError,onFetchingSchema:this.handleFetchingSchema}),r,h.default.createElement(b.default,{title:l,identifier:"AssetAdmin.AddToCampaign",isOpen:this.state.openModal,onClosed:this.closeModal,schemaUrl:o,bodyClassName:"modal__dialog",responseClassBad:"modal__response modal__response--error",responseClassGood:"modal__response modal__response--good"}),this.state.loadingForm&&[h.default.createElement("div",{key:"overlay",className:"cms-content-loading-overlay ui-widget-overlay-light"}),h.default.createElement("div",{key:"spinner",className:"cms-content-loading-spinner"})]))}}]),t}(f.Component);P.propTypes={file:C.default,className:f.PropTypes.string,targetId:f.PropTypes.number.isRequired,onClose:f.PropTypes.func.isRequired,onSubmit:f.PropTypes.func.isRequired,onDelete:f.PropTypes.func.isRequired,schemaUrl:f.PropTypes.string.isRequired,schemaUrlQueries:f.PropTypes.arrayOf(f.PropTypes.shape({name:f.PropTypes.string,value:f.PropTypes.any})),addToCampaignSchemaUrl:f.PropTypes.string,actions:f.PropTypes.object},t.Component=P,t.default=(0,c.connect)(function(){return{}},i)(P)},"./client/src/containers/Gallery/Gallery.js":function(e,t,o){"use strict";function n(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var o in e)Object.prototype.hasOwnProperty.call(e,o)&&(t[o]=e[o]);return t.default=e,t}function r(e){return e&&e.__esModule?e:{default:e}}function s(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function l(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function i(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function a(e,t){var o=t.sort,n=e.assetAdmin.gallery,r=n.selectedFiles,s=n.errorMessage,l=n.noticeMessage,i=n.enableDropzone,a=n.badges,d=n.concatenateSelect,u=n.loading,c=n.sorters,p=n.lastSelected;return!o&&c&&c[0]&&(o=c[0].field+","+c[0].direction),{lastSelected:p,selectedFiles:r,errorMessage:s,noticeMessage:l,enableDropzone:i,badges:a,concatenateSelect:d,loading:t.loading||u,queuedFiles:e.assetAdmin.queuedFiles,securityId:e.config.SecurityID,sorters:c,sort:o}}function d(e){return{actions:{gallery:(0,w.bindActionCreators)(G,e),queuedFiles:(0,w.bindActionCreators)(H,e)}}}Object.defineProperty(t,"__esModule",{value:!0}),t.galleryViewDefaultProps=t.galleryViewPropTypes=t.Component=void 0;var u=Object.assign||function(e){for(var t=1;t=s&&t<=l}).map(function(e){return e.id})}},{key:"getSelectableFiles",value:function(){var e=this.props.files.filter(function(e){return e.id});return"select"===this.props.type?e.filter(function(e){return"folder"!==e.type}):e}},{key:"handleBulkInsert",value:function(e,t){this.props.onInsertMany(e,t)}},{key:"handleBulkDelete",value:function(e,t){var o=this;return this.props.onDelete(t.map(function(e){return e.id})).then(function(e){var n=e.filter(function(e){return e}).length;n!==t.length?(o.props.actions.gallery.setErrorMessage(_.default.sprintf(_.default._t("AssetAdmin.BULK_ACTIONS_DELETE_FAIL","%s folders/files were successfully deleted, but %s files were not able to be deleted."),n,t.length-n)),o.props.actions.gallery.setNoticeMessage(null)):(o.props.actions.gallery.setNoticeMessage(_.default.sprintf(_.default._t("AssetAdmin.BULK_ACTIONS_DELETE_SUCCESS","%s folders/files were successfully deleted."),n)),o.props.actions.gallery.setErrorMessage(null),o.props.actions.gallery.deselectFiles())})}},{key:"handleBulkPublish",value:function(e,t){var o=this,n=t.map(function(e){return e.id});return n.length?(this.props.actions.gallery.setLoading(!0),this.props.onPublish(n).then(function(e){o.props.actions.gallery.setLoading(!1),o.props.actions.gallery.setNoticeMessage(_.default.sprintf(_.default._t("AssetAdmin.BULK_ACTIONS_PUBLISH_SUCCESS","%s folders/files were successfully published."),e.length)),o.props.actions.gallery.setErrorMessage(null),o.props.actions.gallery.deselectFiles()})):(this.props.actions.gallery.deselectFiles(),Promise.resolve(!0))}},{key:"handleBulkUnpublish",value:function(e,t){var o=this,n=t.filter(function(e){return e.published}).map(function(e){return e.id});return n.length?(this.props.actions.gallery.setLoading(!0),this.props.onUnpublish(n).then(function(e){o.props.actions.gallery.setLoading(!1),o.props.actions.gallery.setNoticeMessage(_.default.sprintf(_.default._t("AssetAdmin.BULK_ACTIONS_UNPUBLISH_SUCCESS","%s folders/files were successfully unpublished."),e.length)),o.props.actions.gallery.setErrorMessage(null),o.props.actions.gallery.deselectFiles()})):(this.props.actions.gallery.deselectFiles(),Promise.resolve(!0))}},{key:"initSortDropdown",value:function(){if("tile"===this.props.view){var e=this.getSortElement();e.chosen({allow_single_deselect:!0,disable_search_threshold:20}),e.off("change"),e.on("change",function(){return j.default.Simulate.click(e.find(":selected")[0])})}}},{key:"handleSort",value:function(e){this.props.actions.queuedFiles.purgeUploadQueue(),this.props.onSort(e)}},{key:"handleSetPage",value:function(e){this.props.onSetPage(e)}},{key:"handleCancelUpload",value:function(e){e.xhr.abort(),this.props.actions.queuedFiles.removeQueuedFile(e.queuedId)}},{key:"handleRemoveErroredUpload",value:function(e){this.props.actions.queuedFiles.removeQueuedFile(e.queuedId)}},{key:"handleAddedFile",value:function(e){this.props.actions.queuedFiles.addQueuedFile(e)}},{key:"handlePreviewLoaded",value:function(e,t){this.props.actions.queuedFiles.updateQueuedFile(e.queuedId,t)}},{key:"handleSending",value:function(e,t){this.props.actions.queuedFiles.updateQueuedFile(e._queuedId,{xhr:t})}},{key:"handleUploadProgress",value:function(e,t){this.props.actions.queuedFiles.updateQueuedFile(e._queuedId,{progress:t})}},{key:"handleSuccessfulUpload",value:function(e){var t=JSON.parse(e.xhr.response);if(void 0!==t[0].error)return void this.handleFailedUpload(e);if(this.props.actions.queuedFiles.succeedUpload(e._queuedId,t[0]),this.props.onSuccessfulUpload&&this.props.onSuccessfulUpload(t),"admin"!==this.props.type&&!this.props.fileId&&0===this.props.queuedFiles.items.length){var o=t.pop();this.props.onOpenFile(o.id)}}},{key:"handleFailedUpload",value:function(e,t){this.props.actions.queuedFiles.failUpload(e._queuedId,t)}},{key:"itemIsSelected",value:function(e){return this.props.selectedFiles.indexOf(e)>-1}},{key:"toggleSelectConcat",value:function(e){this.props.actions.gallery.setConcatenateSelect(this.isConcat(e))}},{key:"isConcat",value:function(e){return e.metaKey||e.ctrlKey||e.shiftKey}},{key:"itemIsHighlighted",value:function(e){return this.props.fileId===e}},{key:"hasOpenedItem",value:function(){return!!this.props.fileId}},{key:"handleClearSearch",value:function(e){this.props.onClearSearch(e)}},{key:"handleGroupSelect",value:function(e,t){var o=this,n=this.props.actions.gallery,r=n.setSelectedFiles,s=n.selectFiles,l=this.getSelectableFiles(),i=e.filter(function(t,o){return e.indexOf(t)===o&&l.find(function(e){return e.id===t})}),a=this.props.concatenateSelect||this.isConcat(t);if(null!==this.props.maxFilesSelect){var d=i.length;if(a&&(d=this.props.selectedFiles.filter(function(e){return!o.props.selectedFiles.includes(e)}).concat(this.props.selectedFiles).length),d>=this.props.maxFilesSelect)return}a?r(i):s(i)}},{key:"handleClearSelection",value:function(){this.props.actions.gallery.deselectFiles()}},{key:"handleOpenFolder",value:function(e,t){e.preventDefault(),this.props.actions.gallery.setErrorMessage(null),this.props.actions.gallery.setNoticeMessage(null),this.props.onOpenFolder(t.id)}},{key:"handleOpenFile",value:function(e,t){e.preventDefault(),null!==t.created&&(this.props.selectedFiles.length&&1!==this.props.maxFilesSelect||"select"!==this.props.type||this.handleSelect(e,t),this.props.onOpenFile(t.id,t))}},{key:"handleSelect",value:function(e,t){var o=this.props.maxFilesSelect,n=this.getSelectableFiles(),r=n.filter(function(e){return e.id===t.id}).map(function(e){return e.id});if(1===o)return void this.props.actions.gallery.setSelectedFiles(r);if(-1===this.props.selectedFiles.indexOf(t.id)){if(e.shiftKey&&(r=this.getSelection(this.props.lastSelected,t.id)),this.props.selectedFiles.filter(function(e){return!r.includes(e)}).concat(r).length>o&&null!==o)return;this.props.actions.gallery.selectFiles(r),this.props.actions.gallery.setLastSelected(t.id)}else this.props.actions.gallery.deselectFiles([t.id]),e.shiftKey&&this.props.actions.gallery.setLastSelected(null)}},{key:"handleEnableDropzone",value:function(e){this.props.actions.gallery.setEnableDropzone(e)}},{key:"handleMoveFiles",value:function(e,t){var o=this;this.props.actions.files.moveFiles(e,t).then(function(){var n=R.default.MOVE_SUCCESS_DURATION,r="+"+t.length;o.props.actions.gallery.setFileBadge(e,r,"success",n),"function"==typeof o.props.onMoveFilesSuccess&&o.props.onMoveFilesSuccess(e,t)}).catch(function(){o.props.actions.gallery.setErrorMessage(_.default._t("AssetAdmin.FAILED_MOVE","There was an error moving the selected items."))})}},{key:"handleBulkEdit",value:function(e,t){this.handleOpenFile(e,t[0])}},{key:"handleBulkMove",value:function(){this.props.actions.gallery.activateModal(R.default.MODAL_MOVE)}},{key:"renderSearchAlert",value:function(){var e=this.props.filters;if(!e||0===Object.keys(e).length)return null;var t=this.getSearchMessage(e);if(""===t)return null;var o=y.default.createElement("div",null,y.default.createElement("button",{onClick:this.handleClearSearch,className:"btn btn-info font-icon-cancel form-alert__btn--right"},_.default._t("AssetAdmin.SEARCHCLEARRESULTS","Clear results")),t);return y.default.createElement(L.default,{value:{react:o},type:"warning"})}},{key:"renderTransitionBulkActions",value:function(){return y.default.createElement(C.default,{transitionName:"bulk-actions",transitionEnterTimeout:R.default.CSS_TRANSITION_TIME,transitionLeaveTimeout:R.default.CSS_TRANSITION_TIME},this.renderBulkActions())}},{key:"renderBulkActions",value:function(){var e=this,t="select"===this.props.type?function(e){return"insert"===e.value}:function(e){return"insert"!==e.value},o=R.default.BULK_ACTIONS.filter(t).map(function(t){if(t.callback)return t;switch(t.value){case"delete":return u({},t,{callback:e.handleBulkDelete});case"edit":return u({},t,{callback:e.handleBulkEdit});case"move":return u({},t,{callback:e.handleBulkMove});case"publish":return u({},t,{callback:e.handleBulkPublish});case"unpublish":return u({},t,{callback:e.handleBulkUnpublish});case"insert":return u({},t,{callback:e.handleBulkInsert});default:return t}}),n=this.props.selectedFiles.map(function(t){return e.props.files.find(function(e){return e&&t===e.id})}).filter(function(e){return e});return n.length>0&&["admin","select"].includes(this.props.type)?y.default.createElement(I.default,{actions:o,items:n,total:this.props.maxFilesSelect,key:n.length>0,container:this.gallery,showCount:1!==this.props.maxFilesSelect}):null}},{key:"renderGalleryView",value:function(){var e=this,t="table"===this.props.view?k.default:A.default,o=this.props.files.map(function(t){return u({},t,{selected:e.itemIsSelected(t.id),highlighted:e.itemIsHighlighted(t.id)})}),n=this.props,r=n.type,s=n.loading,l=n.page,i=n.totalCount,a=n.limit,d=n.sort,c=n.selectedFiles,p=n.badges,f={selectableItems:["admin","select"].includes(r),selectableFolders:"select"!==this.props.type,files:o,loading:s,page:l,totalCount:i,limit:a,sort:d,selectedFiles:c,badges:p,onSort:this.handleSort,onSetPage:this.handleSetPage,onOpenFile:this.handleOpenFile,onOpenFolder:this.handleOpenFolder,onSelect:this.handleSelect,onCancelUpload:this.handleCancelUpload,onDropFiles:this.handleMoveFiles,onRemoveErroredUpload:this.handleRemoveErroredUpload,onEnableDropzone:this.handleEnableDropzone,sectionConfig:this.props.sectionConfig,canDrag:"admin"===this.props.type,maxFilesSelect:this.props.maxFilesSelect};return y.default.createElement(t,f)}},{key:"renderToolbar",value:function(){var e=this.props,t=e.GalleryToolbar,o=e.sort,n=e.view,r=e.folder,s=e.onCreateFolder,l=e.onOpenFolder,i=e.onViewChange,a={onMoveFiles:this.handleMoveFiles,onSort:this.handleSort,onCreateFolder:s,onOpenFolder:l,onViewChange:i,view:n,sort:o,folder:r};return y.default.createElement(t,a)}},{key:"render",value:function(){var e=this,t=this.props,o=t.folder,n=t.loading,r=t.errorMessage,s=t.graphQLErrors,l=t.noticeMessage,i=s&&s.length>0;if(!o)return r||i?y.default.createElement("div",{className:"gallery__error flexbox-area-grow"},y.default.createElement("div",{className:"gallery__error-message"},y.default.createElement("h3",null,_.default._t("AssetAdmin.DROPZONE_RESPONSE_ERROR","Server responded with an error.")),r&&y.default.createElement("p",null,r),i&&s.map(function(e,t){return y.default.createElement("p",{key:t},e)}))):n?y.default.createElement("div",{className:"flexbox-area-grow"},y.default.createElement("div",{key:"overlay",className:"cms-content-loading-overlay ui-widget-overlay-light"}),y.default.createElement("div",{key:"spinner",className:"cms-content-loading-spinner"})):y.default.createElement("div",{className:"flexbox-area-grow"},y.default.createElement("div",{className:"editor__file-preview-message--file-missing m-t-3"},_.default._t("Admin.UNKNOWN_ERROR","An unknown error has occurred")));var a=y.default.createElement("div",{className:"gallery_messages"},r&&y.default.createElement(L.default,{value:r,type:"danger"}),l&&y.default.createElement(L.default,{value:l,type:"success"}),this.renderSearchAlert()),d={height:R.default.THUMBNAIL_HEIGHT,width:R.default.THUMBNAIL_WIDTH},c=u({url:this.props.createFileApiUrl,method:this.props.createFileApiMethod,paramName:"Upload",clickable:"#upload-button"},this.props.sectionConfig.dropzoneOptions),p=this.props.securityId,f=this.props.folder.canEdit&&this.props.enableDropzone,h=["panel","panel--padded","panel--scrollable","gallery__main","fill-height"];"insert"===this.props.type&&h.push("insert-media-modal__main");var m=h;return this.hasOpenedItem()&&m.push("gallery__main--has-opened-item"),y.default.createElement("div",{className:"flexbox-area-grow gallery__outer",ref:function(t){e.gallery=t}},this.renderTransitionBulkActions(),y.default.createElement(Q.default,{className:h.join(" ")},this.renderToolbar(),y.default.createElement(W.SelectableGroup,{enabled:"tile"===this.props.view&&"admin"===this.props.type,className:"flexbox-area-grow fill-height gallery__main--selectable",onSelection:this.handleGroupSelect,onNonItemClick:this.handleClearSelection,preventDefault:!1,fixedPosition:!0},y.default.createElement(O.default,{name:"gallery-container",className:"flexbox-area-grow",canUpload:f,onAddedFile:this.handleAddedFile,onPreviewLoaded:this.handlePreviewLoaded,onError:this.handleFailedUpload,onSuccess:this.handleSuccessfulUpload,onSending:this.handleSending,onUploadProgress:this.handleUploadProgress,preview:d,folderId:this.props.folderId,options:c,securityID:p,uploadButton:!1},a,this.renderGalleryView()))),this.props.loading&&[y.default.createElement("div",{key:"overlay",className:"cms-content-loading-overlay ui-widget-overlay-light"}),y.default.createElement("div",{key:"spinner",className:"cms-content-loading-spinner"})],y.default.createElement(Z.default,{sectionConfig:this.props.sectionConfig,folderId:this.props.folderId,onSuccess:this.props.onMoveFilesSuccess,onOpenFolder:this.props.onOpenFolder}))}}]),t}(g.Component),te={page:1,limit:15},oe={sectionConfig:Y.default,loading:g.PropTypes.bool,sort:g.PropTypes.string,files:g.PropTypes.arrayOf(g.PropTypes.shape({id:g.PropTypes.number,parent:g.PropTypes.shape({id:g.PropTypes.number})})).isRequired,selectedFiles:g.PropTypes.arrayOf(g.PropTypes.number),totalCount:g.PropTypes.number,page:g.PropTypes.number,limit:g.PropTypes.number,badges:g.PropTypes.arrayOf(g.PropTypes.shape({id:g.PropTypes.number,message:g.PropTypes.node,status:g.PropTypes.string})),onOpenFile:g.PropTypes.func.isRequired,onOpenFolder:g.PropTypes.func.isRequired,onSort:g.PropTypes.func.isRequired,onSetPage:g.PropTypes.func.isRequired,maxFilesSelect:g.PropTypes.number},ne=Object.assign({},te,{selectableItems:!1}),re=Object.assign({},oe,{selectableItems:g.PropTypes.bool,selectableFolders:g.PropTypes.bool,onSelect:g.PropTypes.func,onCancelUpload:g.PropTypes.func,onDelete:y.default.PropTypes.func,onRemoveErroredUpload:g.PropTypes.func,onEnableDropzone:g.PropTypes.func});ee.defaultProps=Object.assign({},te,{type:"admin",view:"tile",enableDropzone:!0}),ee.propTypes=Object.assign({},oe,{onUploadSuccess:y.default.PropTypes.func,onCreateFolder:y.default.PropTypes.func,onMoveFilesSuccess:y.default.PropTypes.func,onDelete:y.default.PropTypes.func,onPublish:y.default.PropTypes.func,onUnpublish:y.default.PropTypes.func,type:g.PropTypes.oneOf(["insert-media","insert-link","select","admin"]),view:g.PropTypes.oneOf(["tile","table"]),lastSelected:g.PropTypes.number,dialog:g.PropTypes.bool,fileId:g.PropTypes.number,folderId:g.PropTypes.number.isRequired,folder:g.PropTypes.shape({id:g.PropTypes.number,title:g.PropTypes.string,parentId:g.PropTypes.number,canView:g.PropTypes.bool,canEdit:g.PropTypes.bool}),files:g.PropTypes.array,errorMessage:g.PropTypes.string,graphQLErrors:g.PropTypes.arrayOf(g.PropTypes.string),actions:g.PropTypes.object,securityId:g.PropTypes.string,onViewChange:g.PropTypes.func.isRequired,createFileApiUrl:g.PropTypes.string,createFileApiMethod:g.PropTypes.string,search:g.PropTypes.object,enableDropzone:g.PropTypes.bool,concatenateSelect:g.PropTypes.bool,GalleryToolbar:g.PropTypes.func,sorters:g.PropTypes.arrayOf(g.PropTypes.shape({field:g.PropTypes.string.isRequired,direction:g.PropTypes.oneOf(["asc","desc"]).isRequired,label:g.PropTypes.string.isRequired})).isRequired}),t.Component=ee,t.galleryViewPropTypes=re,t.galleryViewDefaultProps=ne,t.default=(0,w.compose)((0,J.inject)(["GalleryToolbar"],null,function(){return"AssetAdmin.Gallery"}),(0,P.connect)(a,d),z.default,function(e){return(0,V.withApollo)(e)})(ee)},"./client/src/containers/Gallery/GalleryDND.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,"__esModule",{value:!0});var i=function(){function e(e,t){for(var o=0;o1&&void 0!==arguments[1])||arguments[1];return h.default.createEndpointFetcher(Object.assign({},e,t?{defaultData:{SecurityID:_.default.get("SecurityID")}}:{}))},S=function(e){function t(e){r(this,t);var o=s(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e));return o.state={detailView:null,history:[],loadedDetails:!1},o.handleClick=o.handleClick.bind(o),o.handleBack=o.handleBack.bind(o),o.timer=null,o.api=j(e.sectionConfig.historyEndpoint),o}return l(t,e),d(t,[{key:"componentDidMount",value:function(){this.refreshHistoryIfNeeded()}},{key:"componentWillReceiveProps",value:function(e){this.refreshHistoryIfNeeded(e)}},{key:"componentWillUnmount",value:function(){clearTimeout(this.timer),this.timer=null}},{key:"refreshHistoryIfNeeded",value:function(e){var t=this;if(!e&&!this.state.loadedDetails||e.data.fileId!==this.props.data.fileId||e.data.latestVersionId!==this.props.data.latestVersionId){this.setState({loadedDetails:!1});var o=e?e.data.fileId:this.props.data.fileId;clearTimeout(this.timer),this.timer=setTimeout(function(){t.api({fileId:o}).then(function(e){t.timer&&t.setState({history:e,loadedDetails:!0})})},250)}}},{key:"handleClick",value:function(e){this.setState({viewDetails:e})}},{key:"handleBack",value:function(e){e.preventDefault(),this.setState({viewDetails:null})}},{key:"render",value:function(){var e=this;if(!this.state.loadedDetails)return c.default.createElement("div",{className:"history-list history-list--loading"},"Loading...");if(this.state.viewDetails){var t=[this.props.historySchemaUrl,this.props.data.fileId,this.state.viewDetails].join("/"),o=["btn","btn-secondary","btn--icon-xl","btn--no-text","font-icon-left-open-big","history-list__back"].join(" ");return c.default.createElement("div",{className:"history-list"},c.default.createElement("a",{href:"#",className:o,onClick:this.handleBack}),c.default.createElement(b.default,{identifier:"AssetAdmin.HistoryList",schemaUrl:t}))}var n=this.state.history||[];return c.default.createElement("div",{className:"history-list"},c.default.createElement("ul",{className:"list-group list-group-flush history-list__list"},n.map(function(t){return c.default.createElement(y.default,a({key:t.versionid},t,{onClick:e.handleClick}))})))}}]),t}(u.Component);S.propTypes={sectionConfig:c.default.PropTypes.shape({form:c.default.PropTypes.object,historyEndpoint:c.default.PropTypes.shape({url:c.default.PropTypes.string,method:c.default.PropTypes.string,responseFormat:c.default.PropTypes.string})}),historySchemaUrl:c.default.PropTypes.string,data:c.default.PropTypes.object},S.defaultProps={data:{fieldId:0}},t.Component=S,t.default=(0,p.connect)(i)(S)},"./client/src/containers/MoveModal/MoveModal.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function i(e){var t=e.assetAdmin.gallery,o=t.modal,n=t.selectedFiles;return{isOpen:o===g.default.MODAL_MOVE,selectedFiles:n,title:m.default.sprintf(m.default._t("AssetAdmin.MOVE_ITEMS_TO","Move %s item(s) to..."),n.length)}}function a(e){return{onClosed:function(){e((0,y.deactivateModal)())},setNotice:function(t){e((0,y.setNoticeMessage)(t))},setError:function(t){e((0,y.setErrorMessage)(t))},setBadge:function(){e(y.setFileBadge.apply(void 0,arguments))}}}Object.defineProperty(t,"__esModule",{value:!0});var d=function(){function e(e,t){for(var o=0;o0)return c.default.createElement("div",{className:"gallery__progress-bar--complete"});var t={className:"gallery__progress-bar-progress",style:{width:e.progress+"%"}};return c.default.createElement("div",{className:"gallery__progress-bar"},c.default.createElement("div",t))}},{key:"renderTitle",value:function(e){var t=this.renderProgressBar(e.rowData);return c.default.createElement("div",{className:"fill-width"},c.default.createElement("div",{className:"flexbox-area-grow"},e.data),t)}},{key:"renderSelect",value:function(e){if(this.props.selectableItems&&(this.props.selectableFolders||"folder"!==e.rowData.type)){var t={type:"checkbox",title:m.default._t("AssetAdmin.SELECT"),checked:e.data,tabIndex:-1,onMouseDown:this.preventFocus};return![null,1].includes(this.props.maxFilesSelect)&&this.props.selectedFiles.length>=this.props.maxFilesSelect&&!e.data&&(t.disabled=!0),c.default.createElement("input",t)}return null}},{key:"renderDate",value:function(e){return"folder"===e.rowData.type?null:c.default.createElement("span",null,e.data)}},{key:"renderThumbnail",value:function(e){var t=e.data||e.rowData.url,o=e.rowData.queuedId&&!e.rowData.id,n=e.rowData.category||"false",r="gallery__table-image",s=[r],l={};return s.push(r+"--"+n),"image"===n&&t&&(l.backgroundImage='url("'+t+'")'),o||t||"folder"===n||s.push(r+"--error"),c.default.createElement("div",{className:s.join(" "),style:l})}},{key:"render",value:function(){return c.default.createElement(f.default,this.getTableProps())}}]),t}(u.Component);y.defaultProps=_.galleryViewDefaultProps,y.propTypes=i({},_.galleryViewPropTypes,{sort:u.PropTypes.string.isRequired}),t.Component=y,t.default=y},"./client/src/containers/ThumbnailView/ThumbnailView.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,"__esModule",{value:!0}),t.Component=void 0;var i=Object.assign||function(e){for(var t=1;t=this.props.maxFilesSelect,b=1===this.props.maxFilesSelect?c.onActivate:this.props.onSelect;c=i({},c,{selectable:!0,onSelect:b,maxSelected:v})}if("folder"===e.type){var E=this.props.onDropFiles;return c=i({},c,{onDropFiles:E}),p.default.createElement(n,c)}return p.default.createElement(o,c)}},{key:"render",value:function(){return p.default.createElement("div",{className:"gallery__main-view--tile"},p.default.createElement("div",{className:"gallery__folders"},this.props.files.filter(this.folderFilter).map(this.renderItem)),p.default.createElement("div",{className:"gallery__files"},this.props.files.filter(this.fileFilter).map(this.renderItem)),0===this.props.files.length&&!this.props.loading&&p.default.createElement("p",{className:"gallery__no-item-notice"},u.default._t("AssetAdmin.NOITEMSFOUND")),p.default.createElement("div",{className:"gallery__load"},this.renderPagination()))}}]),t}(c.Component);g.defaultProps=h.galleryViewDefaultProps,g.propTypes=i({},h.galleryViewPropTypes,{File:c.PropTypes.oneOfType([c.PropTypes.node,c.PropTypes.func]).isRequired,Folder:c.PropTypes.oneOfType([c.PropTypes.node,c.PropTypes.func]).isRequired});var y=(0,f.inject)(["GalleryItemFile","GalleryItemFolder"],function(e,t){return{File:e,Folder:t}},function(){return"AssetAdmin.Gallery.ThumbnailView"});t.Component=g,t.default=y(g)},"./client/src/entwine/UploadField/UploadFieldEntwine.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}var r=Object.assign||function(e){for(var t=1;t
');this.before(o),t=o[0]}return t},onunmatch:function(){this._super(),u.default.unmountComponentAtNode(this.siblings(".uploadfield-holder")[0])},onmatch:function(){var e=this.closest(".cms-content").attr("id"),t=e?{context:e}:{},o=(0,p.loadComponent)("UploadField",t);this.setComponent(o),this._super(),this.hide(),this.refresh()},onclick:function(e){e.preventDefault()},refresh:function(){var t=this.getAttributes(),o=e(this).closest("form"),n=function(){setTimeout(function(){o.trigger("change")},0)},s=this.getComponent();u.default.render(a.default.createElement(s,r({},t,{onChange:n,noHolder:!0})),this.getContainer())},getAttributes:function(){var t=e(this).data("state"),o=e(this).data("schema");return(0,c.schemaMerge)(o,t)}})})},"./client/src/lib/configShape.js":function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var n=o(0),r=n.PropTypes.shape({url:n.PropTypes.string,limit:n.PropTypes.number,imageRetry:n.PropTypes.shape({minRetry:n.PropTypes.number,maxRetry:n.PropTypes.number,expiry:n.PropTypes.number}),form:n.PropTypes.object,dropzoneOptions:n.PropTypes.object});t.default=r},"./client/src/lib/fileFragments.js":function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.fileInterface="\n fragment FileInterfaceFields on FileInterface {\n canDelete\n canEdit\n canView\n category\n exists\n filename\n id\n lastEdited\n name\n parentId\n title\n type\n url\n }\n",t.file="\n fragment FileFields on File {\n draft\n extension\n published\n modified\n size\n smallThumbnail\n thumbnail\n inUseCount\n }\n",t.folder="\n fragment FolderFields on Folder {\n filesInUseCount\n }\n"},"./client/src/lib/fileShape.js":function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var n=o(0),r=n.PropTypes.shape({canEdit:n.PropTypes.bool,canDelete:n.PropTypes.bool,canView:n.PropTypes.bool,exists:n.PropTypes.bool,type:n.PropTypes.string,smallThumbnail:n.PropTypes.string,thumbnail:n.PropTypes.string,width:n.PropTypes.number,height:n.PropTypes.number,category:n.PropTypes.oneOfType([n.PropTypes.bool,n.PropTypes.string]),id:n.PropTypes.number,inUseCount:n.PropTypes.number,url:n.PropTypes.string,title:n.PropTypes.string,progress:n.PropTypes.number});t.default=r},"./client/src/lib/fileStructure.js":function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var n=o(13),r=function(e){return e&&e.__esModule?e:{default:e}}(n),s=(0,r.default)({name:null,canDelete:!1,canEdit:!1,category:null,created:null,extension:null,filename:null,id:0,lastEdited:null,messages:null,owner:{id:0,title:null},parent:{filename:null,id:0,title:null},queuedId:null,size:null,title:null,type:null,url:null,xhr:null,thumbnail:null,smallThumbnail:null,height:null,width:null});t.default=s},"./client/src/state/files/buildPublicationMutation.js":function(e,t,o){"use strict";function n(e,t,o){return t in e?Object.defineProperty(e,t,{value:o,enumerable:!0,configurable:!0,writable:!0}):e[t]=o,e}Object.defineProperty(t,"__esModule",{value:!0});var r=Object.assign||function(e){for(var t=1;t1&&void 0!==arguments[1]&&arguments[1],n=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];return o({variables:{IDs:e,Quiet:n,Force:t}})};return{actions:r({},s,{files:r({},s.files,n({},e,l))})}}}}};t.default=d},"./client/src/state/files/deleteFilesMutation.js":function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.config=t.mutation=void 0;var n=Object.assign||function(e){for(var t=1;t0&&void 0!==arguments[0]?arguments[0]:null;return function(t){return t({type:y.default.SELECT_FILES,payload:{ids:e}})}}function i(e){return function(t){return t({type:y.default.CONCATENATE_SELECT,payload:!!e})}}function a(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;return function(t){return t({type:y.default.DESELECT_FILES,payload:{ids:e}})}}function d(e){return function(t){return t({type:y.default.SET_NOTICE_MESSAGE,payload:{message:e}})}}function u(e){return function(t){return t({type:y.default.SET_ERROR_MESSAGE,payload:{message:e}})}}function c(e){return function(t){return t({type:y.default.SET_ENABLE_DROPZONE,payload:{enableDropzone:e}})}}function p(e){return function(t){t({type:y.default.CLEAR_FILE_BADGE,payload:{id:e}})}}function f(e,t,o,n){return function(r,s){var l=s(),i=l.assetAdmin,a=i.gallery.badges.find(function(t){return t.id===e});a&&a.timer&&clearTimeout(a.timer);var d=n>0?setTimeout(function(){return p(e)(r)},n):null;r({type:y.default.SET_FILE_BADGE,payload:{id:e,message:t,status:o,timer:d}})}}function h(e){return function(t){t({type:y.default.ACTIVATE_MODAL,payload:e})}}function m(){return function(e){e({type:y.default.DEACTIVATE_MODAL})}}function _(e){return function(t){t({type:y.default.SET_LOADING,payload:!!e})}}Object.defineProperty(t,"__esModule",{value:!0}),t.setLastSelected=n,t.setSelectedFiles=r,t.loadFile=s,t.selectFiles=l,t.setConcatenateSelect=i,t.deselectFiles=a,t.setNoticeMessage=d,t.setErrorMessage=u,t.setEnableDropzone=c,t.clearFileBadge=p,t.setFileBadge=f,t.activateModal=h,t.deactivateModal=m,t.setLoading=_;var g=o("./client/src/state/gallery/GalleryActionTypes.js"),y=function(e){return e&&e.__esModule?e:{default:e}}(g)},"./client/src/state/gallery/GalleryReducer.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:p,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},o=t.type,n=t.payload;switch(o){case d.default.SET_LAST_SELECTED:return s({},e,{lastSelected:n.id});case d.default.SET_FILE_BADGE:return s({},e,{badges:e.badges.filter(function(e){return e.id!==n.id}).concat([n])});case d.default.CLEAR_FILE_BADGE:return s({},e,{badges:e.badges.filter(function(e){return e.id!==n.id})});case d.default.SET_ENABLE_DROPZONE:return s({},e,{enableDropzone:n.enableDropzone});case d.default.SET_NOTICE_MESSAGE:return s({},e,{noticeMessage:n.message});case d.default.SET_ERROR_MESSAGE:return s({},e,{errorMessage:n.message});case d.default.LOAD_FILE_SUCCESS:var r=e.files.find(function(e){return e.id===n.id});if(r){var l=s({},r,n.file);return(0,i.default)(s({},e,{files:e.files.map(function(e){return e.id===l.id?l:e})}))}return e.folder.id===n.id?(0,i.default)(s({},e,{folder:s({},e.folder,n.file)})):e;case d.default.SET_SELECTED_FILES:return(0,i.default)(s({},e,{selectedFiles:Array.isArray(n.files)?n.files:[]}));case d.default.SELECT_FILES:var a=null;return a=null===n.ids?e.files.map(function(e){return e.id}):e.selectedFiles.concat(n.ids.filter(function(t){return-1===e.selectedFiles.indexOf(t)})),(0,i.default)(s({},e,{selectedFiles:a}));case d.default.DESELECT_FILES:var u=null;return u=null===n.ids?[]:e.selectedFiles.filter(function(e){return-1===n.ids.indexOf(e)}),(0,i.default)(s({},e,{selectedFiles:u}));case d.default.ACTIVATE_MODAL:return(0,i.default)(s({},e,{modal:n}));case d.default.DEACTIVATE_MODAL:return(0,i.default)(s({},e,{modal:null}));case d.default.CONCATENATE_SELECT:return(0,i.default)(s({},e,{concatenateSelect:n}));case d.default.SET_LOADING:return(0,i.default)(s({},e,{loading:n}));default:return e}}Object.defineProperty(t,"__esModule",{value:!0});var s=Object.assign||function(e){for(var t=1;t1&&void 0!==arguments[1]?arguments[1]:p;r(this,e),this.options=s({},c,t),this.factory=o}return l(e,[{key:"loadImage",value:function(e){return this.options.minRetry&&u.default.lock(e)?this.loadImageLoop(e,this.options.minRetry):null}},{key:"loadImageLoop",value:function(e,t){var o=this;return this.options.onStatusChange(e,a.default.LOADING),new Promise(function(t,n){return o.factory(e,t,n)}).then(function(){return o.handleSuccess(e)}).catch(function(){return o.handleError(e,t)})}},{key:"handleReset",value:function(e,t){this.options.onReset(e),t()}},{key:"handleTimeout",value:function(e,t){var o=setTimeout(e,t);return this.options.onTimeout(o,t),o}},{key:"handleSuccess",value:function(e){u.default.unlock(e),this.options.onStatusChange(e,a.default.SUCCESS)}},{key:"handleFailure",value:function(e){var t=this;return u.default.unlock(e),this.options.onStatusChange(e,a.default.FAILED),this.options.expiry?new Promise(function(o){t.handleTimeout(function(){return t.handleReset(e,o)},1e3*t.options.expiry)}):null}},{key:"handleError",value:function(e,t){return t>this.options.maxRetry?this.handleFailure(e):(this.options.onStatusChange(e,a.default.WAITING),this.handleRetry(e,t))}},{key:"handleRetry",value:function(e,t){var o=this,n=new Promise(function(n){o.handleTimeout(function(){return n(o.loadImageLoop(e,2*t))},1e3*t)});return this.options.onRetry(e,t,n),n}},{key:"setOnRetry",value:function(e){this.options.onRetry=e}},{key:"setOnReset",value:function(e){this.options.onReset=e}},{key:"setOnStatusChange",value:function(e){this.options.onStatusChange=e}},{key:"setOnTimeout",value:function(e){this.options.onTimeout=e}}]),e}();t.defaultImageFactory=p,t.default=f},"./client/src/state/imageLoad/ImageLoadActionTypes.js":function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default={SET_STATUS:"IMAGE_LOAD_SET_STATUS",RESET:"IMAGE_LOAD_RESET"}},"./client/src/state/imageLoad/ImageLoadActions.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){return function(o,n){if(!e)return null;if(n().assetAdmin.imageLoad.files.find(function(t){return t.url===e}))return null;var r=s({},t,{onStatusChange:function(e,t){return o({type:i.default.SET_STATUS,payload:{status:t,url:e}})},onReset:function(e){return o({type:i.default.RESET,payload:{url:e}})}});return new d.default(r).loadImage(e)}}Object.defineProperty(t,"__esModule",{value:!0});var s=Object.assign||function(e){for(var t=1;t=0||(this.urls=[].concat(n(this.urls),[e]),0))}},{key:"unlock",value:function(e){this.urls=this.urls.filter(function(t){return t!==e})}}]),e}();window.ss=window.ss||{},window.ss.imagelocker=window.ss.imagelocker||new l,t.Component=l,t.default=window.ss.imagelocker},"./client/src/state/imageLoad/ImageLoadReducer.js":function(e,t,o){"use strict";function n(e){if(Array.isArray(e)){for(var t=0,o=Array(e.length);t0&&void 0!==arguments[0]?arguments[0]:a,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},o=t.type,r=t.payload;switch(o){case i.default.SET_STATUS:return s({},e,{files:[].concat(n(e.files.filter(function(e){return e.url!==r.url})),[r])});case i.default.RESET:return s({},e,{files:[].concat(n(e.files.filter(function(e){return e.url!==r.url})))});default:return e}}Object.defineProperty(t,"__esModule",{value:!0});var s=Object.assign||function(e){for(var t=1;t0&&void 0!==arguments[0]?arguments[0]:u,t=arguments[1];switch(t.type){case d.default.PREVIEWFIELD_ADD_FILE:return(0,i.default)(Object.assign({},e,r({},t.payload.id,t.payload.file)));case d.default.PREVIEWFIELD_FAIL_UPLOAD:return(0,i.default)(Object.assign({},e,r({},t.payload.id,Object.assign({},e[t.payload.id],t.payload.message))));case d.default.PREVIEWFIELD_REMOVE_FILE:return(0,i.default)(Object.assign({},e,r({},t.payload.id,void 0)));case d.default.PREVIEWFIELD_UPDATE_FILE:return(0,i.default)(Object.assign({},e,r({},t.payload.id,Object.assign({},e[t.payload.id],t.payload.data))));default:return e}}Object.defineProperty(t,"__esModule",{value:!0});var l=o(13),i=n(l),a=o("./client/src/state/previewField/PreviewFieldActionTypes.js"),d=n(a),u={};t.default=s},"./client/src/state/queuedFiles/QueuedFilesActionTypes.js":function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default={ADD_QUEUED_FILE:"ADD_QUEUED_FILE",FAIL_UPLOAD:"FAIL_UPLOAD",PURGE_UPLOAD_QUEUE:"PURGE_UPLOAD_QUEUE",REMOVE_QUEUED_FILE:"REMOVE_QUEUED_FILE",SUCCEED_UPLOAD:"SUCCEED_UPLOAD",UPDATE_QUEUED_FILE:"UPDATE_QUEUED_FILE"}},"./client/src/state/queuedFiles/QueuedFilesActions.js":function(e,t,o){"use strict";function n(e){return function(t){return t({type:u.default.ADD_QUEUED_FILE,payload:{file:e}})}}function r(e,t){return function(o){var n=t.message;return t.errors&&t.errors.length&&(n=t.errors[0]),"string"==typeof t&&(n={value:t,type:"error"}),o({type:u.default.FAIL_UPLOAD,payload:{queuedId:e,message:n}})}}function s(){return function(e){return e({type:u.default.PURGE_UPLOAD_QUEUE,payload:null})}}function l(e){return function(t){return t({type:u.default.REMOVE_QUEUED_FILE,payload:{queuedId:e}})}}function i(e,t){return function(o){return o({type:u.default.SUCCEED_UPLOAD,payload:{queuedId:e,json:t}})}}function a(e,t){return function(o){return o({type:u.default.UPDATE_QUEUED_FILE,payload:{queuedId:e,updates:t}})}}Object.defineProperty(t,"__esModule",{value:!0}),t.addQueuedFile=n,t.failUpload=r,t.purgeUploadQueue=s,t.removeQueuedFile=l,t.succeedUpload=i,t.updateQueuedFile=a;var d=o("./client/src/state/queuedFiles/QueuedFilesActionTypes.js"),u=function(e){return e&&e.__esModule?e:{default:e}}(d)},"./client/src/state/queuedFiles/QueuedFilesReducer.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e){if(Array.isArray(e)){for(var t=0,o=Array(e.length);t0&&void 0!==arguments[0]?arguments[0]:m,t=arguments[1];switch(t.type){case u.default.ADD_QUEUED_FILE:return(0,a.default)(l({},e,{items:[].concat(r(e.items),[l({},p.default,t.payload.file)])}));case u.default.FAIL_UPLOAD:return(0,a.default)(l({},e,{items:e.items.map(function(e){return e.queuedId===t.payload.queuedId?l({},e,{message:t.payload.message}):e})}));case u.default.PURGE_UPLOAD_QUEUE:return(0,a.default)(l({},e,{items:e.items.filter(function(e){return!e.id})}));case u.default.REMOVE_QUEUED_FILE:return(0,a.default)(l({},e,{items:e.items.filter(function(e){return e.queuedId!==t.payload.queuedId})}));case u.default.SUCCEED_UPLOAD:return(0,a.default)(l({},e,{items:e.items.map(function(e){return e.queuedId===t.payload.queuedId?l({},e,t.payload.json,{messages:[{value:h.default._t("AssetAdmin.DROPZONE_SUCCESS_UPLOAD"),type:"success",extraClass:"success"}]}):e})}));case u.default.UPDATE_QUEUED_FILE:return(0,a.default)(l({},e,{items:e.items.map(function(e){return e.queuedId===t.payload.queuedId?l({},e,t.payload.updates):e})}));default:return e}}Object.defineProperty(t,"__esModule",{value:!0});var l=Object.assign||function(e){for(var t=1;t0&&void 0!==arguments[0]?arguments[0]:f,t=arguments[1],o=(0,p.default)(e,t,h);switch(t.type){case a.default.UPLOADFIELD_ADD_FILE:return o(function(e){return e.files.find(function(e){return e.id===t.payload.file.id})?e:l({},e,{files:[].concat(r(e.files),[l({},u.default,t.payload.file)])})});case a.default.UPLOADFIELD_SET_FILES:return o(function(){return{files:t.payload.files}});case a.default.UPLOADFIELD_UPLOAD_FAILURE:return o(function(e){return{files:e.files.map(function(e){return e.queuedId===t.payload.queuedId?Object.assign({},e,{message:t.payload.message}):e})}});case a.default.UPLOADFIELD_REMOVE_FILE:return o(function(e){return{files:e.files.filter(function(e){return!(t.payload.file.queuedId&&e.queuedId===t.payload.file.queuedId||t.payload.file.id&&e.id===t.payload.file.id)})}});case a.default.UPLOADFIELD_UPLOAD_SUCCESS:return o(function(e){return{files:e.files.map(function(e){return e.queuedId===t.payload.queuedId?Object.assign({},e,t.payload.json):e})}});case a.default.UPLOADFIELD_UPDATE_QUEUED_FILE:return o(function(e){return{files:e.files.map(function(e){return e.queuedId===t.payload.queuedId?Object.assign({},e,t.payload.updates):e})}});default:return e}}Object.defineProperty(t,"__esModule",{value:!0});var l=Object.assign||function(e){for(var t=1;t0?s.default._t("AssetAdmin.UPDATE_FILE","Update file"):s.default._t("AssetAdmin.INSERT_FILE","Insert file");return e.mutateField("action_insert",function(e){return n({},e,{title:r||e.title})}),e.getState()};t.default=l},"./client/src/transforms/FormAction/ownerAwareUnpublish.js":function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var r=Object.assign||function(e){for(var t=1;t0?[a.default.inject(a.default._t("AssetAdmin.SINGLE_OWNED_WARNING_1","This file is being used in {count} other published section(s)."),{count:r}),a.default._t("AssetAdmin.SINGLE_OWNED_WARNING_2","Ensure files are removed from content areas prior to unpublishing them. Otherwise, they will appear as broken links."),a.default._t("AssetAdmin.SINGLE_OWNED_WARNING_3","Do you want to unpublish this file anyway?")].join("\n\n"):a.default._t("AssetAdmin.CONFIRMUNPUBLISH","Are you sure you want to unpublish this record?"),confirm(s)?o(e,n):e.preventDefault()}});return l.default.createElement(e,n)}};t.default=d},"./client/src/transforms/TreeDropdownField/moveTreeDropdownField.js":function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.disabledTreeDropdownField=void 0;var n=Object.assign||function(e){for(var t=1;t
'),this.element.appendChild(o)),n=o.getElementsByTagName("span")[0],n&&(null!=n.textContent?n.textContent=this.options.dictFallbackMessage:null!=n.innerText&&(n.innerText=this.options.dictFallbackMessage)),this.element.appendChild(this.getFallbackForm())},resize:function(e){var t,o,n;return t={srcX:0,srcY:0,srcWidth:e.width,srcHeight:e.height},o=e.width/e.height,t.optWidth=this.options.thumbnailWidth,t.optHeight=this.options.thumbnailHeight,null==t.optWidth&&null==t.optHeight?(t.optWidth=t.srcWidth,t.optHeight=t.srcHeight):null==t.optWidth?t.optWidth=o*t.optHeight:null==t.optHeight&&(t.optHeight=1/o*t.optWidth),n=t.optWidth/t.optHeight,e.heightn?(t.srcHeight=e.height,t.srcWidth=t.srcHeight*n):(t.srcWidth=e.width,t.srcHeight=t.srcWidth/n),t.srcX=(e.width-t.srcWidth)/2,t.srcY=(e.height-t.srcHeight)/2,t},drop:function(e){return this.element.classList.remove("dz-drag-hover")},dragstart:a,dragend:function(e){return this.element.classList.remove("dz-drag-hover")},dragenter:function(e){return this.element.classList.add("dz-drag-hover")},dragover:function(e){return this.element.classList.add("dz-drag-hover")},dragleave:function(e){return this.element.classList.remove("dz-drag-hover")},paste:a,reset:function(){return this.element.classList.remove("dz-started")},addedfile:function(e){var o,n,r,s,l,i,a,d,u,c,p,f,h;if(this.element===this.previewsContainer&&this.element.classList.add("dz-started"),this.previewsContainer){for(e.previewElement=t.createElement(this.options.previewTemplate.trim()),e.previewTemplate=e.previewElement,this.previewsContainer.appendChild(e.previewElement),c=e.previewElement.querySelectorAll("[data-dz-name]"),s=0,a=c.length;s'+this.options.dictRemoveFile+"
"),e.previewElement.appendChild(e._removeLink)),n=function(o){return function(n){return n.preventDefault(),n.stopPropagation(),e.status===t.UPLOADING?t.confirm(o.options.dictCancelUploadConfirmation,function(){return o.removeFile(e)}):o.options.dictRemoveFileConfirmation?t.confirm(o.options.dictRemoveFileConfirmation,function(){return o.removeFile(e)}):o.removeFile(e)}}(this),f=e.previewElement.querySelectorAll("[data-dz-remove]"),h=[],i=0,u=f.length;i\n
\n
\n
\n
\n
\n
\n
\n
\n \n Check\n \n \n \n \n \n
\n
\n \n Error\n \n \n \n \n \n \n \n
\n
'},o=function(){var e,t,o,n,r,s,l;for(n=arguments[0],o=2<=arguments.length?u.call(arguments,1):[],s=0,l=o.length;s'+this.options.dictDefaultMessage+"
")),this.clickableElements.length&&(n=function(e){return function(){return e.hiddenFileInput&&e.hiddenFileInput.parentNode.removeChild(e.hiddenFileInput),e.hiddenFileInput=document.createElement("input"),e.hiddenFileInput.setAttribute("type","file"),(null==e.options.maxFiles||e.options.maxFiles>1)&&e.hiddenFileInput.setAttribute("multiple","multiple"),e.hiddenFileInput.className="dz-hidden-input",null!=e.options.acceptedFiles&&e.hiddenFileInput.setAttribute("accept",e.options.acceptedFiles),null!=e.options.capture&&e.hiddenFileInput.setAttribute("capture",e.options.capture),e.hiddenFileInput.style.visibility="hidden",e.hiddenFileInput.style.position="absolute",e.hiddenFileInput.style.top="0",e.hiddenFileInput.style.left="0",e.hiddenFileInput.style.height="0",e.hiddenFileInput.style.width="0",document.querySelector(e.options.hiddenInputContainer).appendChild(e.hiddenFileInput),e.hiddenFileInput.addEventListener("change",function(){var t,o,r,s;if(o=e.hiddenFileInput.files,o.length)for(r=0,s=o.length;r',this.options.dictFallbackText&&(n+="

"+this.options.dictFallbackText+"

"),n+='
',o=t.createElement(n),"FORM"!==this.element.tagName?(r=t.createElement('
'),r.appendChild(o)):(this.element.setAttribute("enctype","multipart/form-data"),this.element.setAttribute("method",this.options.method)),null!=r?r:o)},t.prototype.getExistingFallback=function(){var e,t,o,n,r,s;for(t=function(e){var t,o,n;for(o=0,n=e.length;o0){for(l=["TB","GB","MB","KB","b"],o=i=0,a=l.length;i=t){n=e/Math.pow(this.options.filesizeBase,4-o),r=s;break}n=Math.round(10*n)/10}return""+n+" "+r},t.prototype._updateMaxFilesReachedClass=function(){return null!=this.options.maxFiles&&this.getAcceptedFiles().length>=this.options.maxFiles?(this.getAcceptedFiles().length===this.options.maxFiles&&this.emit("maxfilesreached",this.files),this.element.classList.add("dz-max-files-reached")):this.element.classList.remove("dz-max-files-reached")},t.prototype.drop=function(e){var t,o;e.dataTransfer&&(this.emit("drop",e),t=e.dataTransfer.files,this.emit("addedfiles",t),t.length&&(o=e.dataTransfer.items,o&&o.length&&null!=o[0].webkitGetAsEntry?this._addFilesFromItems(o):this.handleFiles(t)))},t.prototype.paste=function(e){var t,o;if(null!=(null!=e&&null!=(o=e.clipboardData)?o.items:void 0))return this.emit("paste",e),t=e.clipboardData.items,t.length?this._addFilesFromItems(t):void 0},t.prototype.handleFiles=function(e){var t,o,n,r;for(r=[],o=0,n=e.length;o0){for(s=0,l=o.length;s1024*this.options.maxFilesize*1024?o(this.options.dictFileTooBig.replace("{{filesize}}",Math.round(e.size/1024/10.24)/100).replace("{{maxFilesize}}",this.options.maxFilesize)):t.isValidFile(e,this.options.acceptedFiles)?null!=this.options.maxFiles&&this.getAcceptedFiles().length>=this.options.maxFiles?(o(this.options.dictMaxFilesExceeded.replace("{{maxFiles}}",this.options.maxFiles)),this.emit("maxfilesexceeded",e)):this.options.accept.call(this,e,o):o(this.options.dictInvalidFileType)},t.prototype.addFile=function(e){return e.upload={progress:0,total:e.size,bytesSent:0},this.files.push(e),e.status=t.ADDED,this.emit("addedfile",e),this._enqueueThumbnail(e),this.accept(e,function(t){return function(o){return o?(e.accepted=!1,t._errorProcessing([e],o)):(e.accepted=!0,t.options.autoQueue&&t.enqueueFile(e)),t._updateMaxFilesReachedClass()}}(this))},t.prototype.enqueueFiles=function(e){var t,o,n;for(o=0,n=e.length;o=t)&&(n=this.getQueuedFiles(),n.length>0)){if(this.options.uploadMultiple)return this.processFiles(n.slice(0,t-o));for(;e=M;u=0<=M?++x:--x)s.append(this._getParamName(u),e[u],this._renameFilename(e[u].name));return this.submitRequest(j,s,e)},t.prototype.submitRequest=function(e,t,o){return e.send(t)},t.prototype._finished=function(e,o,n){var r,s,l;for(s=0,l=e.length;sd;)t=r[4*(i-1)+3],0===t?s=i:d=i,i=s+d>>1;return a=i/l,0===a?1:a},i=function(e,t,o,n,r,s,i,a,d,u){var c;return c=l(t),e.drawImage(t,o,n,r,s,i,a,d,u/c)},s=function(e,t){var o,n,r,s,l,i,a,d,u;if(r=!1,u=!0,n=e.document,d=n.documentElement,o=n.addEventListener?"addEventListener":"attachEvent",a=n.addEventListener?"removeEventListener":"detachEvent",i=n.addEventListener?"":"on",s=function(o){if("readystatechange"!==o.type||"complete"===n.readyState)return("load"===o.type?e:n)[a](i+o.type,s,!1),!r&&(r=!0)?t.call(e,o.type||o):void 0},l=function(){try{d.doScroll("left")}catch(e){return void setTimeout(l,50)}return s("poll")},"complete"!==n.readyState){if(n.createEventObject&&d.doScroll){try{u=!e.frameElement}catch(e){}u&&l()}return n[o](i+"DOMContentLoaded",s,!1),n[o](i+"readystatechange",s,!1),e[o](i+"load",s,!1)}},o._autoDiscoverFunction=function(){if(o.autoDiscover)return o.discover()},s(window,o._autoDiscoverFunction)}).call(this)}).call(t,o(6),o("./node_modules/webpack/buildin/module.js")(e))},"./node_modules/expose-loader/index.js?InsertEmbedModal!./client/src/components/InsertEmbedModal/InsertEmbedModal.js-exposed":function(e,t,o){(function(t){e.exports=t.InsertEmbedModal=o('./node_modules/babel-loader/lib/index.js?{"presets":[["env",{"modules":false}],"react"],"plugins":["transform-object-rest-spread"],"comments":false,"cacheDirectory":false}!./client/src/components/InsertEmbedModal/InsertEmbedModal.js')}).call(t,o("./node_modules/webpack/buildin/global.js"))},"./node_modules/expose-loader/index.js?InsertMediaModal!./client/src/containers/InsertMediaModal/InsertMediaModal.js-exposed":function(e,t,o){(function(t){e.exports=t.InsertMediaModal=o('./node_modules/babel-loader/lib/index.js?{"presets":[["env",{"modules":false}],"react"],"plugins":["transform-object-rest-spread"],"comments":false,"cacheDirectory":false}!./client/src/containers/InsertMediaModal/InsertMediaModal.js')}).call(t,o("./node_modules/webpack/buildin/global.js"))},"./node_modules/griddle-react/modules/columnProperties.js":function(e,t,o){"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}var r=function(){function e(e,t){for(var o=0;o0}},{key:"getMetadataColumnProperty",value:function(e,t,o){var n=this.getColumnMetadataByName(e);return void 0===n||null===n?o:n.hasOwnProperty(t)?n[t]:o}},{key:"orderColumns",value:function(e){var t=this;return a(e,function(e){var o=i(t.columnMetadata,{columnName:e});return void 0===o||null===o||isNaN(o.order)?100:o.order})}},{key:"getColumns",value:function(){var e=0===this.filteredColumns.length?this.allColumns:this.filteredColumns;return e=d(e,this.metadataColumns),e=this.orderColumns(e)}}]),e}();e.exports=u},"./node_modules/griddle-react/modules/customFilterContainer.jsx.js":function(e,t,o){"use strict";var n=o(0),r=n.createClass({displayName:"CustomFilterContainer",getDefaultProps:function(){return{placeholderText:""}},render:function(){var e=this;return"function"!=typeof e.props.customFilterComponent?(console.log("Couldn't find valid template."),n.createElement("div",null)):n.createElement(e.props.customFilterComponent,{changeFilter:this.props.changeFilter,results:this.props.results,currentResults:this.props.currentResults,placeholderText:this.props.placeholderText})}});e.exports=r},"./node_modules/griddle-react/modules/customPaginationContainer.jsx.js":function(e,t,o){"use strict";var n=Object.assign||function(e){for(var t=1;t0&&(e=n.createElement("button",{type:"button",onClick:this.props.previous,style:this.props.useGriddleStyles?{color:"#222",border:"none",background:"none",margin:"0 0 0 10px"}:null},this.props.previousIconComponent,this.props.previousText)),this.props.currentPage!==this.props.maxPage-1&&(t=n.createElement("button",{type:"button",onClick:this.props.next,style:this.props.useGriddleStyles?{color:"#222",border:"none",background:"none",margin:"0 10px 0 0"}:null},this.props.nextText,this.props.nextIconComponent));var o=null,s=null,l=null;if(!0===this.props.useGriddleStyles){var i={float:"left",minHeight:"1px",marginTop:"5px"};l=r({textAlign:"right",width:"34%"},i),s=r({textAlign:"center",width:"33%"},i),o=r({width:"33%"},i)}for(var a=[],d=1;d<=this.props.maxPage;d++)a.push(n.createElement("option",{value:d,key:d},d));return n.createElement("div",{style:this.props.useGriddleStyles?{minHeight:"35px"}:null},n.createElement("div",{className:this.props.previousClassName,style:o},e),n.createElement("div",{className:"griddle-page",style:s},n.createElement("select",{value:this.props.currentPage+1,onChange:this.pageChange},a)," / ",this.props.maxPage),n.createElement("div",{className:this.props.nextClassName,style:l},t))}});e.exports=s},"./node_modules/griddle-react/modules/gridRow.jsx.js":function(e,t,o){"use strict";var n=o(0),r=(o("./node_modules/griddle-react/modules/columnProperties.js"),o("./node_modules/griddle-react/modules/deep.js")),s=o("./node_modules/griddle-react/node_modules/lodash/isFunction.js"),l=o("./node_modules/griddle-react/node_modules/lodash/zipObject.js"),i=o("./node_modules/griddle-react/node_modules/lodash/assign.js"),a=o("./node_modules/griddle-react/node_modules/lodash/defaults.js"),d=o("./node_modules/griddle-react/node_modules/lodash/toPairs.js"),u=o("./node_modules/griddle-react/node_modules/lodash/without.js"),c=n.createClass({displayName:"GridRow",getDefaultProps:function(){return{isChildRow:!1,showChildren:!1,data:{},columnSettings:null,rowSettings:null,hasChildren:!1,useGriddleStyles:!0,useGriddleIcons:!0,isSubGriddle:!1,paddingHeight:null,rowHeight:null,parentRowCollapsedClassName:"parent-row",parentRowExpandedClassName:"parent-row expanded",parentRowCollapsedComponent:"â–¶",parentRowExpandedComponent:"â–¼",onRowClick:null,multipleSelectionSettings:null}},handleClick:function(e){null!==this.props.onRowClick&&s(this.props.onRowClick)?this.props.onRowClick(this,e):this.props.hasChildren&&this.props.toggleChildren()},handleSelectionChange:function(e){},handleSelectClick:function(e){this.props.multipleSelectionSettings.isMultipleSelection&&("checkbox"===e.target.type?this.props.multipleSelectionSettings.toggleSelectRow(this.props.data,this.refs.selected.checked):this.props.multipleSelectionSettings.toggleSelectRow(this.props.data,!this.refs.selected.checked))},verifyProps:function(){null===this.props.columnSettings&&console.error("gridRow: The columnSettings prop is null and it shouldn't be")},formatData:function(e){return"boolean"==typeof e?String(e):e},render:function(){var e=this;this.verifyProps();var t=this,o=null;this.props.useGriddleStyles&&(o={margin:"0px",padding:t.props.paddingHeight+"px 5px "+t.props.paddingHeight+"px 5px",height:t.props.rowHeight?this.props.rowHeight-2*t.props.paddingHeight+"px":null,backgroundColor:"#FFF",borderTopColor:"#DDD",color:"#222"});var c=this.props.columnSettings.getColumns(),p=l(c,[]),f=i({},this.props.data);a(f,p);var h,m,_=d(r.pick(f,u(c,"children"))),g=_.map(function(t,r){var s=null,l=e.props.columnSettings.getColumnMetadataByName(t[0]),a=0===r&&e.props.hasChildren&&!1===e.props.showChildren&&e.props.useGriddleIcons?n.createElement("span",{style:e.props.useGriddleStyles?{fontSize:"10px",marginRight:"5px"}:null},e.props.parentRowCollapsedComponent):0===r&&e.props.hasChildren&&e.props.showChildren&&e.props.useGriddleIcons?n.createElement("span",{style:e.props.useGriddleStyles?{fontSize:"10px"}:null},e.props.parentRowExpandedComponent):"";if(0===r&&e.props.isChildRow&&e.props.useGriddleStyles&&(o=i(o,{paddingLeft:10})),e.props.columnSettings.hasColumnMetadata()&&void 0!==l&&null!==l)if(void 0!==l.customComponent&&null!==l.customComponent){var d=n.createElement(l.customComponent,{data:t[1],rowData:f,metadata:l});s=n.createElement("td",{onClick:e.handleClick,className:l.cssClassName,key:r,style:o},d)}else s=n.createElement("td",{onClick:e.handleClick,className:l.cssClassName,key:r,style:o},a,e.formatData(t[1]));return s||n.createElement("td",{onClick:e.handleClick,key:r,style:o},a,t[1])});null!==this.props.onRowClick&&s(this.props.onRowClick)?(h=null,m=this.handleSelectClick):this.props.multipleSelectionSettings&&this.props.multipleSelectionSettings.isMultipleSelection?(h=this.handleSelectClick,m=null):(h=null,m=null),g&&this.props.multipleSelectionSettings&&this.props.multipleSelectionSettings.isMultipleSelection&&(this.props.multipleSelectionSettings.getSelectedRowIds(),g.unshift(n.createElement("td",{key:"selection",style:o,className:"griddle-select griddle-select-cell",onClick:m},n.createElement("input",{type:"checkbox",checked:this.props.multipleSelectionSettings.getIsRowChecked(f),onChange:this.handleSelectionChange,ref:"selected"}))));var y=t.props.rowSettings&&t.props.rowSettings.getBodyRowMetadataClass(t.props.data)||"standard-row";return t.props.isChildRow?y="child-row":t.props.hasChildren&&(y=t.props.showChildren?this.props.parentRowExpandedClassName:this.props.parentRowCollapsedClassName),n.createElement("tr",{onClick:h,className:y},g)}});e.exports=c},"./node_modules/griddle-react/modules/gridRowContainer.jsx.js":function(e,t,o){"use strict";var n=o(0),r=(o("./node_modules/griddle-react/modules/columnProperties.js"),o("./node_modules/griddle-react/node_modules/lodash/pick.js")),s=n.createClass({displayName:"GridRowContainer",getDefaultProps:function(){return{useGriddleStyles:!0,useGriddleIcons:!0,isSubGriddle:!1,columnSettings:null,rowSettings:null,paddingHeight:null,rowHeight:null,parentRowCollapsedClassName:"parent-row",parentRowExpandedClassName:"parent-row expanded",parentRowCollapsedComponent:"â–¶",parentRowExpandedComponent:"â–¼",onRowClick:null,multipleSelectionSettings:null}},getInitialState:function(){return{data:{},showChildren:!1}},componentWillReceiveProps:function(){this.setShowChildren(!1)},toggleChildren:function(){this.setShowChildren(!1===this.state.showChildren)},setShowChildren:function(e){this.setState({showChildren:e})},verifyProps:function(){null===this.props.columnSettings&&console.error("gridRowContainer: The columnSettings prop is null and it shouldn't be")},render:function(){this.verifyProps();var e=this;if(void 0===this.props.data)return n.createElement("tbody",null);var t=[],o=this.props.columnSettings.getColumns();t.push(n.createElement(this.props.rowSettings.rowComponent,{useGriddleStyles:this.props.useGriddleStyles,isSubGriddle:this.props.isSubGriddle,data:this.props.rowSettings.isCustom?r(this.props.data,o):this.props.data,rowData:this.props.rowSettings.isCustom?this.props.data:null,columnSettings:this.props.columnSettings,rowSettings:this.props.rowSettings,hasChildren:e.props.hasChildren,toggleChildren:e.toggleChildren,showChildren:e.state.showChildren,key:e.props.uniqueId+"_base_row",useGriddleIcons:e.props.useGriddleIcons,parentRowExpandedClassName:this.props.parentRowExpandedClassName,parentRowCollapsedClassName:this.props.parentRowCollapsedClassName,parentRowExpandedComponent:this.props.parentRowExpandedComponent,parentRowCollapsedComponent:this.props.parentRowCollapsedComponent,paddingHeight:e.props.paddingHeight,rowHeight:e.props.rowHeight,onRowClick:e.props.onRowClick,multipleSelectionSettings:this.props.multipleSelectionSettings}));var s=null;return e.state.showChildren&&(s=e.props.hasChildren&&this.props.data.children.map(function(t,o){var r=e.props.rowSettings.getRowKey(t,o);if(void 0!==t.children){var s=e.constructor.Griddle;return n.createElement("tr",{key:r,style:{paddingLeft:5}},n.createElement("td",{colSpan:e.props.columnSettings.getVisibleColumnCount(),className:"griddle-parent",style:e.props.useGriddleStyles?{border:"none",padding:"0 0 0 5px"}:null},n.createElement(s,{rowMetadata:{key:"id"},isSubGriddle:!0,results:[t],columns:e.props.columnSettings.getColumns(),tableClassName:e.props.tableClassName,parentRowExpandedClassName:e.props.parentRowExpandedClassName,parentRowCollapsedClassName:e.props.parentRowCollapsedClassName,showTableHeading:!1,showPager:!1,columnMetadata:e.props.columnSettings.columnMetadata,parentRowExpandedComponent:e.props.parentRowExpandedComponent,parentRowCollapsedComponent:e.props.parentRowCollapsedComponent,paddingHeight:e.props.paddingHeight,rowHeight:e.props.rowHeight})))}return n.createElement(e.props.rowSettings.rowComponent,{useGriddleStyles:e.props.useGriddleStyles,isSubGriddle:e.props.isSubGriddle,data:t,columnSettings:e.props.columnSettings,isChildRow:!0,columnMetadata:e.props.columnSettings.columnMetadata,key:r})})),!1===e.props.hasChildren?t[0]:n.createElement("tbody",null,e.state.showChildren?t.concat(s):t)}});e.exports=s},"./node_modules/griddle-react/modules/gridSettings.jsx.js":function(e,t,o){"use strict";var n=o(0),r=o("./node_modules/griddle-react/node_modules/lodash/includes.js"),s=o("./node_modules/griddle-react/node_modules/lodash/without.js"),l=o("./node_modules/griddle-react/node_modules/lodash/find.js"),i=n.createClass({displayName:"GridSettings",getDefaultProps:function(){return{columns:[],columnMetadata:[],selectedColumns:[],settingsText:"",maxRowsText:"",resultsPerPage:0,enableToggleCustom:!1,useCustomComponent:!1,useGriddleStyles:!0,toggleCustomComponent:function(){}}},setPageSize:function(e){var t=parseInt(e.target.value,10);this.props.setPageSize(t)},handleChange:function(e){var t=e.target.dataset?e.target.dataset.name:e.target.getAttribute("data-name");!0===e.target.checked&&!1===r(this.props.selectedColumns,t)?(this.props.selectedColumns.push(t),this.props.setColumns(this.props.selectedColumns)):this.props.setColumns(s(this.props.selectedColumns,t))},render:function(){var e=this,t=[];!1===e.props.useCustomComponent&&(t=this.props.columns.map(function(t,o){var s=r(e.props.selectedColumns,t),i=l(e.props.columnMetadata,{columnName:t}),a=t;return void 0!==i&&void 0!==i.displayName&&null!=i.displayName&&(a=i.displayName),void 0!==i&&null!=i&&i.locked?n.createElement("div",{className:"column checkbox"},n.createElement("label",null,n.createElement("input",{type:"checkbox",disabled:!0,name:"check",checked:s,"data-name":t}),a)):void 0!==i&&null!=i&&void 0!==i.visible&&!1===i.visible?null:n.createElement("div",{className:"griddle-column-selection checkbox",key:t,style:e.props.useGriddleStyles?{float:"left",width:"20%"}:null},n.createElement("label",null,n.createElement("input",{type:"checkbox",name:"check",onChange:e.handleChange,checked:s,"data-name":t}),a))}));var o=e.props.enableToggleCustom?n.createElement("div",{className:"form-group"},n.createElement("label",{htmlFor:"maxRows"},n.createElement("input",{type:"checkbox",checked:this.props.useCustomComponent,onChange:this.props.toggleCustomComponent})," ",this.props.enableCustomFormatText)):"",s=this.props.showSetPageSize?n.createElement("div",null,n.createElement("label",{htmlFor:"maxRows"},this.props.maxRowsText,":",n.createElement("select",{onChange:this.setPageSize,value:this.props.resultsPerPage},n.createElement("option",{value:"5"},"5"),n.createElement("option",{value:"10"},"10"),n.createElement("option",{value:"25"},"25"),n.createElement("option",{value:"50"},"50"),n.createElement("option",{value:"100"},"100")))):"";return n.createElement("div",{className:"griddle-settings",style:this.props.useGriddleStyles?{backgroundColor:"#FFF",border:"1px solid #DDD",color:"#222",padding:"10px",marginBottom:"10px"}:null},n.createElement("h6",null,this.props.settingsText),n.createElement("div",{className:"griddle-columns",style:this.props.useGriddleStyles?{clear:"both",display:"table",width:"100%",borderBottom:"1px solid #EDEDED",marginBottom:"10px"}:null},t),s,o)}});e.exports=i},"./node_modules/griddle-react/modules/gridTable.jsx.js":function(e,t,o){"use strict";var n=o(0),r=o("./node_modules/griddle-react/modules/gridTitle.jsx.js"),s=o("./node_modules/griddle-react/modules/gridRowContainer.jsx.js"),l=(o("./node_modules/griddle-react/modules/columnProperties.js"),o("./node_modules/griddle-react/modules/rowProperties.js"),n.createClass({displayName:"GridTable",getDefaultProps:function(){return{data:[],columnSettings:null,rowSettings:null,sortSettings:null,multipleSelectionSettings:null,className:"",enableInfiniteScroll:!1,nextPage:null,hasMorePages:!1,useFixedHeader:!1,useFixedLayout:!0,paddingHeight:null,rowHeight:null,filterByColumn:null,infiniteScrollLoadTreshold:null,bodyHeight:null,useGriddleStyles:!0,useGriddleIcons:!0,isSubGriddle:!1,parentRowCollapsedClassName:"parent-row",parentRowExpandedClassName:"parent-row expanded",parentRowCollapsedComponent:"â–¶",parentRowExpandedComponent:"â–¼",externalLoadingComponent:null,externalIsLoading:!1,onRowClick:null}},getInitialState:function(){return{scrollTop:0,scrollHeight:this.props.bodyHeight,clientHeight:this.props.bodyHeight}},componentDidMount:function(){this.gridScroll()},componentDidUpdate:function(e,t){this.gridScroll()},gridScroll:function(){if(this.props.enableInfiniteScroll&&!this.props.externalIsLoading){var e=this.refs.scrollable,t=e.scrollTop,o=e.scrollHeight,n=e.clientHeight;if(null!==this.props.rowHeight&&this.state.scrollTop!==t&&Math.abs(this.state.scrollTop-t)>=this.getAdjustedRowHeight()){var r={scrollTop:t,scrollHeight:o,clientHeight:n};this.setState(r)}.6*(o-(t+n)-this.props.infiniteScrollLoadTreshold)<=this.props.infiniteScrollLoadTreshold&&this.props.nextPage()}},verifyProps:function(){null===this.props.columnSettings&&console.error("gridTable: The columnSettings prop is null and it shouldn't be"),null===this.props.rowSettings&&console.error("gridTable: The rowSettings prop is null and it shouldn't be")},getAdjustedRowHeight:function(){return this.props.rowHeight+2*this.props.paddingHeight},getNodeContent:function(){this.verifyProps();var e=this,t=!1;if(!this.props.externalIsLoading||this.props.enableInfiniteScroll){var o=e.props.data,r=null,l=null;if(this.props.enableInfiniteScroll&&null!==this.props.rowHeight&&void 0!==this.refs.scrollable){var i=e.getAdjustedRowHeight(),a=Math.ceil(e.state.clientHeight/i),d=Math.max(0,Math.floor(e.state.scrollTop/i)-.25*a),u=Math.min(d+1.25*a,this.props.data.length-1);o=o.slice(d,u+1);var c={height:d*i+"px"};r=n.createElement("tr",{key:"above-"+c.height,style:c});var p={height:(this.props.data.length-u)*i+"px"};l=n.createElement("tr",{key:"below-"+p.height,style:p})}var f=o.map(function(o,r){var l=void 0!==o.children&&o.children.length>0,i=e.props.rowSettings.getRowKey(o,r);return l&&(t=l),n.createElement(s,{useGriddleStyles:e.props.useGriddleStyles,isSubGriddle:e.props.isSubGriddle,parentRowExpandedClassName:e.props.parentRowExpandedClassName,parentRowCollapsedClassName:e.props.parentRowCollapsedClassName,parentRowExpandedComponent:e.props.parentRowExpandedComponent,parentRowCollapsedComponent:e.props.parentRowCollapsedComponent,data:o,key:i+"-container",uniqueId:i,columnSettings:e.props.columnSettings,rowSettings:e.props.rowSettings,paddingHeight:e.props.paddingHeight,multipleSelectionSettings:e.props.multipleSelectionSettings,rowHeight:e.props.rowHeight,hasChildren:l,tableClassName:e.props.className,onRowClick:e.props.onRowClick})});if(this.props.showNoData){var h=this.props.columnSettings.getVisibleColumnCount();f.push(n.createElement("tr",{key:"no-data-section"},n.createElement("td",{colSpan:h},this.props.noDataSection)))}return r&&f.unshift(r),l&&f.push(l),{nodes:f,anyHasChildren:t}}return null},render:function(){var e=[],t=!1,o=this.getNodeContent();o&&(e=o.nodes,t=o.anyHasChildren);var s=null,l=null,i={width:"100%"};if(this.props.useFixedLayout&&(i.tableLayout="fixed"),this.props.enableInfiniteScroll&&(s={position:"relative",overflowY:"scroll",height:this.props.bodyHeight+"px",width:"100%"}),this.props.externalIsLoading){var a=null,d=null;this.props.useGriddleStyles&&(a={textAlign:"center",paddingBottom:"40px"}),d=this.props.columnSettings.getVisibleColumnCount();var u=this.props.externalLoadingComponent?n.createElement(this.props.externalLoadingComponent,null):n.createElement("div",null,"Loading...");l=n.createElement("tbody",null,n.createElement("tr",null,n.createElement("td",{style:a,colSpan:d},u)))}var c=this.props.showTableHeading?n.createElement(r,{useGriddleStyles:this.props.useGriddleStyles,useGriddleIcons:this.props.useGriddleIcons,sortSettings:this.props.sortSettings,multipleSelectionSettings:this.props.multipleSelectionSettings,columnSettings:this.props.columnSettings,filterByColumn:this.props.filterByColumn,rowSettings:this.props.rowSettings}):void 0;t||(e=n.createElement("tbody",null,e));var p=n.createElement("tbody",null);if(this.props.showPager){var f=this.props.useGriddleStyles?{padding:"0px",backgroundColor:"#EDEDED",border:"0px",color:"#222",height:this.props.showNoData?"20px":null}:null;p=n.createElement("tbody",null,n.createElement("tr",null,n.createElement("td",{colSpan:this.props.multipleSelectionSettings.isMultipleSelection?this.props.columnSettings.getVisibleColumnCount()+1:this.props.columnSettings.getVisibleColumnCount(),style:f,className:"footer-container"},this.props.showNoData?null:this.props.pagingContent)))}return this.props.useFixedHeader?(this.props.useGriddleStyles&&(i.tableLayout="fixed"),n.createElement("div",null,n.createElement("table",{className:this.props.className,style:this.props.useGriddleStyles&&i||null},c),n.createElement("div",{ref:"scrollable",onScroll:this.gridScroll,style:s},n.createElement("table",{className:this.props.className,style:this.props.useGriddleStyles&&i||null},e,l,p)))):n.createElement("div",{ref:"scrollable",onScroll:this.gridScroll,style:s},n.createElement("table",{className:this.props.className,style:this.props.useGriddleStyles&&i||null},c,e,l,p))}}));e.exports=l},"./node_modules/griddle-react/modules/gridTitle.jsx.js":function(e,t,o){"use strict";var n=Object.assign||function(e){for(var t=1;t=0)return!0;return!1})},defaultColumnFilter:function(e,t){return A(g.getObjectValues(e),function(e){return e.toString().toLowerCase().indexOf(t.toLowerCase())>=0}).length>0},filterByColumnFilters:function(e){var t=this.defaultColumnFilter,o=Object.keys(e).reduce(function(o,n){return A(o,function(o){var r=g.getAt(o,n||""),s=e[n];return t(r,s)})},this.props.results),n={columnFilters:e};e?(n.filteredResults=o,n.maxPage=this.getMaxPage(n.filteredResults)):this.state.filter?n.filteredResults=this.props.useCustomFilterer?this.props.customFilterer(this.props.results,filter):this.defaultFilter(this.props.results,filter):n.filteredResults=null,this.setState(n)},filterByColumn:function(e,t){var o=this.state.columnFilters;if(o.hasOwnProperty(t)&&!e)o=F(o,t);else{var n={};n[t]=e,o=x({},o,n)}this.filterByColumnFilters(o)},setFilter:function(e){if(this.props.useExternal)return void this.props.externalSetFilter(e);var t=this,o={page:0,filter:e};o.filteredResults=this.props.useCustomFilterer?this.props.customFilterer(this.props.results,e):this.defaultFilter(this.props.results,e),o.maxPage=t.getMaxPage(o.filteredResults),(O(e)||T(e)||w(e))&&(o.filter=e,o.filteredResults=null),t.setState(o),this._resetSelectedRows()},setPageSize:function(e){if(this.props.useExternal)return this.setState({resultsPerPage:e}),void this.props.externalSetPageSize(e);this.state.resultsPerPage=e,this.setMaxPage()},toggleColumnChooser:function(){this.setState({showColumnChooser:!this.state.showColumnChooser})},isNullOrUndefined:function(e){return void 0===e||null===e},shouldUseCustomRowComponent:function(){return this.isNullOrUndefined(this.state.useCustomRowComponent)?this.props.useCustomRowComponent:this.state.useCustomRowComponent},shouldUseCustomGridComponent:function(){return this.isNullOrUndefined(this.state.useCustomGridComponent)?this.props.useCustomGridComponent:this.state.useCustomGridComponent},toggleCustomComponent:function(){"grid"===this.state.customComponentType?this.setState({useCustomGridComponent:!this.shouldUseCustomGridComponent()}):"row"===this.state.customComponentType&&this.setState({useCustomRowComponent:!this.shouldUseCustomRowComponent()})},getMaxPage:function(e,t){return this.props.useExternal?this.props.externalMaxPage:(t||(t=(e||this.getCurrentResults()).length),Math.ceil(t/this.state.resultsPerPage))},setMaxPage:function(e){var t=this.getMaxPage(e);this.state.maxPage!==t&&this.setState({page:0,maxPage:t,filteredColumns:this.columnSettings.filteredColumns})},setPage:function(e){if(this.props.useExternal)return void this.props.externalSetPage(e);if(e*this.state.resultsPerPage<=this.state.resultsPerPage*this.state.maxPage){var t=this,o={page:e};t.setState(o)}this.props.enableInfiniteScroll&&this.setState({isSelectAllChecked:!1})},setColumns:function(e){this.columnSettings.filteredColumns=P(e)?e:[e],this.setState({filteredColumns:this.columnSettings.filteredColumns})},nextPage:function(){var e=this.getCurrentPage();e0&&this.setPage(e-1)},changeSort:function(e){if(!1!==this.props.enableSort){if(this.props.useExternal){var t=this.props.externalSortColumn!==e||!this.props.externalSortAscending;return this.setState({sortColumn:e,sortDirection:t?"asc":"desc"}),void this.props.externalChangeSort(e,t)}var o=b(this.props.columnMetadata,{columnName:e})||{},n=o.sortDirectionCycle?o.sortDirectionCycle:[null,"asc","desc"],r=null,s=n.indexOf(this.state.sortDirection&&e===this.state.sortColumn?this.state.sortDirection:null);s=(s+1)%n.length,r=n[s]?n[s]:null;var l={page:0,sortColumn:e,sortDirection:r};this.setState(l)}},componentWillReceiveProps:function(e){if(this.setMaxPage(e.results),e.resultsPerPage!==this.props.resultsPerPage&&this.setPageSize(e.resultsPerPage),this.columnSettings.columnMetadata=e.columnMetadata,e.results.length>0){var t=g.keys(e.results[0]);this.columnSettings.allColumns.length==t.length&&this.columnSettings.allColumns.every(function(e,o){return e===t[o]})||(this.columnSettings.allColumns=t)}else this.columnSettings.allColumns.length>0&&(this.columnSettings.allColumns=[]);if(e.selectedRowIds){var o=this.getDataForRender(this.getCurrentResults(e.results),this.columnSettings.getColumns(),!0);this.setState({isSelectAllChecked:this._getAreAllRowsChecked(e.selectedRowIds,I(o,this.props.uniqueIdentifier)),selectedRowIds:e.selectedRowIds})}},getInitialState:function(){return{maxPage:0,page:0,filteredResults:null,filteredColumns:[],filter:"",columnFilters:{},resultsPerPage:this.props.resultsPerPage||5,showColumnChooser:!1,isSelectAllChecked:!1,selectedRowIds:this.props.selectedRowIds}},componentWillMount:function(){this.verifyExternal(),this.verifyCustom(),this.columnSettings=new m(this.props.results.length>0?g.keys(this.props.results[0]):[],this.props.columns,this.props.childrenColumnName,this.props.columnMetadata,this.props.metadataColumns),this.rowSettings=new _(this.props.rowMetadata,this.props.useCustomTableRowComponent&&this.props.customTableRowComponent?this.props.customTableRowComponent:u,this.props.useCustomTableRowComponent),this.props.initialSort&&(this.props.useExternal?this.setState({sortColumn:this.props.externalSortColumn,sortDirection:this.props.externalSortAscending?"asc":"desc"}):this.changeSort(this.props.initialSort)),this.setMaxPage(),this.shouldUseCustomGridComponent()?this.setState({customComponentType:"grid"}):this.shouldUseCustomRowComponent()?this.setState({customComponentType:"row"}):this.setState({filteredColumns:this.columnSettings.filteredColumns})},componentDidMount:function(){if(this.props.componentDidMount&&"function"==typeof this.props.componentDidMount)return this.props.componentDidMount()},componentDidUpdate:function(){if(this.props.componentDidUpdate&&"function"==typeof this.props.componentDidUpdate)return this.props.componentDidUpdate(this.state)},verifyExternal:function(){!0===this.props.useExternal&&(null===this.props.externalSetPage&&console.error("useExternal is set to true but there is no externalSetPage function specified."),null===this.props.externalChangeSort&&console.error("useExternal is set to true but there is no externalChangeSort function specified."),null===this.props.externalSetFilter&&console.error("useExternal is set to true but there is no externalSetFilter function specified."),null===this.props.externalSetPageSize&&console.error("useExternal is set to true but there is no externalSetPageSize function specified."),null===this.props.externalMaxPage&&console.error("useExternal is set to true but externalMaxPage is not set."),null===this.props.externalCurrentPage&&console.error("useExternal is set to true but externalCurrentPage is not set. Griddle will not page correctly without that property when using external data."))},verifyCustom:function(){!0===this.props.useCustomGridComponent&&null===this.props.customGridComponent&&console.error("useCustomGridComponent is set to true but no custom component was specified."),!0===this.props.useCustomRowComponent&&null===this.props.customRowComponent&&console.error("useCustomRowComponent is set to true but no custom component was specified."),!0===this.props.useCustomGridComponent&&!0===this.props.useCustomRowComponent&&console.error("Cannot currently use both customGridComponent and customRowComponent."),!0===this.props.useCustomFilterer&&null===this.props.customFilterer&&console.error("useCustomFilterer is set to true but no custom filter function was specified."),!0===this.props.useCustomFilterComponent&&null===this.props.customFilterComponent&&console.error("useCustomFilterComponent is set to true but no customFilterComponent was specified.")},getDataForRender:function(e,t,o){var n=this,r=this;if(""!==this.state.sortColumn){var s,l=this.state.sortColumn,i=A(this.props.columnMetadata,{columnName:l}),a={columns:[],orders:[]};if(i.length>0&&(s=i[0].hasOwnProperty("customCompareFn")&&i[0].customCompareFn,i[0].multiSort&&(a=i[0].multiSort)),this.state.sortDirection)if("function"==typeof s)2===s.length?(e=e.sort(function(e,t){return s(k(e,l),k(t,l))}),"desc"===this.state.sortDirection&&e.reverse()):1===s.length&&(e=D(e,function(e){return s(k(e,l))},[this.state.sortDirection]));else{var d=[function(e){return(k(e,l)||"").toString().toLowerCase()}],u=[this.state.sortDirection];a.columns.forEach(function(e,t){d.push(function(t){return(k(t,e)||"").toString().toLowerCase()}),"asc"===a.orders[t]||"desc"===a.orders[t]?u.push(a.orders[t]):u.push(n.state.sortDirection)}),e=D(e,d,u)}}var c=this.getCurrentPage();if(!this.props.useExternal&&o&&this.state.resultsPerPage*(c+1)<=this.state.resultsPerPage*this.state.maxPage&&c>=0)if(this.isInfiniteScrollEnabled())e=E(e,(c+1)*this.state.resultsPerPage);else{var p=y(e,c*this.state.resultsPerPage);e=(v||S)(p,p.length-this.state.resultsPerPage)}for(var f=(this.columnSettings.getMetadataColumns,[]),h=0;h0&&(m.children=r.getDataForRender(m[r.props.childrenColumnName],t,!1),"children"!==r.props.childrenColumnName&&delete m[r.props.childrenColumnName]),f.push(m)}return f},getCurrentResults:function(e){return this.state.filteredResults||e||this.props.results},getCurrentPage:function(){return this.props.externalCurrentPage||this.state.page},getCurrentSort:function(){return this.props.useExternal?this.props.externalSortColumn:this.state.sortColumn},getCurrentSortAscending:function(){return this.props.useExternal?this.props.externalSortAscending:"asc"===this.state.sortDirection},getCurrentMaxPage:function(){return this.props.useExternal?this.props.externalMaxPage:this.state.maxPage},getSortObject:function(){return{enableSort:this.props.enableSort,changeSort:this.changeSort,sortColumn:this.getCurrentSort(),sortAscending:this.getCurrentSortAscending(),sortDirection:this.state.sortDirection,sortAscendingClassName:this.props.sortAscendingClassName,sortDescendingClassName:this.props.sortDescendingClassName,sortAscendingComponent:this.props.sortAscendingComponent,sortDescendingComponent:this.props.sortDescendingComponent,sortDefaultComponent:this.props.sortDefaultComponent}},_toggleSelectAll:function(){var e=this.getDataForRender(this.getCurrentResults(),this.columnSettings.getColumns(),!0),t=!this.state.isSelectAllChecked,o=JSON.parse(JSON.stringify(this.state.selectedRowIds)),n=this;j(e,function(e){n._updateSelectedRowIds(e[n.props.uniqueIdentifier],o,t)},this),this.setState({isSelectAllChecked:t,selectedRowIds:o}),this.props.onSelectionChange&&this.props.onSelectionChange(o,t)},_toggleSelectRow:function(e,t){var o=this.getDataForRender(this.getCurrentResults(),this.columnSettings.getColumns(),!0),n=JSON.parse(JSON.stringify(this.state.selectedRowIds));this._updateSelectedRowIds(e[this.props.uniqueIdentifier],n,t);var r=this._getAreAllRowsChecked(n,I(o,this.props.uniqueIdentifier));this.setState({isSelectAllChecked:r,selectedRowIds:n}),this.props.onSelectionChange&&this.props.onSelectionChange(n,r)},_updateSelectedRowIds:function(e,t,o){o?void 0===b(t,function(t){return e===t})&&t.push(e):t.splice(t.indexOf(e),1)},_getIsSelectAllChecked:function(){return this.state.isSelectAllChecked},_getAreAllRowsChecked:function(e,t){return t.length===C(t,e).length},_getIsRowChecked:function(e){return this.state.selectedRowIds.indexOf(e[this.props.uniqueIdentifier])>-1},getSelectedRowIds:function(){return this.state.selectedRowIds},_resetSelectedRows:function(){this.setState({isSelectAllChecked:!1,selectedRowIds:[]})},getMultipleSelectionObject:function(){return{isMultipleSelection:!b(this.props.results,function(e){return"children"in e})&&this.props.isMultipleSelection,toggleSelectAll:this._toggleSelectAll,getIsSelectAllChecked:this._getIsSelectAllChecked,toggleSelectRow:this._toggleSelectRow,getSelectedRowIds:this.getSelectedRowIds,getIsRowChecked:this._getIsRowChecked}},isInfiniteScrollEnabled:function(){return!this.props.useCustomPagerComponent&&this.props.enableInfiniteScroll},getClearFixStyles:function(){return{clear:"both",display:"table",width:"100%"}},getSettingsStyles:function(){return{float:"left",width:"50%",textAlign:"right"}},getFilterStyles:function(){return{float:"left",width:"50%",textAlign:"left",color:"#222",minHeight:"1px"}},getFilter:function(){return this.props.showFilter&&!1===this.shouldUseCustomGridComponent()?this.props.useCustomFilterComponent?r.createElement(h,{changeFilter:this.setFilter,placeholderText:this.props.filterPlaceholderText,customFilterComponent:this.props.customFilterComponent,results:this.props.results,currentResults:this.getCurrentResults()}):r.createElement(l,{changeFilter:this.setFilter,placeholderText:this.props.filterPlaceholderText}):""},getSettings:function(){return this.props.showSettings?r.createElement("button",{type:"button",className:this.props.settingsToggleClassName,onClick:this.toggleColumnChooser,style:this.props.useGriddleStyles?{background:"none",border:"none",padding:0,margin:0,fontSize:14}:null},this.props.settingsText,this.props.settingsIconComponent):""},getTopSection:function(e,t){if(!1===this.props.showFilter&&!1===this.props.showSettings)return"";var o=null,n=null,s=null;return this.props.useGriddleStyles&&(o=this.getFilterStyles(),n=this.getSettingsStyles(),s=this.getClearFixStyles()),r.createElement("div",{className:"top-section",style:s},r.createElement("div",{className:"griddle-filter",style:o},e),r.createElement("div",{className:"griddle-settings-toggle",style:n},t))},getPagingSection:function(e,t){if(!1!==(this.props.showPager&&!this.isInfiniteScrollEnabled()&&!this.shouldUseCustomGridComponent()))return r.createElement("div",{className:"griddle-footer"},this.props.useCustomPagerComponent?r.createElement(f,{customPagerComponentOptions:this.props.customPagerComponentOptions,next:this.nextPage,previous:this.previousPage,currentPage:e,maxPage:t,setPage:this.setPage,nextText:this.props.nextText,previousText:this.props.previousText,customPagerComponent:this.props.customPagerComponent}):r.createElement(i,{useGriddleStyles:this.props.useGriddleStyles,next:this.nextPage,previous:this.previousPage,nextClassName:this.props.nextClassName,nextIconComponent:this.props.nextIconComponent,previousClassName:this.props.previousClassName,previousIconComponent:this.props.previousIconComponent,currentPage:e,maxPage:t,setPage:this.setPage,nextText:this.props.nextText,previousText:this.props.previousText}))},getColumnSelectorSection:function(e,t){return this.state.showColumnChooser?r.createElement(a,{columns:e,selectedColumns:t,setColumns:this.setColumns,settingsText:this.props.settingsText,settingsIconComponent:this.props.settingsIconComponent,maxRowsText:this.props.maxRowsText,setPageSize:this.setPageSize,showSetPageSize:!this.shouldUseCustomGridComponent(),resultsPerPage:this.state.resultsPerPage,enableToggleCustom:this.props.enableToggleCustom,toggleCustomComponent:this.toggleCustomComponent,useCustomComponent:this.shouldUseCustomRowComponent()||this.shouldUseCustomGridComponent(),useGriddleStyles:this.props.useGriddleStyles,enableCustomFormatText:this.props.enableCustomFormatText,columnMetadata:this.props.columnMetadata}):""},getCustomGridSection:function(){return r.createElement(this.props.customGridComponent,n({data:this.props.results,className:this.props.customGridComponentClassName},this.props.gridMetadata))},getCustomRowSection:function(e,t,o,n,s){return r.createElement("div",null,r.createElement(p,{data:e,columns:t,metadataColumns:o,globalData:s,className:this.props.customRowComponentClassName,customComponent:this.props.customRowComponent,style:this.props.useGriddleStyles?this.getClearFixStyles():null}),this.props.showPager&&n)},getStandardGridSection:function(e,t,o,n,l){var i=this.getSortObject(),a=this.getMultipleSelectionObject(),d=this.shouldShowNoDataSection(e),u=this.getNoDataSection();return r.createElement("div",{className:"griddle-body"},r.createElement(s,{useGriddleStyles:this.props.useGriddleStyles,noDataSection:u,showNoData:d,columnSettings:this.columnSettings,rowSettings:this.rowSettings,sortSettings:i,multipleSelectionSettings:a,filterByColumn:this.filterByColumn,isSubGriddle:this.props.isSubGriddle,useGriddleIcons:this.props.useGriddleIcons,useFixedLayout:this.props.useFixedLayout,showPager:this.props.showPager,pagingContent:n,data:e,className:this.props.tableClassName,enableInfiniteScroll:this.isInfiniteScrollEnabled(),nextPage:this.nextPage,showTableHeading:this.props.showTableHeading,useFixedHeader:this.props.useFixedHeader,parentRowCollapsedClassName:this.props.parentRowCollapsedClassName,parentRowExpandedClassName:this.props.parentRowExpandedClassName,parentRowCollapsedComponent:this.props.parentRowCollapsedComponent,parentRowExpandedComponent:this.props.parentRowExpandedComponent,bodyHeight:this.props.bodyHeight,paddingHeight:this.props.paddingHeight,rowHeight:this.props.rowHeight,infiniteScrollLoadTreshold:this.props.infiniteScrollLoadTreshold,externalLoadingComponent:this.props.externalLoadingComponent,externalIsLoading:this.props.externalIsLoading,hasMorePages:l,onRowClick:this.props.onRowClick}))},getContentSection:function(e,t,o,n,r,s){return this.shouldUseCustomGridComponent()&&null!==this.props.customGridComponent?this.getCustomGridSection():this.shouldUseCustomRowComponent()?this.getCustomRowSection(e,t,o,n,s):this.getStandardGridSection(e,t,o,n,r)},getNoDataSection:function(){return null!=this.props.customNoDataComponent?r.createElement("div",{className:this.props.noDataClassName},r.createElement(this.props.customNoDataComponent,this.props.customNoDataComponentProps)):r.createElement(d,{noDataMessage:this.props.noDataMessage})},shouldShowNoDataSection:function(e){return!this.props.allowEmptyGrid&&(!1===this.props.useExternal&&(void 0===e||0===e.length)||!0===this.props.useExternal&&!1===this.props.externalIsLoading&&0===e.length)},render:function(){var e=this.getCurrentResults(),t=(this.props.tableClassName,this.getFilter()),o=this.getSettings(),n=this.getTopSection(t,o),s=[],l=this.columnSettings.getColumns(),i=this.getDataForRender(e,l,!0),a=this.columnSettings.getMetadataColumns();this.props.columnMetadata?j(this.props.columnMetadata,function(e){"boolean"==typeof e.visible&&!1===e.visible||s.push(e.columnName)}):s=g.keys(F(e[0],a)),s=this.columnSettings.orderColumns(s);var d=this.getCurrentPage(),u=this.getCurrentMaxPage(),c=d+10?"griddle "+this.props.gridClassName:"griddle";return m+=this.shouldUseCustomRowComponent()?" griddle-custom":"",r.createElement("div",{className:m},n,h,r.createElement("div",{className:"griddle-container",style:this.props.useGriddleStyles&&!this.props.isSubGriddle?{border:"1px solid #DDD"}:null},f))}});c.Griddle=e.exports=N},"./node_modules/griddle-react/modules/rowProperties.js":function(e,t,o){"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}var r=function(){function e(e,t){for(var o=0;o-1}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseIndexOf.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_arrayIncludesWith.js":function(e,t){function o(e,t,o){for(var n=-1,r=null==e?0:e.length;++n=u&&(p=d,f=!1,t=new r(t));e:for(;++c0&&o(u)?t>1?n(u,t-1,o,l,i):r(i,u):l||(i[i.length]=u)}return i}var r=o("./node_modules/griddle-react/node_modules/lodash/_arrayPush.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_isFlattenable.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_baseFor.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_createBaseFor.js"),r=n();e.exports=r},"./node_modules/griddle-react/node_modules/lodash/_baseForOwn.js":function(e,t,o){function n(e,t){return e&&r(e,t,s)}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseFor.js"),s=o("./node_modules/griddle-react/node_modules/lodash/keys.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_baseGet.js":function(e,t,o){function n(e,t){t=r(t,e);for(var o=0,n=t.length;null!=e&&o=120&&g.length>=120)?new r(f&&g):void 0}g=e[0];var y=-1,v=h[0];e:for(;++yr?0:r+t),o=o>r?r:o,o<0&&(o+=r),r=t>o?0:o-t>>>0,t>>>=0;for(var s=Array(r);++nt||l&&i&&d&&!a&&!u||n&&i&&d||!o&&d||!s)return 1;if(!n&&!l&&!u&&e=a?d:d*("desc"==o[n]?-1:1)}return e.index-t.index}var r=o("./node_modules/griddle-react/node_modules/lodash/_compareAscending.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_copyArray.js":function(e,t){function o(e,t){var o=-1,n=e.length;for(t||(t=Array(n));++o1?o[r-1]:void 0,i=r>2?o[2]:void 0;for(l=e.length>3&&"function"==typeof l?(r--,l):void 0,i&&s(o[0],o[1],i)&&(l=r<3?void 0:l,r=1),t=Object(t);++n-1?i[a?t[d]:d]:void 0}}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseIteratee.js"),s=o("./node_modules/griddle-react/node_modules/lodash/isArrayLike.js"),l=o("./node_modules/griddle-react/node_modules/lodash/keys.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_createToPairs.js":function(e,t,o){function n(e){return function(t){var o=s(t);return o==a?l(t):o==d?i(t):r(t,e(t))}}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseToPairs.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_getTag.js"),l=o("./node_modules/griddle-react/node_modules/lodash/_mapToArray.js"),i=o("./node_modules/griddle-react/node_modules/lodash/_setToPairs.js"),a="[object Map]",d="[object Set]";e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_customDefaultsAssignIn.js":function(e,t,o){function n(e,t,o,n){return void 0===e||r(e,s[o])&&!l.call(n,o)?t:e}var r=o("./node_modules/griddle-react/node_modules/lodash/eq.js"),s=Object.prototype,l=s.hasOwnProperty;e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_customOmitClone.js":function(e,t,o){function n(e){return r(e)?void 0:e}var r=o("./node_modules/griddle-react/node_modules/lodash/isPlainObject.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_defineProperty.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_getNative.js"),r=function(){try{var e=n(Object,"defineProperty");return e({},"",{}),e}catch(e){}}();e.exports=r},"./node_modules/griddle-react/node_modules/lodash/_equalArrays.js":function(e,t,o){function n(e,t,o,n,d,u){var c=o&i,p=e.length,f=t.length;if(p!=f&&!(c&&f>p))return!1;var h=u.get(e);if(h&&u.get(t))return h==t;var m=-1,_=!0,g=o&a?new r:void 0;for(u.set(e,t),u.set(t,e);++m-1&&e%1==0&&e-1}var r=o("./node_modules/griddle-react/node_modules/lodash/_assocIndexOf.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_listCacheSet.js":function(e,t,o){function n(e,t){var o=this.__data__,n=r(o,e);return n<0?(++this.size,o.push([e,t])):o[n][1]=t,this}var r=o("./node_modules/griddle-react/node_modules/lodash/_assocIndexOf.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_mapCacheClear.js":function(e,t,o){function n(){this.size=0,this.__data__={hash:new r,map:new(l||s),string:new r}}var r=o("./node_modules/griddle-react/node_modules/lodash/_Hash.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_ListCache.js"),l=o("./node_modules/griddle-react/node_modules/lodash/_Map.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_mapCacheDelete.js":function(e,t,o){function n(e){var t=r(this,e).delete(e);return this.size-=t?1:0,t}var r=o("./node_modules/griddle-react/node_modules/lodash/_getMapData.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_mapCacheGet.js":function(e,t,o){function n(e){return r(this,e).get(e)}var r=o("./node_modules/griddle-react/node_modules/lodash/_getMapData.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_mapCacheHas.js":function(e,t,o){function n(e){return r(this,e).has(e)}var r=o("./node_modules/griddle-react/node_modules/lodash/_getMapData.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_mapCacheSet.js":function(e,t,o){function n(e,t){var o=r(this,e),n=o.size;return o.set(e,t),this.size+=o.size==n?0:1,this}var r=o("./node_modules/griddle-react/node_modules/lodash/_getMapData.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_mapToArray.js":function(e,t){function o(e){var t=-1,o=Array(e.size);return e.forEach(function(e,n){o[++t]=[n,e]}),o}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/_matchesStrictComparable.js":function(e,t){function o(e,t){return function(o){return null!=o&&o[e]===t&&(void 0!==t||e in Object(o))}}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/_memoizeCapped.js":function(e,t,o){function n(e){var t=r(e,function(e){return o.size===s&&o.clear(),e}),o=t.cache;return t}var r=o("./node_modules/griddle-react/node_modules/lodash/memoize.js"),s=500;e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_nativeCreate.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_getNative.js"),r=n(Object,"create");e.exports=r},"./node_modules/griddle-react/node_modules/lodash/_nativeKeys.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_overArg.js"),r=n(Object.keys,Object);e.exports=r},"./node_modules/griddle-react/node_modules/lodash/_nativeKeysIn.js":function(e,t){function o(e){var t=[];if(null!=e)for(var o in Object(e))t.push(o);return t}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/_nodeUtil.js":function(e,t,o){(function(e){var n=o("./node_modules/griddle-react/node_modules/lodash/_freeGlobal.js"),r="object"==typeof t&&t&&!t.nodeType&&t,s=r&&"object"==typeof e&&e&&!e.nodeType&&e,l=s&&s.exports===r,i=l&&n.process,a=function(){try{return i&&i.binding&&i.binding("util")}catch(e){}}();e.exports=a}).call(t,o("./node_modules/webpack/buildin/module.js")(e))},"./node_modules/griddle-react/node_modules/lodash/_objectToString.js":function(e,t){function o(e){return r.call(e)}var n=Object.prototype,r=n.toString;e.exports=o},"./node_modules/griddle-react/node_modules/lodash/_overArg.js":function(e,t){function o(e,t){return function(o){return e(t(o))}}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/_overRest.js":function(e,t,o){function n(e,t,o){return t=s(void 0===t?e.length-1:t,0),function(){for(var n=arguments,l=-1,i=s(n.length-t,0),a=Array(i);++l0){if(++t>=n)return arguments[0]}else t=0;return e.apply(void 0,arguments)}}var n=800,r=16,s=Date.now;e.exports=o},"./node_modules/griddle-react/node_modules/lodash/_stackClear.js":function(e,t,o){function n(){this.__data__=new r,this.size=0}var r=o("./node_modules/griddle-react/node_modules/lodash/_ListCache.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/_stackDelete.js":function(e,t){function o(e){var t=this.__data__,o=t.delete(e);return this.size=t.size,o}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/_stackGet.js":function(e,t){function o(e){return this.__data__.get(e)}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/_stackHas.js":function(e,t){function o(e){return this.__data__.has(e)}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/_stackSet.js":function(e,t,o){function n(e,t){var o=this.__data__;if(o instanceof r){var n=o.__data__;if(!s||n.length-1:!!u&&r(e,t,o)>-1}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseIndexOf.js"),s=o("./node_modules/griddle-react/node_modules/lodash/isArrayLike.js"),l=o("./node_modules/griddle-react/node_modules/lodash/isString.js"),i=o("./node_modules/griddle-react/node_modules/lodash/toInteger.js"),a=o("./node_modules/griddle-react/node_modules/lodash/values.js"),d=Math.max;e.exports=n},"./node_modules/griddle-react/node_modules/lodash/initial.js":function(e,t,o){function n(e){return(null==e?0:e.length)?r(e,0,-1):[]}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseSlice.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/intersection.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_arrayMap.js"),r=o("./node_modules/griddle-react/node_modules/lodash/_baseIntersection.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_baseRest.js"),l=o("./node_modules/griddle-react/node_modules/lodash/_castArrayLikeObject.js"),i=s(function(e){var t=n(e,l);return t.length&&t[0]===e[0]?r(t):[]});e.exports=i},"./node_modules/griddle-react/node_modules/lodash/isArguments.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_baseIsArguments.js"),r=o("./node_modules/griddle-react/node_modules/lodash/isObjectLike.js"),s=Object.prototype,l=s.hasOwnProperty,i=s.propertyIsEnumerable,a=n(function(){return arguments}())?n:function(e){return r(e)&&l.call(e,"callee")&&!i.call(e,"callee")};e.exports=a},"./node_modules/griddle-react/node_modules/lodash/isArray.js":function(e,t){var o=Array.isArray;e.exports=o},"./node_modules/griddle-react/node_modules/lodash/isArrayLike.js":function(e,t,o){function n(e){return null!=e&&s(e.length)&&!r(e)}var r=o("./node_modules/griddle-react/node_modules/lodash/isFunction.js"),s=o("./node_modules/griddle-react/node_modules/lodash/isLength.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/isArrayLikeObject.js":function(e,t,o){function n(e){return s(e)&&r(e)}var r=o("./node_modules/griddle-react/node_modules/lodash/isArrayLike.js"),s=o("./node_modules/griddle-react/node_modules/lodash/isObjectLike.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/isBuffer.js":function(e,t,o){(function(e){var n=o("./node_modules/griddle-react/node_modules/lodash/_root.js"),r=o("./node_modules/griddle-react/node_modules/lodash/stubFalse.js"),s="object"==typeof t&&t&&!t.nodeType&&t,l=s&&"object"==typeof e&&e&&!e.nodeType&&e,i=l&&l.exports===s,a=i?n.Buffer:void 0,d=a?a.isBuffer:void 0,u=d||r;e.exports=u}).call(t,o("./node_modules/webpack/buildin/module.js")(e))},"./node_modules/griddle-react/node_modules/lodash/isEmpty.js":function(e,t,o){function n(e){if(null==e)return!0;if(a(e)&&(i(e)||"string"==typeof e||"function"==typeof e.splice||d(e)||c(e)||l(e)))return!e.length;var t=s(e);if(t==p||t==f)return!e.size;if(u(e))return!r(e).length;for(var o in e)if(m.call(e,o))return!1;return!0}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseKeys.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_getTag.js"),l=o("./node_modules/griddle-react/node_modules/lodash/isArguments.js"),i=o("./node_modules/griddle-react/node_modules/lodash/isArray.js"),a=o("./node_modules/griddle-react/node_modules/lodash/isArrayLike.js"),d=o("./node_modules/griddle-react/node_modules/lodash/isBuffer.js"),u=o("./node_modules/griddle-react/node_modules/lodash/_isPrototype.js"),c=o("./node_modules/griddle-react/node_modules/lodash/isTypedArray.js"),p="[object Map]",f="[object Set]",h=Object.prototype,m=h.hasOwnProperty;e.exports=n},"./node_modules/griddle-react/node_modules/lodash/isFunction.js":function(e,t,o){function n(e){if(!s(e))return!1;var t=r(e);return t==i||t==a||t==l||t==d}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"),s=o("./node_modules/griddle-react/node_modules/lodash/isObject.js"),l="[object AsyncFunction]",i="[object Function]",a="[object GeneratorFunction]",d="[object Proxy]";e.exports=n},"./node_modules/griddle-react/node_modules/lodash/isLength.js":function(e,t){function o(e){return"number"==typeof e&&e>-1&&e%1==0&&e<=n}var n=9007199254740991;e.exports=o},"./node_modules/griddle-react/node_modules/lodash/isNull.js":function(e,t){function o(e){return null===e}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/isObject.js":function(e,t){function o(e){var t=typeof e;return null!=e&&("object"==t||"function"==t)}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/isObjectLike.js":function(e,t){function o(e){return null!=e&&"object"==typeof e}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/isPlainObject.js":function(e,t,o){function n(e){if(!l(e)||r(e)!=i)return!1;var t=s(e);if(null===t)return!0;var o=c.call(t,"constructor")&&t.constructor;return"function"==typeof o&&o instanceof o&&u.call(o)==p}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_getPrototype.js"),l=o("./node_modules/griddle-react/node_modules/lodash/isObjectLike.js"),i="[object Object]",a=Function.prototype,d=Object.prototype,u=a.toString,c=d.hasOwnProperty,p=u.call(Object);e.exports=n},"./node_modules/griddle-react/node_modules/lodash/isString.js":function(e,t,o){function n(e){return"string"==typeof e||!s(e)&&l(e)&&r(e)==i}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"),s=o("./node_modules/griddle-react/node_modules/lodash/isArray.js"),l=o("./node_modules/griddle-react/node_modules/lodash/isObjectLike.js"),i="[object String]";e.exports=n},"./node_modules/griddle-react/node_modules/lodash/isSymbol.js":function(e,t,o){function n(e){return"symbol"==typeof e||s(e)&&r(e)==l}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"),s=o("./node_modules/griddle-react/node_modules/lodash/isObjectLike.js"),l="[object Symbol]";e.exports=n},"./node_modules/griddle-react/node_modules/lodash/isTypedArray.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_baseIsTypedArray.js"),r=o("./node_modules/griddle-react/node_modules/lodash/_baseUnary.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_nodeUtil.js"),l=s&&s.isTypedArray,i=l?r(l):n;e.exports=i},"./node_modules/griddle-react/node_modules/lodash/isUndefined.js":function(e,t){function o(e){return void 0===e}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/keys.js":function(e,t,o){function n(e){return l(e)?r(e):s(e)}var r=o("./node_modules/griddle-react/node_modules/lodash/_arrayLikeKeys.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_baseKeys.js"),l=o("./node_modules/griddle-react/node_modules/lodash/isArrayLike.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/keysIn.js":function(e,t,o){function n(e){return l(e)?r(e,!0):s(e)}var r=o("./node_modules/griddle-react/node_modules/lodash/_arrayLikeKeys.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_baseKeysIn.js"),l=o("./node_modules/griddle-react/node_modules/lodash/isArrayLike.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/last.js":function(e,t){function o(e){var t=null==e?0:e.length;return t?e[t-1]:void 0}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/map.js":function(e,t,o){function n(e,t){return(i(e)?r:l)(e,s(t,3))}var r=o("./node_modules/griddle-react/node_modules/lodash/_arrayMap.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_baseIteratee.js"),l=o("./node_modules/griddle-react/node_modules/lodash/_baseMap.js"),i=o("./node_modules/griddle-react/node_modules/lodash/isArray.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/memoize.js":function(e,t,o){function n(e,t){if("function"!=typeof e||null!=t&&"function"!=typeof t)throw new TypeError(s);var o=function(){var n=arguments,r=t?t.apply(this,n):n[0],s=o.cache;if(s.has(r))return s.get(r);var l=e.apply(this,n);return o.cache=s.set(r,l)||s,l};return o.cache=new(n.Cache||r),o}var r=o("./node_modules/griddle-react/node_modules/lodash/_MapCache.js"),s="Expected a function";n.Cache=r,e.exports=n},"./node_modules/griddle-react/node_modules/lodash/omit.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_arrayMap.js"),r=o("./node_modules/griddle-react/node_modules/lodash/_baseClone.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_baseUnset.js"),l=o("./node_modules/griddle-react/node_modules/lodash/_castPath.js"),i=o("./node_modules/griddle-react/node_modules/lodash/_copyObject.js"),a=o("./node_modules/griddle-react/node_modules/lodash/_customOmitClone.js"),d=o("./node_modules/griddle-react/node_modules/lodash/_flatRest.js"),u=o("./node_modules/griddle-react/node_modules/lodash/_getAllKeysIn.js"),c=d(function(e,t){var o={};if(null==e)return o;var d=!1;t=n(t,function(t){return t=l(t,e),d||(d=t.length>1),t}),i(e,u(e),o),d&&(o=r(o,7,a));for(var c=t.length;c--;)s(o,t[c]);return o});e.exports=c},"./node_modules/griddle-react/node_modules/lodash/orderBy.js":function(e,t,o){function n(e,t,o,n){return null==e?[]:(s(t)||(t=null==t?[]:[t]),o=n?void 0:o,s(o)||(o=null==o?[]:[o]),r(e,t,o))}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseOrderBy.js"),s=o("./node_modules/griddle-react/node_modules/lodash/isArray.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/pick.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_basePick.js"),r=o("./node_modules/griddle-react/node_modules/lodash/_flatRest.js"),s=r(function(e,t){return null==e?{}:n(e,t)});e.exports=s},"./node_modules/griddle-react/node_modules/lodash/property.js":function(e,t,o){function n(e){return l(e)?r(i(e)):s(e)}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseProperty.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_basePropertyDeep.js"),l=o("./node_modules/griddle-react/node_modules/lodash/_isKey.js"),i=o("./node_modules/griddle-react/node_modules/lodash/_toKey.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/sortBy.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_baseFlatten.js"),r=o("./node_modules/griddle-react/node_modules/lodash/_baseOrderBy.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_baseRest.js"),l=o("./node_modules/griddle-react/node_modules/lodash/_isIterateeCall.js"),i=s(function(e,t){if(null==e)return[];var o=t.length;return o>1&&l(e,t[0],t[1])?t=[]:o>2&&l(t[0],t[1],t[2])&&(t=[t[0]]),r(e,n(t,1),[])});e.exports=i},"./node_modules/griddle-react/node_modules/lodash/stubArray.js":function(e,t){function o(){return[]}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/stubFalse.js":function(e,t){function o(){return!1}e.exports=o},"./node_modules/griddle-react/node_modules/lodash/take.js":function(e,t,o){function n(e,t,o){return e&&e.length?(t=o||void 0===t?1:s(t),r(e,0,t<0?0:t)):[]}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseSlice.js"),s=o("./node_modules/griddle-react/node_modules/lodash/toInteger.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/toFinite.js":function(e,t,o){function n(e){return e?(e=r(e))===s||e===-s?(e<0?-1:1)*l:e===e?e:0:0===e?e:0}var r=o("./node_modules/griddle-react/node_modules/lodash/toNumber.js"),s=1/0,l=1.7976931348623157e308;e.exports=n},"./node_modules/griddle-react/node_modules/lodash/toInteger.js":function(e,t,o){function n(e){var t=r(e),o=t%1;return t===t?o?t-o:t:0}var r=o("./node_modules/griddle-react/node_modules/lodash/toFinite.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/toNumber.js":function(e,t,o){function n(e){if("number"==typeof e)return e;if(s(e))return l;if(r(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=r(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=e.replace(i,"");var o=d.test(e);return o||u.test(e)?c(e.slice(2),o?2:8):a.test(e)?l:+e}var r=o("./node_modules/griddle-react/node_modules/lodash/isObject.js"),s=o("./node_modules/griddle-react/node_modules/lodash/isSymbol.js"),l=NaN,i=/^\s+|\s+$/g,a=/^[-+]0x[0-9a-f]+$/i,d=/^0b[01]+$/i,u=/^0o[0-7]+$/i,c=parseInt;e.exports=n},"./node_modules/griddle-react/node_modules/lodash/toPairs.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_createToPairs.js"),r=o("./node_modules/griddle-react/node_modules/lodash/keys.js"),s=n(r);e.exports=s},"./node_modules/griddle-react/node_modules/lodash/toString.js":function(e,t,o){function n(e){return null==e?"":r(e)}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseToString.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/uniqueId.js":function(e,t,o){function n(e){var t=++s;return r(e)+t}var r=o("./node_modules/griddle-react/node_modules/lodash/toString.js"),s=0;e.exports=n},"./node_modules/griddle-react/node_modules/lodash/values.js":function(e,t,o){function n(e){return null==e?[]:r(e,s(e))}var r=o("./node_modules/griddle-react/node_modules/lodash/_baseValues.js"),s=o("./node_modules/griddle-react/node_modules/lodash/keys.js");e.exports=n},"./node_modules/griddle-react/node_modules/lodash/without.js":function(e,t,o){var n=o("./node_modules/griddle-react/node_modules/lodash/_baseDifference.js"),r=o("./node_modules/griddle-react/node_modules/lodash/_baseRest.js"),s=o("./node_modules/griddle-react/node_modules/lodash/isArrayLikeObject.js"),l=r(function(e,t){return s(e)?n(e,t):[]});e.exports=l},"./node_modules/griddle-react/node_modules/lodash/zipObject.js":function(e,t,o){function n(e,t){return s(e||[],t||[],r)}var r=o("./node_modules/griddle-react/node_modules/lodash/_assignValue.js"),s=o("./node_modules/griddle-react/node_modules/lodash/_baseZipObject.js");e.exports=n},"./node_modules/react-selectable/dist/react-selectable.js":function(e,t,o){!function(t,n){e.exports=function(e,t){return function(e){function t(n){if(o[n])return o[n].exports;var r=o[n]={exports:{},id:n,loaded:!1};return e[n].call(r.exports,r,r.exports,t),r.loaded=!0,r.exports}var o={};return t.m=e,t.c=o,t.p="",t(0)}([function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.nodeInRoot=t.isNodeIn=t.createSelectable=t.SelectableGroup=void 0;var r=o(1),s=n(r),l=o(9),i=n(l),a=o(5),d=n(a),u=o(4),c=n(u);t.SelectableGroup=s.default,t.createSelectable=i.default,t.isNodeIn=d.default,t.nodeInRoot=c.default},function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,"__esModule",{value:!0});var i=function(){function e(e,t){for(var o=0;oo+i||t+r-an+l)};t.default=function(e,t,o){var n=e instanceof HTMLElement?(0,r.default)(e):e,l=t instanceof HTMLElement?(0,r.default)(t):t;return s(n.top,n.left,l.top,l.left,n.offsetWidth,n.offsetHeight,l.offsetWidth,l.offsetHeight,o)}},function(e,t){(function(t){"use strict";function o(e,t,o){function n(t){var o=m,n=_;return m=_=void 0,E=t,y=e.apply(n,o)}function s(e){return E=e,v=setTimeout(u,t),P?n(e):y}function l(e){var o=e-b,n=e-E,r=t-o;return w?S(r,g-n):r}function a(e){var o=e-b,n=e-E;return void 0===b||o>=t||o<0||w&&n>=g}function u(){var e=C();if(a(e))return c(e);v=setTimeout(u,l(e))}function c(e){return v=void 0,T&&m?n(e):(m=_=void 0,y)}function p(){void 0!==v&&clearTimeout(v),E=0,m=b=_=v=void 0}function f(){return void 0===v?y:c(C())}function h(){var e=C(),o=a(e);if(m=arguments,_=this,b=e,o){if(void 0===v)return s(b);if(w)return v=setTimeout(u,t),n(b)}return void 0===v&&(v=setTimeout(u,t)),y}var m,_,g,y,v,b,E=0,P=!1,w=!1,T=!0;if("function"!=typeof e)throw new TypeError(d);return t=i(t)||0,r(o)&&(P=!!o.leading,w="maxWait"in o,g=w?j(i(o.maxWait)||0,t):g,T="trailing"in o?!!o.trailing:T),h.cancel=p,h.flush=f,h}function n(e,t,n){var s=!0,l=!0;if("function"!=typeof e)throw new TypeError(d);return r(n)&&(s="leading"in n?!!n.leading:s,l="trailing"in n?!!n.trailing:l),o(e,t,{leading:s,maxWait:t,trailing:l})}function r(e){var t=void 0===e?"undefined":a(e);return!!e&&("object"==t||"function"==t)}function s(e){return!!e&&"object"==(void 0===e?"undefined":a(e))}function l(e){return"symbol"==(void 0===e?"undefined":a(e))||s(e)&&E.call(e)==c}function i(e){if("number"==typeof e)return e;if(l(e))return u;if(r(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=r(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=e.replace(p,"");var o=h.test(e);return o||m.test(e)?_(e.slice(2),o?2:8):f.test(e)?u:+e}var a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},d="Expected a function",u=NaN,c="[object Symbol]",p=/^\s+|\s+$/g,f=/^[-+]0x[0-9a-f]+$/i,h=/^0b[01]+$/i,m=/^0o[0-7]+$/i,_=parseInt,g="object"==(void 0===t?"undefined":a(t))&&t&&t.Object===Object&&t,y="object"==("undefined"==typeof self?"undefined":a(self))&&self&&self.Object===Object&&self,v=g||y||Function("return this")(),b=Object.prototype,E=b.toString,j=Math.max,S=Math.min,C=function(){return v.Date.now()};e.exports=n}).call(t,function(){return this}())},function(e,t,o){"use strict";function n(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function s(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function l(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,"__esModule",{value:!0});var i=function(){function e(e,t){for(var o=0;o-1}var r=o("./node_modules/redux-form/node_modules/lodash/_assocIndexOf.js");e.exports=n},"./node_modules/redux-form/node_modules/lodash/_listCacheSet.js":function(e,t,o){function n(e,t){var o=this.__data__,n=r(o,e);return n<0?(++this.size,o.push([e,t])):o[n][1]=t,this}var r=o("./node_modules/redux-form/node_modules/lodash/_assocIndexOf.js");e.exports=n},"./node_modules/redux-form/node_modules/lodash/_mapCacheClear.js":function(e,t,o){function n(){this.size=0,this.__data__={hash:new r,map:new(l||s),string:new r}}var r=o("./node_modules/redux-form/node_modules/lodash/_Hash.js"),s=o("./node_modules/redux-form/node_modules/lodash/_ListCache.js"),l=o("./node_modules/redux-form/node_modules/lodash/_Map.js");e.exports=n},"./node_modules/redux-form/node_modules/lodash/_mapCacheDelete.js":function(e,t,o){function n(e){var t=r(this,e).delete(e);return this.size-=t?1:0,t}var r=o("./node_modules/redux-form/node_modules/lodash/_getMapData.js");e.exports=n},"./node_modules/redux-form/node_modules/lodash/_mapCacheGet.js":function(e,t,o){function n(e){return r(this,e).get(e)}var r=o("./node_modules/redux-form/node_modules/lodash/_getMapData.js");e.exports=n},"./node_modules/redux-form/node_modules/lodash/_mapCacheHas.js":function(e,t,o){function n(e){return r(this,e).has(e)}var r=o("./node_modules/redux-form/node_modules/lodash/_getMapData.js");e.exports=n},"./node_modules/redux-form/node_modules/lodash/_mapCacheSet.js":function(e,t,o){function n(e,t){var o=r(this,e),n=o.size;return o.set(e,t),this.size+=o.size==n?0:1,this}var r=o("./node_modules/redux-form/node_modules/lodash/_getMapData.js");e.exports=n},"./node_modules/redux-form/node_modules/lodash/_memoizeCapped.js":function(e,t,o){function n(e){var t=r(e,function(e){return o.size===s&&o.clear(),e}),o=t.cache;return t}var r=o("./node_modules/redux-form/node_modules/lodash/memoize.js"),s=500;e.exports=n},"./node_modules/redux-form/node_modules/lodash/_nativeCreate.js":function(e,t,o){var n=o("./node_modules/redux-form/node_modules/lodash/_getNative.js"),r=n(Object,"create");e.exports=r},"./node_modules/redux-form/node_modules/lodash/_objectToString.js":function(e,t){function o(e){return r.call(e)}var n=Object.prototype,r=n.toString;e.exports=o},"./node_modules/redux-form/node_modules/lodash/_root.js":function(e,t,o){var n=o("./node_modules/redux-form/node_modules/lodash/_freeGlobal.js"),r="object"==typeof self&&self&&self.Object===Object&&self,s=n||r||Function("return this")();e.exports=s},"./node_modules/redux-form/node_modules/lodash/_stringToPath.js":function(e,t,o){var n=o("./node_modules/redux-form/node_modules/lodash/_memoizeCapped.js"),r=/^\./,s=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,l=/\\(\\)?/g,i=n(function(e){var t=[];return r.test(e)&&t.push(""),e.replace(s,function(e,o,n,r){t.push(n?r.replace(l,"$1"):o||e)}),t});e.exports=i},"./node_modules/redux-form/node_modules/lodash/_toKey.js":function(e,t,o){function n(e){if("string"==typeof e||r(e))return e;var t=e+"";return"0"==t&&1/e==-s?"-0":t}var r=o("./node_modules/redux-form/node_modules/lodash/isSymbol.js"),s=1/0;e.exports=n},"./node_modules/redux-form/node_modules/lodash/_toSource.js":function(e,t){function o(e){if(null!=e){try{return r.call(e)}catch(e){}try{return e+""}catch(e){}}return""}var n=Function.prototype,r=n.toString;e.exports=o},"./node_modules/redux-form/node_modules/lodash/eq.js":function(e,t){function o(e,t){return e===t||e!==e&&t!==t}e.exports=o},"./node_modules/redux-form/node_modules/lodash/isArray.js":function(e,t){var o=Array.isArray;e.exports=o},"./node_modules/redux-form/node_modules/lodash/isFunction.js":function(e,t,o){function n(e){if(!s(e))return!1;var t=r(e);return t==i||t==a||t==l||t==d}var r=o("./node_modules/redux-form/node_modules/lodash/_baseGetTag.js"),s=o("./node_modules/redux-form/node_modules/lodash/isObject.js"),l="[object AsyncFunction]",i="[object Function]",a="[object GeneratorFunction]",d="[object Proxy]";e.exports=n},"./node_modules/redux-form/node_modules/lodash/isObject.js":function(e,t){function o(e){var t=typeof e;return null!=e&&("object"==t||"function"==t)}e.exports=o},"./node_modules/redux-form/node_modules/lodash/isObjectLike.js":function(e,t){function o(e){return null!=e&&"object"==typeof e}e.exports=o},"./node_modules/redux-form/node_modules/lodash/isSymbol.js":function(e,t,o){function n(e){return"symbol"==typeof e||s(e)&&r(e)==l}var r=o("./node_modules/redux-form/node_modules/lodash/_baseGetTag.js"),s=o("./node_modules/redux-form/node_modules/lodash/isObjectLike.js"),l="[object Symbol]";e.exports=n},"./node_modules/redux-form/node_modules/lodash/memoize.js":function(e,t,o){function n(e,t){if("function"!=typeof e||null!=t&&"function"!=typeof t)throw new TypeError(s);var o=function(){var n=arguments,r=t?t.apply(this,n):n[0],s=o.cache;if(s.has(r))return s.get(r);var l=e.apply(this,n);return o.cache=s.set(r,l)||s,l};return o.cache=new(n.Cache||r),o}var r=o("./node_modules/redux-form/node_modules/lodash/_MapCache.js"),s="Expected a function";n.Cache=r,e.exports=n},"./node_modules/redux-form/node_modules/lodash/toPath.js":function(e,t,o){function n(e){return l(e)?r(e,d):i(e)?[e]:s(a(u(e)))}var r=o("./node_modules/redux-form/node_modules/lodash/_arrayMap.js"),s=o("./node_modules/redux-form/node_modules/lodash/_copyArray.js"),l=o("./node_modules/redux-form/node_modules/lodash/isArray.js"),i=o("./node_modules/redux-form/node_modules/lodash/isSymbol.js"),a=o("./node_modules/redux-form/node_modules/lodash/_stringToPath.js"),d=o("./node_modules/redux-form/node_modules/lodash/_toKey.js"),u=o("./node_modules/redux-form/node_modules/lodash/toString.js");e.exports=n},"./node_modules/redux-form/node_modules/lodash/toString.js":function(e,t,o){function n(e){return null==e?"":r(e)}var r=o("./node_modules/redux-form/node_modules/lodash/_baseToString.js");e.exports=n},"./node_modules/webpack/buildin/global.js":function(e,t){var o;o=function(){return this}();try{o=o||Function("return this")()||(0,eval)("this")}catch(e){"object"==typeof window&&(o=window)}e.exports=o},"./node_modules/webpack/buildin/module.js":function(e,t){e.exports=function(e){return e.webpackPolyfill||(e.deprecate=function(){},e.paths=[],e.children||(e.children=[]),Object.defineProperty(e,"loaded",{enumerable:!0,get:function(){return e.l}}),Object.defineProperty(e,"id",{enumerable:!0,get:function(){return e.i}}),e.webpackPolyfill=1),e}},0:function(e,t){e.exports=React},1:function(e,t){e.exports=i18n},10:function(e,t){e.exports=InsertMediaModal},11:function(e,t){e.exports=FormBuilderModal},12:function(e,t){e.exports=DataFormat},13:function(e,t){e.exports=DeepFreezeStrict},14:function(e,t){e.exports=GraphQLTag},15:function(e,t){e.exports=ReactDND},16:function(e,t){e.exports=SchemaActions},17:function(e,t){e.exports=Badge},18:function(e,t){e.exports=FormBuilderLoader},19:function(e,t){e.exports=Backend},2:function(e,t){e.exports=Injector},20:function(e,t){e.exports=Config},21:function(e,t){e.exports=ReactDNDHtml5Backend},22:function(e,t){e.exports=Reactstrap},23:function(e,t){e.exports=ReduxForm},24:function(e,t){e.exports=getFormState},26:function(e,t){e.exports=Breadcrumb},27:function(e,t){e.exports=BreadcrumbsActions},28:function(e,t){e.exports=FieldHolder},29:function(e,t){e.exports=FileSchemaModalHandler},3:function(e,t){e.exports=ReactRedux},30:function(e,t){e.exports=Focusedzone},31:function(e,t){e.exports=FormAlert},32:function(e,t){e.exports=ReactAddonsCssTransitionGroup},33:function(e,t){e.exports=ReactAddonsTestUtils},34:function(e,t){e.exports=ReactRouteRegister},35:function(e,t){e.exports=ReactRouter},36:function(e,t){e.exports=Toolbar},37:function(e,t){e.exports=TreeDropdownField},38:function(e,t){e.exports=UnsavedFormsActions},39:function(e,t){e.exports=qs},4:function(e,t){e.exports=Redux},40:function(e,t){e.exports=reduxFieldReducer},41:function(e,t){e.exports=schemaFieldValues},5:function(e,t){e.exports=ReactDom},6:function(e,t){e.exports=jQuery},8:function(e,t){e.exports=ReactApollo},9:function(e,t){e.exports=classnames}}); \ No newline at end of file +/******/ (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] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = 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; +/******/ +/******/ // identity function for calling harmony imports with the correct context +/******/ __webpack_require__.i = function(value) { return value; }; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { +/******/ configurable: false, +/******/ enumerable: true, +/******/ get: getter +/******/ }); +/******/ } +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = "./client/src/bundles/bundle.js"); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "../../../node_modules/babel-loader/lib/index.js?{\"presets\":[[\"env\",{\"modules\":false}],\"react\"],\"plugins\":[\"transform-object-rest-spread\"],\"comments\":false,\"cacheDirectory\":true}!./client/src/components/InsertEmbedModal/InsertEmbedModal.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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"); } }; }(); + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _redux = __webpack_require__(4); + +var _reactRedux = __webpack_require__(3); + +var _FormBuilderModal = __webpack_require__(11); + +var _FormBuilderModal2 = _interopRequireDefault(_FormBuilderModal); + +var _SchemaActions = __webpack_require__(16); + +var schemaActions = _interopRequireWildcard(_SchemaActions); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var sectionConfigKey = 'SilverStripe\\AssetAdmin\\Controller\\AssetAdmin'; + +var InsertEmbedModal = function (_Component) { + _inherits(InsertEmbedModal, _Component); + + function InsertEmbedModal(props) { + _classCallCheck(this, InsertEmbedModal); + + var _this = _possibleConstructorReturn(this, (InsertEmbedModal.__proto__ || Object.getPrototypeOf(InsertEmbedModal)).call(this, props)); + + _this.handleSubmit = _this.handleSubmit.bind(_this); + return _this; + } + + _createClass(InsertEmbedModal, [{ + key: 'componentWillMount', + value: function componentWillMount() { + this.setOverrides(this.props); + } + }, { + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(props) { + if (props.isOpen && !this.props.isOpen) { + this.setOverrides(props); + } + } + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + this.clearOverrides(); + } + }, { + key: 'setOverrides', + value: function setOverrides(props) { + if (this.props.schemaUrl !== props.schemaUrl) { + this.clearOverrides(); + } + if (props.schemaUrl) { + var attrs = Object.assign({}, props.fileAttributes); + delete attrs.ID; + + var overrides = { + fields: Object.entries(attrs).map(function (field) { + var _field = _slicedToArray(field, 2), + name = _field[0], + value = _field[1]; + + return { name: name, value: value }; + }) + }; + + this.props.actions.schema.setSchemaStateOverrides(props.schemaUrl, overrides); + } + } + }, { + key: 'getModalProps', + value: function getModalProps() { + var props = Object.assign({ + onSubmit: this.handleSubmit, + onLoadingError: this.handleLoadingError, + showErrorMessage: true, + responseClassBad: 'alert alert-danger', + identifier: 'AssetAdmin.InsertEmbedModal' + }, this.props, { + className: 'insert-embed-modal ' + this.props.className, + size: 'lg', + onClosed: this.props.onClosed, + title: this.props.targetUrl ? _i18n2.default._t('AssetAdmin.EditTitle', 'Media from the web') : _i18n2.default._t('AssetAdmin.CreateTitle', 'Insert new media from the web') + }); + delete props.sectionConfig; + delete props.onInsert; + delete props.fileAttributes; + + return props; + } + }, { + key: 'clearOverrides', + value: function clearOverrides() { + this.props.actions.schema.setSchemaStateOverrides(this.props.schemaUrl, null); + } + }, { + key: 'handleLoadingError', + value: function handleLoadingError(error) { + if (typeof this.props.onLoadingError === 'function') { + this.props.onLoadingError(error); + } + } + }, { + key: 'handleSubmit', + value: function handleSubmit(data, action) { + switch (action) { + case 'action_addmedia': + { + this.props.onCreate(data); + break; + } + case 'action_insertmedia': + { + this.props.onInsert(data); + break; + } + case 'action_cancel': + { + this.props.onClosed(); + break; + } + default: + {} + } + + return Promise.resolve(); + } + }, { + key: 'render', + value: function render() { + return _react2.default.createElement(_FormBuilderModal2.default, this.getModalProps()); + } + }]); + + return InsertEmbedModal; +}(_react.Component); + +InsertEmbedModal.propTypes = { + sectionConfig: _react.PropTypes.shape({ + url: _react.PropTypes.string, + form: _react.PropTypes.object + }), + isOpen: _react.PropTypes.bool, + onInsert: _react.PropTypes.func.isRequired, + onCreate: _react.PropTypes.func.isRequired, + fileAttributes: _react.PropTypes.shape({ + Url: _react.PropTypes.string, + CaptionText: _react.PropTypes.string, + PreviewUrl: _react.PropTypes.string, + Placement: _react.PropTypes.string, + Width: _react.PropTypes.number, + Height: _react.PropTypes.number + }), + onClosed: _react.PropTypes.func.isRequired, + className: _react.PropTypes.string, + actions: _react.PropTypes.object, + schemaUrl: _react.PropTypes.string.isRequired, + targetUrl: _react.PropTypes.string, + onLoadingError: _react.PropTypes.func +}; + +InsertEmbedModal.defaultProps = { + className: '', + fileAttributes: {} +}; + +function mapStateToProps(state, ownProps) { + var sectionConfig = state.config.sections.find(function (section) { + return section.name === sectionConfigKey; + }); + + var targetUrl = ownProps.fileAttributes ? ownProps.fileAttributes.Url : ''; + var baseEditUrl = sectionConfig.form.remoteEditForm.schemaUrl; + + var editUrl = targetUrl && baseEditUrl + '/?embedurl=' + encodeURIComponent(targetUrl); + var createUrl = sectionConfig.form.remoteCreateForm.schemaUrl; + + var schemaUrl = editUrl || createUrl; + + return { + sectionConfig: sectionConfig, + schemaUrl: schemaUrl, + targetUrl: targetUrl + }; +} + +function mapDispatchToProps(dispatch) { + return { + actions: { + schema: (0, _redux.bindActionCreators)(schemaActions, dispatch) + } + }; +} + +exports.Component = InsertEmbedModal; +exports.default = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps)(InsertEmbedModal); + +/***/ }), + +/***/ "../../../node_modules/babel-loader/lib/index.js?{\"presets\":[[\"env\",{\"modules\":false}],\"react\"],\"plugins\":[\"transform-object-rest-spread\"],\"comments\":false,\"cacheDirectory\":true}!./client/src/containers/InsertMediaModal/InsertMediaModal.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _redux = __webpack_require__(4); + +var _reactRedux = __webpack_require__(3); + +var _AssetAdmin = __webpack_require__("./client/src/containers/AssetAdmin/AssetAdmin.js"); + +var _AssetAdmin2 = _interopRequireDefault(_AssetAdmin); + +var _stateRouter = __webpack_require__("./client/src/containers/AssetAdmin/stateRouter.js"); + +var _stateRouter2 = _interopRequireDefault(_stateRouter); + +var _fileSchemaModalHandler = __webpack_require__(29); + +var _fileSchemaModalHandler2 = _interopRequireDefault(_fileSchemaModalHandler); + +var _GalleryActions = __webpack_require__("./client/src/state/gallery/GalleryActions.js"); + +var galleryActions = _interopRequireWildcard(_GalleryActions); + +var _FormBuilderModal = __webpack_require__(11); + +var _FormBuilderModal2 = _interopRequireDefault(_FormBuilderModal); + +var _classnames = __webpack_require__(9); + +var _classnames2 = _interopRequireDefault(_classnames); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var InsertMediaModal = function (_Component) { + _inherits(InsertMediaModal, _Component); + + function InsertMediaModal(props) { + _classCallCheck(this, InsertMediaModal); + + var _this = _possibleConstructorReturn(this, (InsertMediaModal.__proto__ || Object.getPrototypeOf(InsertMediaModal)).call(this, props)); + + _this.handleSubmit = _this.handleSubmit.bind(_this); + return _this; + } + + _createClass(InsertMediaModal, [{ + key: 'componentDidMount', + value: function componentDidMount() { + var _props = this.props, + isOpen = _props.isOpen, + onBrowse = _props.onBrowse, + setOverrides = _props.setOverrides, + fileAttributes = _props.fileAttributes, + folderId = _props.folderId; + + + if (!isOpen) { + onBrowse(folderId || 0); + } else if (typeof setOverrides === 'function' && fileAttributes.ID) { + setOverrides(this.props); + onBrowse(folderId, fileAttributes.ID); + } + } + }, { + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(props) { + if (!props.isOpen && this.props.isOpen) { + props.onBrowse(props.folderId); + props.actions.gallery.deselectFiles(); + } + if (typeof this.props.setOverrides === 'function' && props.isOpen && !this.props.isOpen) { + this.props.setOverrides(props); + props.onBrowse(props.folderId, props.fileAttributes ? props.fileAttributes.ID : null); + } + } + }, { + key: 'getSectionProps', + value: function getSectionProps() { + return _extends({}, this.props, { + dialog: true, + toolbarChildren: this.renderToolbarChildren(), + onSubmitEditor: this.handleSubmit, + onReplaceUrl: this.props.onBrowse + }); + } + }, { + key: 'getModalProps', + value: function getModalProps() { + var props = _extends({}, this.props, { + className: (0, _classnames2.default)('insert-media-modal', this.props.className), + size: 'lg', + showCloseButton: false + }); + delete props.onHide; + delete props.onInsert; + delete props.sectionConfig; + delete props.schemaUrl; + + return props; + } + }, { + key: 'handleSubmit', + value: function handleSubmit(data, action, submitFn, file) { + if (action === 'action_createfolder') { + return submitFn(); + } + return this.props.onInsert(data, file); + } + }, { + key: 'renderToolbarChildren', + value: function renderToolbarChildren() { + return _react2.default.createElement( + 'button', + { + type: 'button', + className: 'close insert-media-modal__close-button', + onClick: this.props.onClosed, + 'aria-label': _i18n2.default._t('FormBuilderModal.CLOSE', 'Close') + }, + _react2.default.createElement( + 'span', + { 'aria-hidden': 'true' }, + '\xD7' + ) + ); + } + }, { + key: 'render', + value: function render() { + var modalProps = this.getModalProps(); + var sectionProps = this.getSectionProps(); + var assetAdmin = this.props.isOpen ? _react2.default.createElement(_AssetAdmin2.default, sectionProps) : null; + + return _react2.default.createElement( + _FormBuilderModal2.default, + modalProps, + assetAdmin + ); + } + }]); + + return InsertMediaModal; +}(_react.Component); + +InsertMediaModal.propTypes = { + sectionConfig: _react.PropTypes.shape({ + url: _react.PropTypes.string, + form: _react.PropTypes.object + }), + type: _react.PropTypes.oneOf(['insert-media', 'insert-link', 'select', 'admin']), + schemaUrl: _react.PropTypes.string, + isOpen: _react.PropTypes.bool, + setOverrides: _react.PropTypes.func, + onInsert: _react.PropTypes.func.isRequired, + fileAttributes: _react.PropTypes.shape({ + ID: _react.PropTypes.number, + AltText: _react.PropTypes.string, + Width: _react.PropTypes.number, + Height: _react.PropTypes.number, + TitleTooltip: _react.PropTypes.string, + Alignment: _react.PropTypes.string, + Description: _react.PropTypes.string, + TargetBlank: _react.PropTypes.bool + }), + requireLinkText: _react.PropTypes.bool, + folderId: _react.PropTypes.number, + fileId: _react.PropTypes.number, + viewAction: _react.PropTypes.string, + query: _react.PropTypes.object, + getUrl: _react.PropTypes.func, + onBrowse: _react.PropTypes.func.isRequired, + onClosed: _react.PropTypes.func, + className: _react.PropTypes.string, + actions: _react.PropTypes.object +}; + +InsertMediaModal.defaultProps = { + className: '', + fileAttributes: {}, + type: 'insert-media', + folderId: 0 +}; + +function mapStateToProps(state, ownProps) { + var config = ownProps.sectionConfig; + + if (!config) { + return {}; + } + + var folderId = 0; + if (ownProps.folderId !== null) { + folderId = ownProps.folderId; + } else if (ownProps.folder) { + folderId = ownProps.folder.id; + } + var fileId = ownProps.fileAttributes ? ownProps.fileAttributes.ID : ownProps.fileId; + + var props = { + config: config, + viewAction: ownProps.viewAction, + folderId: folderId, + type: ownProps.type, + fileId: fileId + }; + + var _getFormSchema = (0, _AssetAdmin.getFormSchema)(props), + schemaUrl = _getFormSchema.schemaUrl, + targetId = _getFormSchema.targetId; + + if (!schemaUrl) { + return {}; + } + + var requireTextFieldUrl = ownProps.requireLinkText ? '?requireLinkText=true' : ''; + + return { + schemaUrl: schemaUrl + '/' + targetId + requireTextFieldUrl + }; +} + +function mapDispatchToProps(dispatch) { + return { + actions: { + gallery: (0, _redux.bindActionCreators)(galleryActions, dispatch) + } + }; +} + +exports.Component = InsertMediaModal; +exports.default = (0, _redux.compose)(_stateRouter2.default, (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps), _fileSchemaModalHandler2.default)(InsertMediaModal); + +/***/ }), + +/***/ "../../../node_modules/constants-browserify/constants.json": +/***/ (function(module, exports) { + +module.exports = {"O_RDONLY":0,"O_WRONLY":1,"O_RDWR":2,"S_IFMT":61440,"S_IFREG":32768,"S_IFDIR":16384,"S_IFCHR":8192,"S_IFBLK":24576,"S_IFIFO":4096,"S_IFLNK":40960,"S_IFSOCK":49152,"O_CREAT":512,"O_EXCL":2048,"O_NOCTTY":131072,"O_TRUNC":1024,"O_APPEND":8,"O_DIRECTORY":1048576,"O_NOFOLLOW":256,"O_SYNC":128,"O_SYMLINK":2097152,"O_NONBLOCK":4,"S_IRWXU":448,"S_IRUSR":256,"S_IWUSR":128,"S_IXUSR":64,"S_IRWXG":56,"S_IRGRP":32,"S_IWGRP":16,"S_IXGRP":8,"S_IRWXO":7,"S_IROTH":4,"S_IWOTH":2,"S_IXOTH":1,"E2BIG":7,"EACCES":13,"EADDRINUSE":48,"EADDRNOTAVAIL":49,"EAFNOSUPPORT":47,"EAGAIN":35,"EALREADY":37,"EBADF":9,"EBADMSG":94,"EBUSY":16,"ECANCELED":89,"ECHILD":10,"ECONNABORTED":53,"ECONNREFUSED":61,"ECONNRESET":54,"EDEADLK":11,"EDESTADDRREQ":39,"EDOM":33,"EDQUOT":69,"EEXIST":17,"EFAULT":14,"EFBIG":27,"EHOSTUNREACH":65,"EIDRM":90,"EILSEQ":92,"EINPROGRESS":36,"EINTR":4,"EINVAL":22,"EIO":5,"EISCONN":56,"EISDIR":21,"ELOOP":62,"EMFILE":24,"EMLINK":31,"EMSGSIZE":40,"EMULTIHOP":95,"ENAMETOOLONG":63,"ENETDOWN":50,"ENETRESET":52,"ENETUNREACH":51,"ENFILE":23,"ENOBUFS":55,"ENODATA":96,"ENODEV":19,"ENOENT":2,"ENOEXEC":8,"ENOLCK":77,"ENOLINK":97,"ENOMEM":12,"ENOMSG":91,"ENOPROTOOPT":42,"ENOSPC":28,"ENOSR":98,"ENOSTR":99,"ENOSYS":78,"ENOTCONN":57,"ENOTDIR":20,"ENOTEMPTY":66,"ENOTSOCK":38,"ENOTSUP":45,"ENOTTY":25,"ENXIO":6,"EOPNOTSUPP":102,"EOVERFLOW":84,"EPERM":1,"EPIPE":32,"EPROTO":100,"EPROTONOSUPPORT":43,"EPROTOTYPE":41,"ERANGE":34,"EROFS":30,"ESPIPE":29,"ESRCH":3,"ESTALE":70,"ETIME":101,"ETIMEDOUT":60,"ETXTBSY":26,"EWOULDBLOCK":35,"EXDEV":18,"SIGHUP":1,"SIGINT":2,"SIGQUIT":3,"SIGILL":4,"SIGTRAP":5,"SIGABRT":6,"SIGIOT":6,"SIGBUS":10,"SIGFPE":8,"SIGKILL":9,"SIGUSR1":30,"SIGSEGV":11,"SIGUSR2":31,"SIGPIPE":13,"SIGALRM":14,"SIGTERM":15,"SIGCHLD":20,"SIGCONT":19,"SIGSTOP":17,"SIGTSTP":18,"SIGTTIN":21,"SIGTTOU":22,"SIGURG":16,"SIGXCPU":24,"SIGXFSZ":25,"SIGVTALRM":26,"SIGPROF":27,"SIGWINCH":28,"SIGIO":23,"SIGSYS":12,"SSL_OP_ALL":2147486719,"SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION":262144,"SSL_OP_CIPHER_SERVER_PREFERENCE":4194304,"SSL_OP_CISCO_ANYCONNECT":32768,"SSL_OP_COOKIE_EXCHANGE":8192,"SSL_OP_CRYPTOPRO_TLSEXT_BUG":2147483648,"SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS":2048,"SSL_OP_EPHEMERAL_RSA":0,"SSL_OP_LEGACY_SERVER_CONNECT":4,"SSL_OP_MICROSOFT_BIG_SSLV3_BUFFER":32,"SSL_OP_MICROSOFT_SESS_ID_BUG":1,"SSL_OP_MSIE_SSLV2_RSA_PADDING":0,"SSL_OP_NETSCAPE_CA_DN_BUG":536870912,"SSL_OP_NETSCAPE_CHALLENGE_BUG":2,"SSL_OP_NETSCAPE_DEMO_CIPHER_CHANGE_BUG":1073741824,"SSL_OP_NETSCAPE_REUSE_CIPHER_CHANGE_BUG":8,"SSL_OP_NO_COMPRESSION":131072,"SSL_OP_NO_QUERY_MTU":4096,"SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION":65536,"SSL_OP_NO_SSLv2":16777216,"SSL_OP_NO_SSLv3":33554432,"SSL_OP_NO_TICKET":16384,"SSL_OP_NO_TLSv1":67108864,"SSL_OP_NO_TLSv1_1":268435456,"SSL_OP_NO_TLSv1_2":134217728,"SSL_OP_PKCS1_CHECK_1":0,"SSL_OP_PKCS1_CHECK_2":0,"SSL_OP_SINGLE_DH_USE":1048576,"SSL_OP_SINGLE_ECDH_USE":524288,"SSL_OP_SSLEAY_080_CLIENT_DH_BUG":128,"SSL_OP_SSLREF2_REUSE_CERT_TYPE_BUG":0,"SSL_OP_TLS_BLOCK_PADDING_BUG":512,"SSL_OP_TLS_D5_BUG":256,"SSL_OP_TLS_ROLLBACK_BUG":8388608,"ENGINE_METHOD_DSA":2,"ENGINE_METHOD_DH":4,"ENGINE_METHOD_RAND":8,"ENGINE_METHOD_ECDH":16,"ENGINE_METHOD_ECDSA":32,"ENGINE_METHOD_CIPHERS":64,"ENGINE_METHOD_DIGESTS":128,"ENGINE_METHOD_STORE":256,"ENGINE_METHOD_PKEY_METHS":512,"ENGINE_METHOD_PKEY_ASN1_METHS":1024,"ENGINE_METHOD_ALL":65535,"ENGINE_METHOD_NONE":0,"DH_CHECK_P_NOT_SAFE_PRIME":2,"DH_CHECK_P_NOT_PRIME":1,"DH_UNABLE_TO_CHECK_GENERATOR":4,"DH_NOT_SUITABLE_GENERATOR":8,"NPN_ENABLED":1,"RSA_PKCS1_PADDING":1,"RSA_SSLV23_PADDING":2,"RSA_NO_PADDING":3,"RSA_PKCS1_OAEP_PADDING":4,"RSA_X931_PADDING":5,"RSA_PKCS1_PSS_PADDING":6,"POINT_CONVERSION_COMPRESSED":2,"POINT_CONVERSION_UNCOMPRESSED":4,"POINT_CONVERSION_HYBRID":6,"F_OK":0,"R_OK":4,"W_OK":2,"X_OK":1,"UV_UDP_REUSEADDR":4} + +/***/ }), + +/***/ "../../../node_modules/dropzone/dist/dropzone.js": +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(jQuery, module) { +/* + * + * More info at [www.dropzonejs.com](http://www.dropzonejs.com) + * + * Copyright (c) 2012, Matias Meno + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + * + */ + +(function() { + var Dropzone, Emitter, camelize, contentLoaded, detectVerticalSquash, drawImageIOSFix, noop, without, + __slice = [].slice, + __hasProp = {}.hasOwnProperty, + __extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; }; + + noop = function() {}; + + Emitter = (function() { + function Emitter() {} + + Emitter.prototype.addEventListener = Emitter.prototype.on; + + Emitter.prototype.on = function(event, fn) { + this._callbacks = this._callbacks || {}; + if (!this._callbacks[event]) { + this._callbacks[event] = []; + } + this._callbacks[event].push(fn); + return this; + }; + + Emitter.prototype.emit = function() { + var args, callback, callbacks, event, _i, _len; + event = arguments[0], args = 2 <= arguments.length ? __slice.call(arguments, 1) : []; + this._callbacks = this._callbacks || {}; + callbacks = this._callbacks[event]; + if (callbacks) { + for (_i = 0, _len = callbacks.length; _i < _len; _i++) { + callback = callbacks[_i]; + callback.apply(this, args); + } + } + return this; + }; + + Emitter.prototype.removeListener = Emitter.prototype.off; + + Emitter.prototype.removeAllListeners = Emitter.prototype.off; + + Emitter.prototype.removeEventListener = Emitter.prototype.off; + + Emitter.prototype.off = function(event, fn) { + var callback, callbacks, i, _i, _len; + if (!this._callbacks || arguments.length === 0) { + this._callbacks = {}; + return this; + } + callbacks = this._callbacks[event]; + if (!callbacks) { + return this; + } + if (arguments.length === 1) { + delete this._callbacks[event]; + return this; + } + for (i = _i = 0, _len = callbacks.length; _i < _len; i = ++_i) { + callback = callbacks[i]; + if (callback === fn) { + callbacks.splice(i, 1); + break; + } + } + return this; + }; + + return Emitter; + + })(); + + Dropzone = (function(_super) { + var extend, resolveOption; + + __extends(Dropzone, _super); + + Dropzone.prototype.Emitter = Emitter; + + + /* + This is a list of all available events you can register on a dropzone object. + + You can register an event handler like this: + + dropzone.on("dragEnter", function() { }); + */ + + Dropzone.prototype.events = ["drop", "dragstart", "dragend", "dragenter", "dragover", "dragleave", "addedfile", "addedfiles", "removedfile", "thumbnail", "error", "errormultiple", "processing", "processingmultiple", "uploadprogress", "totaluploadprogress", "sending", "sendingmultiple", "success", "successmultiple", "canceled", "canceledmultiple", "complete", "completemultiple", "reset", "maxfilesexceeded", "maxfilesreached", "queuecomplete"]; + + Dropzone.prototype.defaultOptions = { + url: null, + method: "post", + withCredentials: false, + parallelUploads: 2, + uploadMultiple: false, + maxFilesize: 256, + paramName: "file", + createImageThumbnails: true, + maxThumbnailFilesize: 10, + thumbnailWidth: 120, + thumbnailHeight: 120, + filesizeBase: 1000, + maxFiles: null, + params: {}, + clickable: true, + ignoreHiddenFiles: true, + acceptedFiles: null, + acceptedMimeTypes: null, + autoProcessQueue: true, + autoQueue: true, + addRemoveLinks: false, + previewsContainer: null, + hiddenInputContainer: "body", + capture: null, + renameFilename: null, + dictDefaultMessage: "Drop files here to upload", + dictFallbackMessage: "Your browser does not support drag'n'drop file uploads.", + dictFallbackText: "Please use the fallback form below to upload your files like in the olden days.", + dictFileTooBig: "File is too big ({{filesize}}MiB). Max filesize: {{maxFilesize}}MiB.", + dictInvalidFileType: "You can't upload files of this type.", + dictResponseError: "Server responded with {{statusCode}} code.", + dictCancelUpload: "Cancel upload", + dictCancelUploadConfirmation: "Are you sure you want to cancel this upload?", + dictRemoveFile: "Remove file", + dictRemoveFileConfirmation: null, + dictMaxFilesExceeded: "You can not upload any more files.", + accept: function(file, done) { + return done(); + }, + init: function() { + return noop; + }, + forceFallback: false, + fallback: function() { + var child, messageElement, span, _i, _len, _ref; + this.element.className = "" + this.element.className + " dz-browser-not-supported"; + _ref = this.element.getElementsByTagName("div"); + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + child = _ref[_i]; + if (/(^| )dz-message($| )/.test(child.className)) { + messageElement = child; + child.className = "dz-message"; + continue; + } + } + if (!messageElement) { + messageElement = Dropzone.createElement("
"); + this.element.appendChild(messageElement); + } + span = messageElement.getElementsByTagName("span")[0]; + if (span) { + if (span.textContent != null) { + span.textContent = this.options.dictFallbackMessage; + } else if (span.innerText != null) { + span.innerText = this.options.dictFallbackMessage; + } + } + return this.element.appendChild(this.getFallbackForm()); + }, + resize: function(file) { + var info, srcRatio, trgRatio; + info = { + srcX: 0, + srcY: 0, + srcWidth: file.width, + srcHeight: file.height + }; + srcRatio = file.width / file.height; + info.optWidth = this.options.thumbnailWidth; + info.optHeight = this.options.thumbnailHeight; + if ((info.optWidth == null) && (info.optHeight == null)) { + info.optWidth = info.srcWidth; + info.optHeight = info.srcHeight; + } else if (info.optWidth == null) { + info.optWidth = srcRatio * info.optHeight; + } else if (info.optHeight == null) { + info.optHeight = (1 / srcRatio) * info.optWidth; + } + trgRatio = info.optWidth / info.optHeight; + if (file.height < info.optHeight || file.width < info.optWidth) { + info.trgHeight = info.srcHeight; + info.trgWidth = info.srcWidth; + } else { + if (srcRatio > trgRatio) { + info.srcHeight = file.height; + info.srcWidth = info.srcHeight * trgRatio; + } else { + info.srcWidth = file.width; + info.srcHeight = info.srcWidth / trgRatio; + } + } + info.srcX = (file.width - info.srcWidth) / 2; + info.srcY = (file.height - info.srcHeight) / 2; + return info; + }, + + /* + Those functions register themselves to the events on init and handle all + the user interface specific stuff. Overwriting them won't break the upload + but can break the way it's displayed. + You can overwrite them if you don't like the default behavior. If you just + want to add an additional event handler, register it on the dropzone object + and don't overwrite those options. + */ + drop: function(e) { + return this.element.classList.remove("dz-drag-hover"); + }, + dragstart: noop, + dragend: function(e) { + return this.element.classList.remove("dz-drag-hover"); + }, + dragenter: function(e) { + return this.element.classList.add("dz-drag-hover"); + }, + dragover: function(e) { + return this.element.classList.add("dz-drag-hover"); + }, + dragleave: function(e) { + return this.element.classList.remove("dz-drag-hover"); + }, + paste: noop, + reset: function() { + return this.element.classList.remove("dz-started"); + }, + addedfile: function(file) { + var node, removeFileEvent, removeLink, _i, _j, _k, _len, _len1, _len2, _ref, _ref1, _ref2, _results; + if (this.element === this.previewsContainer) { + this.element.classList.add("dz-started"); + } + if (this.previewsContainer) { + file.previewElement = Dropzone.createElement(this.options.previewTemplate.trim()); + file.previewTemplate = file.previewElement; + this.previewsContainer.appendChild(file.previewElement); + _ref = file.previewElement.querySelectorAll("[data-dz-name]"); + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + node = _ref[_i]; + node.textContent = this._renameFilename(file.name); + } + _ref1 = file.previewElement.querySelectorAll("[data-dz-size]"); + for (_j = 0, _len1 = _ref1.length; _j < _len1; _j++) { + node = _ref1[_j]; + node.innerHTML = this.filesize(file.size); + } + if (this.options.addRemoveLinks) { + file._removeLink = Dropzone.createElement("" + this.options.dictRemoveFile + ""); + file.previewElement.appendChild(file._removeLink); + } + removeFileEvent = (function(_this) { + return function(e) { + e.preventDefault(); + e.stopPropagation(); + if (file.status === Dropzone.UPLOADING) { + return Dropzone.confirm(_this.options.dictCancelUploadConfirmation, function() { + return _this.removeFile(file); + }); + } else { + if (_this.options.dictRemoveFileConfirmation) { + return Dropzone.confirm(_this.options.dictRemoveFileConfirmation, function() { + return _this.removeFile(file); + }); + } else { + return _this.removeFile(file); + } + } + }; + })(this); + _ref2 = file.previewElement.querySelectorAll("[data-dz-remove]"); + _results = []; + for (_k = 0, _len2 = _ref2.length; _k < _len2; _k++) { + removeLink = _ref2[_k]; + _results.push(removeLink.addEventListener("click", removeFileEvent)); + } + return _results; + } + }, + removedfile: function(file) { + var _ref; + if (file.previewElement) { + if ((_ref = file.previewElement) != null) { + _ref.parentNode.removeChild(file.previewElement); + } + } + return this._updateMaxFilesReachedClass(); + }, + thumbnail: function(file, dataUrl) { + var thumbnailElement, _i, _len, _ref; + if (file.previewElement) { + file.previewElement.classList.remove("dz-file-preview"); + _ref = file.previewElement.querySelectorAll("[data-dz-thumbnail]"); + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + thumbnailElement = _ref[_i]; + thumbnailElement.alt = file.name; + thumbnailElement.src = dataUrl; + } + return setTimeout(((function(_this) { + return function() { + return file.previewElement.classList.add("dz-image-preview"); + }; + })(this)), 1); + } + }, + error: function(file, message) { + var node, _i, _len, _ref, _results; + if (file.previewElement) { + file.previewElement.classList.add("dz-error"); + if (typeof message !== "String" && message.error) { + message = message.error; + } + _ref = file.previewElement.querySelectorAll("[data-dz-errormessage]"); + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + node = _ref[_i]; + _results.push(node.textContent = message); + } + return _results; + } + }, + errormultiple: noop, + processing: function(file) { + if (file.previewElement) { + file.previewElement.classList.add("dz-processing"); + if (file._removeLink) { + return file._removeLink.textContent = this.options.dictCancelUpload; + } + } + }, + processingmultiple: noop, + uploadprogress: function(file, progress, bytesSent) { + var node, _i, _len, _ref, _results; + if (file.previewElement) { + _ref = file.previewElement.querySelectorAll("[data-dz-uploadprogress]"); + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + node = _ref[_i]; + if (node.nodeName === 'PROGRESS') { + _results.push(node.value = progress); + } else { + _results.push(node.style.width = "" + progress + "%"); + } + } + return _results; + } + }, + totaluploadprogress: noop, + sending: noop, + sendingmultiple: noop, + success: function(file) { + if (file.previewElement) { + return file.previewElement.classList.add("dz-success"); + } + }, + successmultiple: noop, + canceled: function(file) { + return this.emit("error", file, "Upload canceled."); + }, + canceledmultiple: noop, + complete: function(file) { + if (file._removeLink) { + file._removeLink.textContent = this.options.dictRemoveFile; + } + if (file.previewElement) { + return file.previewElement.classList.add("dz-complete"); + } + }, + completemultiple: noop, + maxfilesexceeded: noop, + maxfilesreached: noop, + queuecomplete: noop, + addedfiles: noop, + previewTemplate: "
\n
\n
\n
\n
\n
\n
\n
\n
\n \n Check\n \n \n \n \n \n
\n
\n \n Error\n \n \n \n \n \n \n \n
\n
" + }; + + extend = function() { + var key, object, objects, target, val, _i, _len; + target = arguments[0], objects = 2 <= arguments.length ? __slice.call(arguments, 1) : []; + for (_i = 0, _len = objects.length; _i < _len; _i++) { + object = objects[_i]; + for (key in object) { + val = object[key]; + target[key] = val; + } + } + return target; + }; + + function Dropzone(element, options) { + var elementOptions, fallback, _ref; + this.element = element; + this.version = Dropzone.version; + this.defaultOptions.previewTemplate = this.defaultOptions.previewTemplate.replace(/\n*/g, ""); + this.clickableElements = []; + this.listeners = []; + this.files = []; + if (typeof this.element === "string") { + this.element = document.querySelector(this.element); + } + if (!(this.element && (this.element.nodeType != null))) { + throw new Error("Invalid dropzone element."); + } + if (this.element.dropzone) { + throw new Error("Dropzone already attached."); + } + Dropzone.instances.push(this); + this.element.dropzone = this; + elementOptions = (_ref = Dropzone.optionsForElement(this.element)) != null ? _ref : {}; + this.options = extend({}, this.defaultOptions, elementOptions, options != null ? options : {}); + if (this.options.forceFallback || !Dropzone.isBrowserSupported()) { + return this.options.fallback.call(this); + } + if (this.options.url == null) { + this.options.url = this.element.getAttribute("action"); + } + if (!this.options.url) { + throw new Error("No URL provided."); + } + if (this.options.acceptedFiles && this.options.acceptedMimeTypes) { + throw new Error("You can't provide both 'acceptedFiles' and 'acceptedMimeTypes'. 'acceptedMimeTypes' is deprecated."); + } + if (this.options.acceptedMimeTypes) { + this.options.acceptedFiles = this.options.acceptedMimeTypes; + delete this.options.acceptedMimeTypes; + } + this.options.method = this.options.method.toUpperCase(); + if ((fallback = this.getExistingFallback()) && fallback.parentNode) { + fallback.parentNode.removeChild(fallback); + } + if (this.options.previewsContainer !== false) { + if (this.options.previewsContainer) { + this.previewsContainer = Dropzone.getElement(this.options.previewsContainer, "previewsContainer"); + } else { + this.previewsContainer = this.element; + } + } + if (this.options.clickable) { + if (this.options.clickable === true) { + this.clickableElements = [this.element]; + } else { + this.clickableElements = Dropzone.getElements(this.options.clickable, "clickable"); + } + } + this.init(); + } + + Dropzone.prototype.getAcceptedFiles = function() { + var file, _i, _len, _ref, _results; + _ref = this.files; + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + file = _ref[_i]; + if (file.accepted) { + _results.push(file); + } + } + return _results; + }; + + Dropzone.prototype.getRejectedFiles = function() { + var file, _i, _len, _ref, _results; + _ref = this.files; + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + file = _ref[_i]; + if (!file.accepted) { + _results.push(file); + } + } + return _results; + }; + + Dropzone.prototype.getFilesWithStatus = function(status) { + var file, _i, _len, _ref, _results; + _ref = this.files; + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + file = _ref[_i]; + if (file.status === status) { + _results.push(file); + } + } + return _results; + }; + + Dropzone.prototype.getQueuedFiles = function() { + return this.getFilesWithStatus(Dropzone.QUEUED); + }; + + Dropzone.prototype.getUploadingFiles = function() { + return this.getFilesWithStatus(Dropzone.UPLOADING); + }; + + Dropzone.prototype.getAddedFiles = function() { + return this.getFilesWithStatus(Dropzone.ADDED); + }; + + Dropzone.prototype.getActiveFiles = function() { + var file, _i, _len, _ref, _results; + _ref = this.files; + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + file = _ref[_i]; + if (file.status === Dropzone.UPLOADING || file.status === Dropzone.QUEUED) { + _results.push(file); + } + } + return _results; + }; + + Dropzone.prototype.init = function() { + var eventName, noPropagation, setupHiddenFileInput, _i, _len, _ref, _ref1; + if (this.element.tagName === "form") { + this.element.setAttribute("enctype", "multipart/form-data"); + } + if (this.element.classList.contains("dropzone") && !this.element.querySelector(".dz-message")) { + this.element.appendChild(Dropzone.createElement("
" + this.options.dictDefaultMessage + "
")); + } + if (this.clickableElements.length) { + setupHiddenFileInput = (function(_this) { + return function() { + if (_this.hiddenFileInput) { + _this.hiddenFileInput.parentNode.removeChild(_this.hiddenFileInput); + } + _this.hiddenFileInput = document.createElement("input"); + _this.hiddenFileInput.setAttribute("type", "file"); + if ((_this.options.maxFiles == null) || _this.options.maxFiles > 1) { + _this.hiddenFileInput.setAttribute("multiple", "multiple"); + } + _this.hiddenFileInput.className = "dz-hidden-input"; + if (_this.options.acceptedFiles != null) { + _this.hiddenFileInput.setAttribute("accept", _this.options.acceptedFiles); + } + if (_this.options.capture != null) { + _this.hiddenFileInput.setAttribute("capture", _this.options.capture); + } + _this.hiddenFileInput.style.visibility = "hidden"; + _this.hiddenFileInput.style.position = "absolute"; + _this.hiddenFileInput.style.top = "0"; + _this.hiddenFileInput.style.left = "0"; + _this.hiddenFileInput.style.height = "0"; + _this.hiddenFileInput.style.width = "0"; + document.querySelector(_this.options.hiddenInputContainer).appendChild(_this.hiddenFileInput); + return _this.hiddenFileInput.addEventListener("change", function() { + var file, files, _i, _len; + files = _this.hiddenFileInput.files; + if (files.length) { + for (_i = 0, _len = files.length; _i < _len; _i++) { + file = files[_i]; + _this.addFile(file); + } + } + _this.emit("addedfiles", files); + return setupHiddenFileInput(); + }); + }; + })(this); + setupHiddenFileInput(); + } + this.URL = (_ref = window.URL) != null ? _ref : window.webkitURL; + _ref1 = this.events; + for (_i = 0, _len = _ref1.length; _i < _len; _i++) { + eventName = _ref1[_i]; + this.on(eventName, this.options[eventName]); + } + this.on("uploadprogress", (function(_this) { + return function() { + return _this.updateTotalUploadProgress(); + }; + })(this)); + this.on("removedfile", (function(_this) { + return function() { + return _this.updateTotalUploadProgress(); + }; + })(this)); + this.on("canceled", (function(_this) { + return function(file) { + return _this.emit("complete", file); + }; + })(this)); + this.on("complete", (function(_this) { + return function(file) { + if (_this.getAddedFiles().length === 0 && _this.getUploadingFiles().length === 0 && _this.getQueuedFiles().length === 0) { + return setTimeout((function() { + return _this.emit("queuecomplete"); + }), 0); + } + }; + })(this)); + noPropagation = function(e) { + e.stopPropagation(); + if (e.preventDefault) { + return e.preventDefault(); + } else { + return e.returnValue = false; + } + }; + this.listeners = [ + { + element: this.element, + events: { + "dragstart": (function(_this) { + return function(e) { + return _this.emit("dragstart", e); + }; + })(this), + "dragenter": (function(_this) { + return function(e) { + noPropagation(e); + return _this.emit("dragenter", e); + }; + })(this), + "dragover": (function(_this) { + return function(e) { + var efct; + try { + efct = e.dataTransfer.effectAllowed; + } catch (_error) {} + e.dataTransfer.dropEffect = 'move' === efct || 'linkMove' === efct ? 'move' : 'copy'; + noPropagation(e); + return _this.emit("dragover", e); + }; + })(this), + "dragleave": (function(_this) { + return function(e) { + return _this.emit("dragleave", e); + }; + })(this), + "drop": (function(_this) { + return function(e) { + noPropagation(e); + return _this.drop(e); + }; + })(this), + "dragend": (function(_this) { + return function(e) { + return _this.emit("dragend", e); + }; + })(this) + } + } + ]; + this.clickableElements.forEach((function(_this) { + return function(clickableElement) { + return _this.listeners.push({ + element: clickableElement, + events: { + "click": function(evt) { + if ((clickableElement !== _this.element) || (evt.target === _this.element || Dropzone.elementInside(evt.target, _this.element.querySelector(".dz-message")))) { + _this.hiddenFileInput.click(); + } + return true; + } + } + }); + }; + })(this)); + this.enable(); + return this.options.init.call(this); + }; + + Dropzone.prototype.destroy = function() { + var _ref; + this.disable(); + this.removeAllFiles(true); + if ((_ref = this.hiddenFileInput) != null ? _ref.parentNode : void 0) { + this.hiddenFileInput.parentNode.removeChild(this.hiddenFileInput); + this.hiddenFileInput = null; + } + delete this.element.dropzone; + return Dropzone.instances.splice(Dropzone.instances.indexOf(this), 1); + }; + + Dropzone.prototype.updateTotalUploadProgress = function() { + var activeFiles, file, totalBytes, totalBytesSent, totalUploadProgress, _i, _len, _ref; + totalBytesSent = 0; + totalBytes = 0; + activeFiles = this.getActiveFiles(); + if (activeFiles.length) { + _ref = this.getActiveFiles(); + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + file = _ref[_i]; + totalBytesSent += file.upload.bytesSent; + totalBytes += file.upload.total; + } + totalUploadProgress = 100 * totalBytesSent / totalBytes; + } else { + totalUploadProgress = 100; + } + return this.emit("totaluploadprogress", totalUploadProgress, totalBytes, totalBytesSent); + }; + + Dropzone.prototype._getParamName = function(n) { + if (typeof this.options.paramName === "function") { + return this.options.paramName(n); + } else { + return "" + this.options.paramName + (this.options.uploadMultiple ? "[" + n + "]" : ""); + } + }; + + Dropzone.prototype._renameFilename = function(name) { + if (typeof this.options.renameFilename !== "function") { + return name; + } + return this.options.renameFilename(name); + }; + + Dropzone.prototype.getFallbackForm = function() { + var existingFallback, fields, fieldsString, form; + if (existingFallback = this.getExistingFallback()) { + return existingFallback; + } + fieldsString = "
"; + if (this.options.dictFallbackText) { + fieldsString += "

" + this.options.dictFallbackText + "

"; + } + fieldsString += "
"; + fields = Dropzone.createElement(fieldsString); + if (this.element.tagName !== "FORM") { + form = Dropzone.createElement("
"); + form.appendChild(fields); + } else { + this.element.setAttribute("enctype", "multipart/form-data"); + this.element.setAttribute("method", this.options.method); + } + return form != null ? form : fields; + }; + + Dropzone.prototype.getExistingFallback = function() { + var fallback, getFallback, tagName, _i, _len, _ref; + getFallback = function(elements) { + var el, _i, _len; + for (_i = 0, _len = elements.length; _i < _len; _i++) { + el = elements[_i]; + if (/(^| )fallback($| )/.test(el.className)) { + return el; + } + } + }; + _ref = ["div", "form"]; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + tagName = _ref[_i]; + if (fallback = getFallback(this.element.getElementsByTagName(tagName))) { + return fallback; + } + } + }; + + Dropzone.prototype.setupEventListeners = function() { + var elementListeners, event, listener, _i, _len, _ref, _results; + _ref = this.listeners; + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + elementListeners = _ref[_i]; + _results.push((function() { + var _ref1, _results1; + _ref1 = elementListeners.events; + _results1 = []; + for (event in _ref1) { + listener = _ref1[event]; + _results1.push(elementListeners.element.addEventListener(event, listener, false)); + } + return _results1; + })()); + } + return _results; + }; + + Dropzone.prototype.removeEventListeners = function() { + var elementListeners, event, listener, _i, _len, _ref, _results; + _ref = this.listeners; + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + elementListeners = _ref[_i]; + _results.push((function() { + var _ref1, _results1; + _ref1 = elementListeners.events; + _results1 = []; + for (event in _ref1) { + listener = _ref1[event]; + _results1.push(elementListeners.element.removeEventListener(event, listener, false)); + } + return _results1; + })()); + } + return _results; + }; + + Dropzone.prototype.disable = function() { + var file, _i, _len, _ref, _results; + this.clickableElements.forEach(function(element) { + return element.classList.remove("dz-clickable"); + }); + this.removeEventListeners(); + _ref = this.files; + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + file = _ref[_i]; + _results.push(this.cancelUpload(file)); + } + return _results; + }; + + Dropzone.prototype.enable = function() { + this.clickableElements.forEach(function(element) { + return element.classList.add("dz-clickable"); + }); + return this.setupEventListeners(); + }; + + Dropzone.prototype.filesize = function(size) { + var cutoff, i, selectedSize, selectedUnit, unit, units, _i, _len; + selectedSize = 0; + selectedUnit = "b"; + if (size > 0) { + units = ['TB', 'GB', 'MB', 'KB', 'b']; + for (i = _i = 0, _len = units.length; _i < _len; i = ++_i) { + unit = units[i]; + cutoff = Math.pow(this.options.filesizeBase, 4 - i) / 10; + if (size >= cutoff) { + selectedSize = size / Math.pow(this.options.filesizeBase, 4 - i); + selectedUnit = unit; + break; + } + } + selectedSize = Math.round(10 * selectedSize) / 10; + } + return "" + selectedSize + " " + selectedUnit; + }; + + Dropzone.prototype._updateMaxFilesReachedClass = function() { + if ((this.options.maxFiles != null) && this.getAcceptedFiles().length >= this.options.maxFiles) { + if (this.getAcceptedFiles().length === this.options.maxFiles) { + this.emit('maxfilesreached', this.files); + } + return this.element.classList.add("dz-max-files-reached"); + } else { + return this.element.classList.remove("dz-max-files-reached"); + } + }; + + Dropzone.prototype.drop = function(e) { + var files, items; + if (!e.dataTransfer) { + return; + } + this.emit("drop", e); + files = e.dataTransfer.files; + this.emit("addedfiles", files); + if (files.length) { + items = e.dataTransfer.items; + if (items && items.length && (items[0].webkitGetAsEntry != null)) { + this._addFilesFromItems(items); + } else { + this.handleFiles(files); + } + } + }; + + Dropzone.prototype.paste = function(e) { + var items, _ref; + if ((e != null ? (_ref = e.clipboardData) != null ? _ref.items : void 0 : void 0) == null) { + return; + } + this.emit("paste", e); + items = e.clipboardData.items; + if (items.length) { + return this._addFilesFromItems(items); + } + }; + + Dropzone.prototype.handleFiles = function(files) { + var file, _i, _len, _results; + _results = []; + for (_i = 0, _len = files.length; _i < _len; _i++) { + file = files[_i]; + _results.push(this.addFile(file)); + } + return _results; + }; + + Dropzone.prototype._addFilesFromItems = function(items) { + var entry, item, _i, _len, _results; + _results = []; + for (_i = 0, _len = items.length; _i < _len; _i++) { + item = items[_i]; + if ((item.webkitGetAsEntry != null) && (entry = item.webkitGetAsEntry())) { + if (entry.isFile) { + _results.push(this.addFile(item.getAsFile())); + } else if (entry.isDirectory) { + _results.push(this._addFilesFromDirectory(entry, entry.name)); + } else { + _results.push(void 0); + } + } else if (item.getAsFile != null) { + if ((item.kind == null) || item.kind === "file") { + _results.push(this.addFile(item.getAsFile())); + } else { + _results.push(void 0); + } + } else { + _results.push(void 0); + } + } + return _results; + }; + + Dropzone.prototype._addFilesFromDirectory = function(directory, path) { + var dirReader, errorHandler, readEntries; + dirReader = directory.createReader(); + errorHandler = function(error) { + return typeof console !== "undefined" && console !== null ? typeof console.log === "function" ? console.log(error) : void 0 : void 0; + }; + readEntries = (function(_this) { + return function() { + return dirReader.readEntries(function(entries) { + var entry, _i, _len; + if (entries.length > 0) { + for (_i = 0, _len = entries.length; _i < _len; _i++) { + entry = entries[_i]; + if (entry.isFile) { + entry.file(function(file) { + if (_this.options.ignoreHiddenFiles && file.name.substring(0, 1) === '.') { + return; + } + file.fullPath = "" + path + "/" + file.name; + return _this.addFile(file); + }); + } else if (entry.isDirectory) { + _this._addFilesFromDirectory(entry, "" + path + "/" + entry.name); + } + } + readEntries(); + } + return null; + }, errorHandler); + }; + })(this); + return readEntries(); + }; + + Dropzone.prototype.accept = function(file, done) { + if (file.size > this.options.maxFilesize * 1024 * 1024) { + return done(this.options.dictFileTooBig.replace("{{filesize}}", Math.round(file.size / 1024 / 10.24) / 100).replace("{{maxFilesize}}", this.options.maxFilesize)); + } else if (!Dropzone.isValidFile(file, this.options.acceptedFiles)) { + return done(this.options.dictInvalidFileType); + } else if ((this.options.maxFiles != null) && this.getAcceptedFiles().length >= this.options.maxFiles) { + done(this.options.dictMaxFilesExceeded.replace("{{maxFiles}}", this.options.maxFiles)); + return this.emit("maxfilesexceeded", file); + } else { + return this.options.accept.call(this, file, done); + } + }; + + Dropzone.prototype.addFile = function(file) { + file.upload = { + progress: 0, + total: file.size, + bytesSent: 0 + }; + this.files.push(file); + file.status = Dropzone.ADDED; + this.emit("addedfile", file); + this._enqueueThumbnail(file); + return this.accept(file, (function(_this) { + return function(error) { + if (error) { + file.accepted = false; + _this._errorProcessing([file], error); + } else { + file.accepted = true; + if (_this.options.autoQueue) { + _this.enqueueFile(file); + } + } + return _this._updateMaxFilesReachedClass(); + }; + })(this)); + }; + + Dropzone.prototype.enqueueFiles = function(files) { + var file, _i, _len; + for (_i = 0, _len = files.length; _i < _len; _i++) { + file = files[_i]; + this.enqueueFile(file); + } + return null; + }; + + Dropzone.prototype.enqueueFile = function(file) { + if (file.status === Dropzone.ADDED && file.accepted === true) { + file.status = Dropzone.QUEUED; + if (this.options.autoProcessQueue) { + return setTimeout(((function(_this) { + return function() { + return _this.processQueue(); + }; + })(this)), 0); + } + } else { + throw new Error("This file can't be queued because it has already been processed or was rejected."); + } + }; + + Dropzone.prototype._thumbnailQueue = []; + + Dropzone.prototype._processingThumbnail = false; + + Dropzone.prototype._enqueueThumbnail = function(file) { + if (this.options.createImageThumbnails && file.type.match(/image.*/) && file.size <= this.options.maxThumbnailFilesize * 1024 * 1024) { + this._thumbnailQueue.push(file); + return setTimeout(((function(_this) { + return function() { + return _this._processThumbnailQueue(); + }; + })(this)), 0); + } + }; + + Dropzone.prototype._processThumbnailQueue = function() { + if (this._processingThumbnail || this._thumbnailQueue.length === 0) { + return; + } + this._processingThumbnail = true; + return this.createThumbnail(this._thumbnailQueue.shift(), (function(_this) { + return function() { + _this._processingThumbnail = false; + return _this._processThumbnailQueue(); + }; + })(this)); + }; + + Dropzone.prototype.removeFile = function(file) { + if (file.status === Dropzone.UPLOADING) { + this.cancelUpload(file); + } + this.files = without(this.files, file); + this.emit("removedfile", file); + if (this.files.length === 0) { + return this.emit("reset"); + } + }; + + Dropzone.prototype.removeAllFiles = function(cancelIfNecessary) { + var file, _i, _len, _ref; + if (cancelIfNecessary == null) { + cancelIfNecessary = false; + } + _ref = this.files.slice(); + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + file = _ref[_i]; + if (file.status !== Dropzone.UPLOADING || cancelIfNecessary) { + this.removeFile(file); + } + } + return null; + }; + + Dropzone.prototype.createThumbnail = function(file, callback) { + var fileReader; + fileReader = new FileReader; + fileReader.onload = (function(_this) { + return function() { + if (file.type === "image/svg+xml") { + _this.emit("thumbnail", file, fileReader.result); + if (callback != null) { + callback(); + } + return; + } + return _this.createThumbnailFromUrl(file, fileReader.result, callback); + }; + })(this); + return fileReader.readAsDataURL(file); + }; + + Dropzone.prototype.createThumbnailFromUrl = function(file, imageUrl, callback, crossOrigin) { + var img; + img = document.createElement("img"); + if (crossOrigin) { + img.crossOrigin = crossOrigin; + } + img.onload = (function(_this) { + return function() { + var canvas, ctx, resizeInfo, thumbnail, _ref, _ref1, _ref2, _ref3; + file.width = img.width; + file.height = img.height; + resizeInfo = _this.options.resize.call(_this, file); + if (resizeInfo.trgWidth == null) { + resizeInfo.trgWidth = resizeInfo.optWidth; + } + if (resizeInfo.trgHeight == null) { + resizeInfo.trgHeight = resizeInfo.optHeight; + } + canvas = document.createElement("canvas"); + ctx = canvas.getContext("2d"); + canvas.width = resizeInfo.trgWidth; + canvas.height = resizeInfo.trgHeight; + drawImageIOSFix(ctx, img, (_ref = resizeInfo.srcX) != null ? _ref : 0, (_ref1 = resizeInfo.srcY) != null ? _ref1 : 0, resizeInfo.srcWidth, resizeInfo.srcHeight, (_ref2 = resizeInfo.trgX) != null ? _ref2 : 0, (_ref3 = resizeInfo.trgY) != null ? _ref3 : 0, resizeInfo.trgWidth, resizeInfo.trgHeight); + thumbnail = canvas.toDataURL("image/png"); + _this.emit("thumbnail", file, thumbnail); + if (callback != null) { + return callback(); + } + }; + })(this); + if (callback != null) { + img.onerror = callback; + } + return img.src = imageUrl; + }; + + Dropzone.prototype.processQueue = function() { + var i, parallelUploads, processingLength, queuedFiles; + parallelUploads = this.options.parallelUploads; + processingLength = this.getUploadingFiles().length; + i = processingLength; + if (processingLength >= parallelUploads) { + return; + } + queuedFiles = this.getQueuedFiles(); + if (!(queuedFiles.length > 0)) { + return; + } + if (this.options.uploadMultiple) { + return this.processFiles(queuedFiles.slice(0, parallelUploads - processingLength)); + } else { + while (i < parallelUploads) { + if (!queuedFiles.length) { + return; + } + this.processFile(queuedFiles.shift()); + i++; + } + } + }; + + Dropzone.prototype.processFile = function(file) { + return this.processFiles([file]); + }; + + Dropzone.prototype.processFiles = function(files) { + var file, _i, _len; + for (_i = 0, _len = files.length; _i < _len; _i++) { + file = files[_i]; + file.processing = true; + file.status = Dropzone.UPLOADING; + this.emit("processing", file); + } + if (this.options.uploadMultiple) { + this.emit("processingmultiple", files); + } + return this.uploadFiles(files); + }; + + Dropzone.prototype._getFilesWithXhr = function(xhr) { + var file, files; + return files = (function() { + var _i, _len, _ref, _results; + _ref = this.files; + _results = []; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + file = _ref[_i]; + if (file.xhr === xhr) { + _results.push(file); + } + } + return _results; + }).call(this); + }; + + Dropzone.prototype.cancelUpload = function(file) { + var groupedFile, groupedFiles, _i, _j, _len, _len1, _ref; + if (file.status === Dropzone.UPLOADING) { + groupedFiles = this._getFilesWithXhr(file.xhr); + for (_i = 0, _len = groupedFiles.length; _i < _len; _i++) { + groupedFile = groupedFiles[_i]; + groupedFile.status = Dropzone.CANCELED; + } + file.xhr.abort(); + for (_j = 0, _len1 = groupedFiles.length; _j < _len1; _j++) { + groupedFile = groupedFiles[_j]; + this.emit("canceled", groupedFile); + } + if (this.options.uploadMultiple) { + this.emit("canceledmultiple", groupedFiles); + } + } else if ((_ref = file.status) === Dropzone.ADDED || _ref === Dropzone.QUEUED) { + file.status = Dropzone.CANCELED; + this.emit("canceled", file); + if (this.options.uploadMultiple) { + this.emit("canceledmultiple", [file]); + } + } + if (this.options.autoProcessQueue) { + return this.processQueue(); + } + }; + + resolveOption = function() { + var args, option; + option = arguments[0], args = 2 <= arguments.length ? __slice.call(arguments, 1) : []; + if (typeof option === 'function') { + return option.apply(this, args); + } + return option; + }; + + Dropzone.prototype.uploadFile = function(file) { + return this.uploadFiles([file]); + }; + + Dropzone.prototype.uploadFiles = function(files) { + var file, formData, handleError, headerName, headerValue, headers, i, input, inputName, inputType, key, method, option, progressObj, response, updateProgress, url, value, xhr, _i, _j, _k, _l, _len, _len1, _len2, _len3, _m, _ref, _ref1, _ref2, _ref3, _ref4, _ref5; + xhr = new XMLHttpRequest(); + for (_i = 0, _len = files.length; _i < _len; _i++) { + file = files[_i]; + file.xhr = xhr; + } + method = resolveOption(this.options.method, files); + url = resolveOption(this.options.url, files); + xhr.open(method, url, true); + xhr.withCredentials = !!this.options.withCredentials; + response = null; + handleError = (function(_this) { + return function() { + var _j, _len1, _results; + _results = []; + for (_j = 0, _len1 = files.length; _j < _len1; _j++) { + file = files[_j]; + _results.push(_this._errorProcessing(files, response || _this.options.dictResponseError.replace("{{statusCode}}", xhr.status), xhr)); + } + return _results; + }; + })(this); + updateProgress = (function(_this) { + return function(e) { + var allFilesFinished, progress, _j, _k, _l, _len1, _len2, _len3, _results; + if (e != null) { + progress = 100 * e.loaded / e.total; + for (_j = 0, _len1 = files.length; _j < _len1; _j++) { + file = files[_j]; + file.upload = { + progress: progress, + total: e.total, + bytesSent: e.loaded + }; + } + } else { + allFilesFinished = true; + progress = 100; + for (_k = 0, _len2 = files.length; _k < _len2; _k++) { + file = files[_k]; + if (!(file.upload.progress === 100 && file.upload.bytesSent === file.upload.total)) { + allFilesFinished = false; + } + file.upload.progress = progress; + file.upload.bytesSent = file.upload.total; + } + if (allFilesFinished) { + return; + } + } + _results = []; + for (_l = 0, _len3 = files.length; _l < _len3; _l++) { + file = files[_l]; + _results.push(_this.emit("uploadprogress", file, progress, file.upload.bytesSent)); + } + return _results; + }; + })(this); + xhr.onload = (function(_this) { + return function(e) { + var _ref; + if (files[0].status === Dropzone.CANCELED) { + return; + } + if (xhr.readyState !== 4) { + return; + } + response = xhr.responseText; + if (xhr.getResponseHeader("content-type") && ~xhr.getResponseHeader("content-type").indexOf("application/json")) { + try { + response = JSON.parse(response); + } catch (_error) { + e = _error; + response = "Invalid JSON response from server."; + } + } + updateProgress(); + if (!((200 <= (_ref = xhr.status) && _ref < 300))) { + return handleError(); + } else { + return _this._finished(files, response, e); + } + }; + })(this); + xhr.onerror = (function(_this) { + return function() { + if (files[0].status === Dropzone.CANCELED) { + return; + } + return handleError(); + }; + })(this); + progressObj = (_ref = xhr.upload) != null ? _ref : xhr; + progressObj.onprogress = updateProgress; + headers = { + "Accept": "application/json", + "Cache-Control": "no-cache", + "X-Requested-With": "XMLHttpRequest" + }; + if (this.options.headers) { + extend(headers, this.options.headers); + } + for (headerName in headers) { + headerValue = headers[headerName]; + if (headerValue) { + xhr.setRequestHeader(headerName, headerValue); + } + } + formData = new FormData(); + if (this.options.params) { + _ref1 = this.options.params; + for (key in _ref1) { + value = _ref1[key]; + formData.append(key, value); + } + } + for (_j = 0, _len1 = files.length; _j < _len1; _j++) { + file = files[_j]; + this.emit("sending", file, xhr, formData); + } + if (this.options.uploadMultiple) { + this.emit("sendingmultiple", files, xhr, formData); + } + if (this.element.tagName === "FORM") { + _ref2 = this.element.querySelectorAll("input, textarea, select, button"); + for (_k = 0, _len2 = _ref2.length; _k < _len2; _k++) { + input = _ref2[_k]; + inputName = input.getAttribute("name"); + inputType = input.getAttribute("type"); + if (input.tagName === "SELECT" && input.hasAttribute("multiple")) { + _ref3 = input.options; + for (_l = 0, _len3 = _ref3.length; _l < _len3; _l++) { + option = _ref3[_l]; + if (option.selected) { + formData.append(inputName, option.value); + } + } + } else if (!inputType || ((_ref4 = inputType.toLowerCase()) !== "checkbox" && _ref4 !== "radio") || input.checked) { + formData.append(inputName, input.value); + } + } + } + for (i = _m = 0, _ref5 = files.length - 1; 0 <= _ref5 ? _m <= _ref5 : _m >= _ref5; i = 0 <= _ref5 ? ++_m : --_m) { + formData.append(this._getParamName(i), files[i], this._renameFilename(files[i].name)); + } + return this.submitRequest(xhr, formData, files); + }; + + Dropzone.prototype.submitRequest = function(xhr, formData, files) { + return xhr.send(formData); + }; + + Dropzone.prototype._finished = function(files, responseText, e) { + var file, _i, _len; + for (_i = 0, _len = files.length; _i < _len; _i++) { + file = files[_i]; + file.status = Dropzone.SUCCESS; + this.emit("success", file, responseText, e); + this.emit("complete", file); + } + if (this.options.uploadMultiple) { + this.emit("successmultiple", files, responseText, e); + this.emit("completemultiple", files); + } + if (this.options.autoProcessQueue) { + return this.processQueue(); + } + }; + + Dropzone.prototype._errorProcessing = function(files, message, xhr) { + var file, _i, _len; + for (_i = 0, _len = files.length; _i < _len; _i++) { + file = files[_i]; + file.status = Dropzone.ERROR; + this.emit("error", file, message, xhr); + this.emit("complete", file); + } + if (this.options.uploadMultiple) { + this.emit("errormultiple", files, message, xhr); + this.emit("completemultiple", files); + } + if (this.options.autoProcessQueue) { + return this.processQueue(); + } + }; + + return Dropzone; + + })(Emitter); + + Dropzone.version = "4.3.0"; + + Dropzone.options = {}; + + Dropzone.optionsForElement = function(element) { + if (element.getAttribute("id")) { + return Dropzone.options[camelize(element.getAttribute("id"))]; + } else { + return void 0; + } + }; + + Dropzone.instances = []; + + Dropzone.forElement = function(element) { + if (typeof element === "string") { + element = document.querySelector(element); + } + if ((element != null ? element.dropzone : void 0) == null) { + throw new Error("No Dropzone found for given element. This is probably because you're trying to access it before Dropzone had the time to initialize. Use the `init` option to setup any additional observers on your Dropzone."); + } + return element.dropzone; + }; + + Dropzone.autoDiscover = true; + + Dropzone.discover = function() { + var checkElements, dropzone, dropzones, _i, _len, _results; + if (document.querySelectorAll) { + dropzones = document.querySelectorAll(".dropzone"); + } else { + dropzones = []; + checkElements = function(elements) { + var el, _i, _len, _results; + _results = []; + for (_i = 0, _len = elements.length; _i < _len; _i++) { + el = elements[_i]; + if (/(^| )dropzone($| )/.test(el.className)) { + _results.push(dropzones.push(el)); + } else { + _results.push(void 0); + } + } + return _results; + }; + checkElements(document.getElementsByTagName("div")); + checkElements(document.getElementsByTagName("form")); + } + _results = []; + for (_i = 0, _len = dropzones.length; _i < _len; _i++) { + dropzone = dropzones[_i]; + if (Dropzone.optionsForElement(dropzone) !== false) { + _results.push(new Dropzone(dropzone)); + } else { + _results.push(void 0); + } + } + return _results; + }; + + Dropzone.blacklistedBrowsers = [/opera.*Macintosh.*version\/12/i]; + + Dropzone.isBrowserSupported = function() { + var capableBrowser, regex, _i, _len, _ref; + capableBrowser = true; + if (window.File && window.FileReader && window.FileList && window.Blob && window.FormData && document.querySelector) { + if (!("classList" in document.createElement("a"))) { + capableBrowser = false; + } else { + _ref = Dropzone.blacklistedBrowsers; + for (_i = 0, _len = _ref.length; _i < _len; _i++) { + regex = _ref[_i]; + if (regex.test(navigator.userAgent)) { + capableBrowser = false; + continue; + } + } + } + } else { + capableBrowser = false; + } + return capableBrowser; + }; + + without = function(list, rejectedItem) { + var item, _i, _len, _results; + _results = []; + for (_i = 0, _len = list.length; _i < _len; _i++) { + item = list[_i]; + if (item !== rejectedItem) { + _results.push(item); + } + } + return _results; + }; + + camelize = function(str) { + return str.replace(/[\-_](\w)/g, function(match) { + return match.charAt(1).toUpperCase(); + }); + }; + + Dropzone.createElement = function(string) { + var div; + div = document.createElement("div"); + div.innerHTML = string; + return div.childNodes[0]; + }; + + Dropzone.elementInside = function(element, container) { + if (element === container) { + return true; + } + while (element = element.parentNode) { + if (element === container) { + return true; + } + } + return false; + }; + + Dropzone.getElement = function(el, name) { + var element; + if (typeof el === "string") { + element = document.querySelector(el); + } else if (el.nodeType != null) { + element = el; + } + if (element == null) { + throw new Error("Invalid `" + name + "` option provided. Please provide a CSS selector or a plain HTML element."); + } + return element; + }; + + Dropzone.getElements = function(els, name) { + var e, el, elements, _i, _j, _len, _len1, _ref; + if (els instanceof Array) { + elements = []; + try { + for (_i = 0, _len = els.length; _i < _len; _i++) { + el = els[_i]; + elements.push(this.getElement(el, name)); + } + } catch (_error) { + e = _error; + elements = null; + } + } else if (typeof els === "string") { + elements = []; + _ref = document.querySelectorAll(els); + for (_j = 0, _len1 = _ref.length; _j < _len1; _j++) { + el = _ref[_j]; + elements.push(el); + } + } else if (els.nodeType != null) { + elements = [els]; + } + if (!((elements != null) && elements.length)) { + throw new Error("Invalid `" + name + "` option provided. Please provide a CSS selector, a plain HTML element or a list of those."); + } + return elements; + }; + + Dropzone.confirm = function(question, accepted, rejected) { + if (window.confirm(question)) { + return accepted(); + } else if (rejected != null) { + return rejected(); + } + }; + + Dropzone.isValidFile = function(file, acceptedFiles) { + var baseMimeType, mimeType, validType, _i, _len; + if (!acceptedFiles) { + return true; + } + acceptedFiles = acceptedFiles.split(","); + mimeType = file.type; + baseMimeType = mimeType.replace(/\/.*$/, ""); + for (_i = 0, _len = acceptedFiles.length; _i < _len; _i++) { + validType = acceptedFiles[_i]; + validType = validType.trim(); + if (validType.charAt(0) === ".") { + if (file.name.toLowerCase().indexOf(validType.toLowerCase(), file.name.length - validType.length) !== -1) { + return true; + } + } else if (/\/\*$/.test(validType)) { + if (baseMimeType === validType.replace(/\/.*$/, "")) { + return true; + } + } else { + if (mimeType === validType) { + return true; + } + } + } + return false; + }; + + if (typeof jQuery !== "undefined" && jQuery !== null) { + jQuery.fn.dropzone = function(options) { + return this.each(function() { + return new Dropzone(this, options); + }); + }; + } + + if (typeof module !== "undefined" && module !== null) { + module.exports = Dropzone; + } else { + window.Dropzone = Dropzone; + } + + Dropzone.ADDED = "added"; + + Dropzone.QUEUED = "queued"; + + Dropzone.ACCEPTED = Dropzone.QUEUED; + + Dropzone.UPLOADING = "uploading"; + + Dropzone.PROCESSING = Dropzone.UPLOADING; + + Dropzone.CANCELED = "canceled"; + + Dropzone.ERROR = "error"; + + Dropzone.SUCCESS = "success"; + + + /* + + Bugfix for iOS 6 and 7 + Source: http://stackoverflow.com/questions/11929099/html5-canvas-drawimage-ratio-bug-ios + based on the work of https://github.com/stomita/ios-imagefile-megapixel + */ + + detectVerticalSquash = function(img) { + var alpha, canvas, ctx, data, ey, ih, iw, py, ratio, sy; + iw = img.naturalWidth; + ih = img.naturalHeight; + canvas = document.createElement("canvas"); + canvas.width = 1; + canvas.height = ih; + ctx = canvas.getContext("2d"); + ctx.drawImage(img, 0, 0); + data = ctx.getImageData(0, 0, 1, ih).data; + sy = 0; + ey = ih; + py = ih; + while (py > sy) { + alpha = data[(py - 1) * 4 + 3]; + if (alpha === 0) { + ey = py; + } else { + sy = py; + } + py = (ey + sy) >> 1; + } + ratio = py / ih; + if (ratio === 0) { + return 1; + } else { + return ratio; + } + }; + + drawImageIOSFix = function(ctx, img, sx, sy, sw, sh, dx, dy, dw, dh) { + var vertSquashRatio; + vertSquashRatio = detectVerticalSquash(img); + return ctx.drawImage(img, sx, sy, sw, sh, dx, dy, dw, dh / vertSquashRatio); + }; + + + /* + * contentloaded.js + * + * Author: Diego Perini (diego.perini at gmail.com) + * Summary: cross-browser wrapper for DOMContentLoaded + * Updated: 20101020 + * License: MIT + * Version: 1.2 + * + * URL: + * http://javascript.nwbox.com/ContentLoaded/ + * http://javascript.nwbox.com/ContentLoaded/MIT-LICENSE + */ + + contentLoaded = function(win, fn) { + var add, doc, done, init, poll, pre, rem, root, top; + done = false; + top = true; + doc = win.document; + root = doc.documentElement; + add = (doc.addEventListener ? "addEventListener" : "attachEvent"); + rem = (doc.addEventListener ? "removeEventListener" : "detachEvent"); + pre = (doc.addEventListener ? "" : "on"); + init = function(e) { + if (e.type === "readystatechange" && doc.readyState !== "complete") { + return; + } + (e.type === "load" ? win : doc)[rem](pre + e.type, init, false); + if (!done && (done = true)) { + return fn.call(win, e.type || e); + } + }; + poll = function() { + var e; + try { + root.doScroll("left"); + } catch (_error) { + e = _error; + setTimeout(poll, 50); + return; + } + return init("poll"); + }; + if (doc.readyState !== "complete") { + if (doc.createEventObject && root.doScroll) { + try { + top = !win.frameElement; + } catch (_error) {} + if (top) { + poll(); + } + } + doc[add](pre + "DOMContentLoaded", init, false); + doc[add](pre + "readystatechange", init, false); + return win[add](pre + "load", init, false); + } + }; + + Dropzone._autoDiscoverFunction = function() { + if (Dropzone.autoDiscover) { + return Dropzone.discover(); + } + }; + + contentLoaded(window, Dropzone._autoDiscoverFunction); + +}).call(this); + +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6), __webpack_require__("../../../node_modules/webpack/buildin/module.js")(module))) + +/***/ }), + +/***/ "../../../node_modules/expose-loader/index.js?InsertEmbedModal!./client/src/components/InsertEmbedModal/InsertEmbedModal.js-exposed": +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(global) {module.exports = global["InsertEmbedModal"] = __webpack_require__("../../../node_modules/babel-loader/lib/index.js?{\"presets\":[[\"env\",{\"modules\":false}],\"react\"],\"plugins\":[\"transform-object-rest-spread\"],\"comments\":false,\"cacheDirectory\":true}!./client/src/components/InsertEmbedModal/InsertEmbedModal.js"); +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__("../../../node_modules/webpack/buildin/global.js"))) + +/***/ }), + +/***/ "../../../node_modules/expose-loader/index.js?InsertMediaModal!./client/src/containers/InsertMediaModal/InsertMediaModal.js-exposed": +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(global) {module.exports = global["InsertMediaModal"] = __webpack_require__("../../../node_modules/babel-loader/lib/index.js?{\"presets\":[[\"env\",{\"modules\":false}],\"react\"],\"plugins\":[\"transform-object-rest-spread\"],\"comments\":false,\"cacheDirectory\":true}!./client/src/containers/InsertMediaModal/InsertMediaModal.js"); +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__("../../../node_modules/webpack/buildin/global.js"))) + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/columnProperties.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })(); + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } + +var map = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/map.js"); +var filter = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/filter.js"); +var find = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/find.js"); +var sortBy = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/sortBy.js"); +var difference = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/difference.js"); + +var ColumnProperties = (function () { + function ColumnProperties() { + var allColumns = arguments.length <= 0 || arguments[0] === undefined ? [] : arguments[0]; + var filteredColumns = arguments.length <= 1 || arguments[1] === undefined ? [] : arguments[1]; + var childrenColumnName = arguments.length <= 2 || arguments[2] === undefined ? "children" : arguments[2]; + var columnMetadata = arguments.length <= 3 || arguments[3] === undefined ? [] : arguments[3]; + var metadataColumns = arguments.length <= 4 || arguments[4] === undefined ? [] : arguments[4]; + + _classCallCheck(this, ColumnProperties); + + this.allColumns = allColumns; + this.filteredColumns = filteredColumns; + this.childrenColumnName = childrenColumnName; + this.columnMetadata = columnMetadata; + this.metadataColumns = metadataColumns; + } + + _createClass(ColumnProperties, [{ + key: 'getMetadataColumns', + value: function getMetadataColumns() { + var meta = map(filter(this.columnMetadata, { visible: false }), function (item) { + return item.columnName; + }); + if (meta.indexOf(this.childrenColumnName) < 0) { + meta.push(this.childrenColumnName); + } + return meta.concat(this.metadataColumns); + } + }, { + key: 'getVisibleColumnCount', + value: function getVisibleColumnCount() { + return this.getColumns().length; + } + }, { + key: 'getColumnMetadataByName', + value: function getColumnMetadataByName(name) { + return find(this.columnMetadata, { columnName: name }); + } + }, { + key: 'hasColumnMetadata', + value: function hasColumnMetadata() { + return this.columnMetadata !== null && this.columnMetadata.length > 0; + } + }, { + key: 'getMetadataColumnProperty', + value: function getMetadataColumnProperty(columnName, propertyName, defaultValue) { + var meta = this.getColumnMetadataByName(columnName); + + //send back the default value if meta isn't there + if (typeof meta === "undefined" || meta === null) return defaultValue; + + return meta.hasOwnProperty(propertyName) ? meta[propertyName] : defaultValue; + } + }, { + key: 'orderColumns', + value: function orderColumns(cols) { + var _this = this; + + var ORDER_MAX = 100; + + var orderedColumns = sortBy(cols, function (item) { + var metaItem = find(_this.columnMetadata, { columnName: item }); + + if (typeof metaItem === 'undefined' || metaItem === null || isNaN(metaItem.order)) { + return ORDER_MAX; + } + + return metaItem.order; + }); + + return orderedColumns; + } + }, { + key: 'getColumns', + value: function getColumns() { + //if we didn't set default or filter + var filteredColumns = this.filteredColumns.length === 0 ? this.allColumns : this.filteredColumns; + + filteredColumns = difference(filteredColumns, this.metadataColumns); + + filteredColumns = this.orderColumns(filteredColumns); + + return filteredColumns; + } + }]); + + return ColumnProperties; +})(); + +module.exports = ColumnProperties; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/customFilterContainer.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +var React = __webpack_require__(0); + +var CustomFilterContainer = React.createClass({ + displayName: "CustomFilterContainer", + + getDefaultProps: function getDefaultProps() { + return { + "placeholderText": "" + }; + }, + render: function render() { + var that = this; + + if (typeof that.props.customFilterComponent !== 'function') { + console.log("Couldn't find valid template."); + return React.createElement("div", null); + } + + return React.createElement(that.props.customFilterComponent, { + changeFilter: this.props.changeFilter, + results: this.props.results, + currentResults: this.props.currentResults, + placeholderText: this.props.placeholderText }); + } +}); + +module.exports = CustomFilterContainer; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/customPaginationContainer.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + Griddle - Simple Grid Component for React + https://github.com/DynamicTyped/Griddle + Copyright (c) 2014 Ryan Lanciaux | DynamicTyped + + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +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 React = __webpack_require__(0); + +var CustomPaginationContainer = React.createClass({ + displayName: "CustomPaginationContainer", + + getDefaultProps: function getDefaultProps() { + return { + "maxPage": 0, + "nextText": "", + "previousText": "", + "currentPage": 0, + "customPagerComponent": {}, + "customPagerComponentOptions": {} + }; + }, + render: function render() { + var that = this; + + if (typeof that.props.customPagerComponent !== 'function') { + console.log("Couldn't find valid template."); + return React.createElement("div", null); + } + + return React.createElement(that.props.customPagerComponent, _extends({}, this.props.customPagerComponentOptions, { maxPage: this.props.maxPage, nextText: this.props.nextText, previousText: this.props.previousText, currentPage: this.props.currentPage, setPage: this.props.setPage, previous: this.props.previous, next: this.props.next })); + } +}); + +module.exports = CustomPaginationContainer; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/customRowComponentContainer.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + Griddle - Simple Grid Component for React + https://github.com/DynamicTyped/Griddle + Copyright (c) 2014 Ryan Lanciaux | DynamicTyped + + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +var React = __webpack_require__(0); + +var CustomRowComponentContainer = React.createClass({ + displayName: "CustomRowComponentContainer", + + getDefaultProps: function getDefaultProps() { + return { + "data": [], + "metadataColumns": [], + "className": "", + "customComponent": {}, + "globalData": {} + }; + }, + render: function render() { + var that = this; + + if (typeof that.props.customComponent !== 'function') { + console.log("Couldn't find valid template."); + return React.createElement("div", { className: this.props.className }); + } + + var nodes = this.props.data.map(function (row, index) { + return React.createElement(that.props.customComponent, { data: row, metadataColumns: that.props.metadataColumns, key: index, globalData: that.props.globalData }); + }); + + var footer = this.props.showPager && this.props.pagingContent; + return React.createElement("div", { className: this.props.className, style: this.props.style }, nodes); + } +}); + +module.exports = CustomRowComponentContainer; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/deep.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +var forEach = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/forEach.js"); +var isObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObject.js"); +var isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"); +var isFunction = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isFunction.js"); +var isPlainObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isPlainObject.js"); +var forOwn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/forOwn.js"); + +// Credits: https://github.com/documentcloud/underscore-contrib +// Sub module: underscore.object.selectors +// License: MIT (https://github.com/documentcloud/underscore-contrib/blob/master/LICENSE) +// https://github.com/documentcloud/underscore-contrib/blob/master/underscore.object.selectors.js + +// Will take a path like 'element[0][1].subElement["Hey!.What?"]["[hey]"]' +// and return ["element", "0", "1", "subElement", "Hey!.What?", "[hey]"] +function keysFromPath(path) { + // from http://codereview.stackexchange.com/a/63010/8176 + /** + * Repeatedly capture either: + * - a bracketed expression, discarding optional matching quotes inside, or + * - an unbracketed expression, delimited by a dot or a bracket. + */ + var re = /\[("|')(.+)\1\]|([^.\[\]]+)/g; + + var elements = []; + var result; + while ((result = re.exec(path)) !== null) { + elements.push(result[2] || result[3]); + } + return elements; +} + +// Gets the value at any depth in a nested object based on the +// path described by the keys given. Keys may be given as an array +// or as a dot-separated string. +function getPath(obj, ks) { + if (typeof ks == "string") { + if (obj[ks] !== undefined) { + return obj[ks]; + } + ks = keysFromPath(ks); + } + + var i = -1, + length = ks.length; + + // If the obj is null or undefined we have to break as + // a TypeError will result trying to access any property + // Otherwise keep incrementally access the next property in + // ks until complete + while (++i < length && obj != null) { + obj = obj[ks[i]]; + } + return i === length ? obj : void 0; +} + +// Based on the origin underscore _.pick function +// Credit: https://github.com/jashkenas/underscore/blob/master/underscore.js +function powerPick(object, keys) { + var result = {}, + obj = object, + iteratee; + iteratee = function (key, obj) { + return key in obj; + }; + + obj = Object(obj); + + for (var i = 0, length = keys.length; i < length; i++) { + var key = keys[i]; + if (iteratee(key, obj)) result[key] = getPath(obj, key); + } + + return result; +} + +// Gets all the keys for a flattened object structure. +// Doesn't flatten arrays. +// Input: +// { +// a: { +// x: 1, +// y: 2 +// }, +// b: [3, 4], +// c: 5 +// } +// Output: +// [ +// "a.x", +// "a.y", +// "b", +// "c" +// ] +function getKeys(obj, prefix) { + var keys = []; + + forEach(obj, function (value, key) { + var fullKey = prefix ? prefix + "." + key : key; + if (isObject(value) && !isArray(value) && !isFunction(value) && !(value instanceof Date)) { + keys = keys.concat(getKeys(value, fullKey)); + } else { + keys.push(fullKey); + } + }); + + return keys; +} + +// Recursivly traverse plain objects and arrays calling `fn` on each +// non-object/non-array leaf node. +function iterObject(thing, fn) { + if (isArray(thing)) { + forEach(thing, function (item) { + iterObject(item, fn); + }); + } else if (isPlainObject(thing)) { + forOwn(thing, function (item) { + iterObject(item, fn); + }); + } else { + fn(thing); + } +} + +// Recursivly traverse plain objects and arrays and build a list of all +// non-object/non-array leaf nodes. +// +// Input: +// { "array": [1, "two", {"tree": 3}], "string": "a string" } +// +// Output: +// [1, 'two', 3, 'a string'] +// +function getObjectValues(thing) { + var results = []; + iterObject(thing, function (value) { + results.push(value); + }); + return results; +} + +module.exports = { + pick: powerPick, + getAt: getPath, + keys: getKeys, + getObjectValues: getObjectValues +}; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/gridFilter.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +var React = __webpack_require__(0); + +var GridFilter = React.createClass({ + displayName: "GridFilter", + + getDefaultProps: function getDefaultProps() { + return { + "placeholderText": "" + }; + }, + handleChange: function handleChange(event) { + this.props.changeFilter(event.target.value); + }, + render: function render() { + return React.createElement("div", { className: "filter-container" }, React.createElement("input", { type: "text", name: "filter", placeholder: this.props.placeholderText, className: "form-control", onChange: this.handleChange })); + } +}); + +module.exports = GridFilter; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/gridNoData.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +var React = __webpack_require__(0); + +var GridNoData = React.createClass({ + displayName: "GridNoData", + + getDefaultProps: function getDefaultProps() { + return { + "noDataMessage": "No Data" + }; + }, + render: function render() { + var that = this; + + return React.createElement("div", null, this.props.noDataMessage); + } +}); + +module.exports = GridNoData; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/gridPagination.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +var React = __webpack_require__(0); +var assign = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/assign.js"); + +//needs props maxPage, currentPage, nextFunction, prevFunction +var GridPagination = React.createClass({ + displayName: 'GridPagination', + + getDefaultProps: function getDefaultProps() { + return { + "maxPage": 0, + "nextText": "", + "previousText": "", + "currentPage": 0, + "useGriddleStyles": true, + "nextClassName": "griddle-next", + "previousClassName": "griddle-previous", + "nextIconComponent": null, + "previousIconComponent": null + }; + }, + pageChange: function pageChange(event) { + this.props.setPage(parseInt(event.target.value, 10) - 1); + }, + render: function render() { + var previous = ""; + var next = ""; + + if (this.props.currentPage > 0) { + previous = React.createElement('button', { type: 'button', onClick: this.props.previous, style: this.props.useGriddleStyles ? { "color": "#222", border: "none", background: "none", margin: "0 0 0 10px" } : null }, this.props.previousIconComponent, this.props.previousText); + } + + if (this.props.currentPage !== this.props.maxPage - 1) { + next = React.createElement('button', { type: 'button', onClick: this.props.next, style: this.props.useGriddleStyles ? { "color": "#222", border: "none", background: "none", margin: "0 10px 0 0" } : null }, this.props.nextText, this.props.nextIconComponent); + } + + var leftStyle = null; + var middleStyle = null; + var rightStyle = null; + + if (this.props.useGriddleStyles === true) { + var baseStyle = { + "float": "left", + minHeight: "1px", + marginTop: "5px" + }; + + rightStyle = assign({ textAlign: "right", width: "34%" }, baseStyle); + middleStyle = assign({ textAlign: "center", width: "33%" }, baseStyle); + leftStyle = assign({ width: "33%" }, baseStyle); + } + + var options = []; + + for (var i = 1; i <= this.props.maxPage; i++) { + options.push(React.createElement('option', { value: i, key: i }, i)); + } + + return React.createElement('div', { style: this.props.useGriddleStyles ? { minHeight: "35px" } : null }, React.createElement('div', { className: this.props.previousClassName, style: leftStyle }, previous), React.createElement('div', { className: 'griddle-page', style: middleStyle }, React.createElement('select', { value: this.props.currentPage + 1, onChange: this.pageChange }, options), ' / ', this.props.maxPage), React.createElement('div', { className: this.props.nextClassName, style: rightStyle }, next)); + } +}); + +module.exports = GridPagination; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/gridRow.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +var React = __webpack_require__(0); +var ColumnProperties = __webpack_require__("../../../node_modules/griddle-react/modules/columnProperties.js"); +var deep = __webpack_require__("../../../node_modules/griddle-react/modules/deep.js"); +var isFunction = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isFunction.js"); +var zipObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/zipObject.js"); +var assign = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/assign.js"); +var defaults = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/defaults.js"); +var toPairs = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/toPairs.js"); +var without = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/without.js"); + +var GridRow = React.createClass({ + displayName: 'GridRow', + + getDefaultProps: function getDefaultProps() { + return { + "isChildRow": false, + "showChildren": false, + "data": {}, + "columnSettings": null, + "rowSettings": null, + "hasChildren": false, + "useGriddleStyles": true, + "useGriddleIcons": true, + "isSubGriddle": false, + "paddingHeight": null, + "rowHeight": null, + "parentRowCollapsedClassName": "parent-row", + "parentRowExpandedClassName": "parent-row expanded", + "parentRowCollapsedComponent": "â–¶", + "parentRowExpandedComponent": "â–¼", + "onRowClick": null, + "multipleSelectionSettings": null + }; + }, + handleClick: function handleClick(e) { + if (this.props.onRowClick !== null && isFunction(this.props.onRowClick)) { + this.props.onRowClick(this, e); + } else if (this.props.hasChildren) { + this.props.toggleChildren(); + } + }, + handleSelectionChange: function handleSelectionChange(e) { + //hack to get around warning that's not super useful in this case + return; + }, + handleSelectClick: function handleSelectClick(e) { + if (this.props.multipleSelectionSettings.isMultipleSelection) { + if (e.target.type === "checkbox") { + this.props.multipleSelectionSettings.toggleSelectRow(this.props.data, this.refs.selected.checked); + } else { + this.props.multipleSelectionSettings.toggleSelectRow(this.props.data, !this.refs.selected.checked); + } + } + }, + verifyProps: function verifyProps() { + if (this.props.columnSettings === null) { + console.error("gridRow: The columnSettings prop is null and it shouldn't be"); + } + }, + formatData: function formatData(data) { + if (typeof data === 'boolean') { + return String(data); + } + return data; + }, + render: function render() { + var _this = this; + + this.verifyProps(); + var that = this; + var columnStyles = null; + + if (this.props.useGriddleStyles) { + columnStyles = { + margin: "0px", + padding: that.props.paddingHeight + "px 5px " + that.props.paddingHeight + "px 5px", + height: that.props.rowHeight ? this.props.rowHeight - that.props.paddingHeight * 2 + "px" : null, + backgroundColor: "#FFF", + borderTopColor: "#DDD", + color: "#222" + }; + } + + var columns = this.props.columnSettings.getColumns(); + + // make sure that all the columns we need have default empty values + // otherwise they will get clipped + var defaultValues = zipObject(columns, []); + + // creates a 'view' on top the data so we will not alter the original data but will allow us to add default values to missing columns + var dataView = assign({}, this.props.data); + + defaults(dataView, defaultValues); + var data = toPairs(deep.pick(dataView, without(columns, 'children'))); + var nodes = data.map(function (col, index) { + var returnValue = null; + var meta = _this.props.columnSettings.getColumnMetadataByName(col[0]); + + //todo: Make this not as ridiculous looking + var firstColAppend = index === 0 && _this.props.hasChildren && _this.props.showChildren === false && _this.props.useGriddleIcons ? React.createElement('span', { style: _this.props.useGriddleStyles ? { fontSize: "10px", marginRight: "5px" } : null }, _this.props.parentRowCollapsedComponent) : index === 0 && _this.props.hasChildren && _this.props.showChildren && _this.props.useGriddleIcons ? React.createElement('span', { style: _this.props.useGriddleStyles ? { fontSize: "10px" } : null }, _this.props.parentRowExpandedComponent) : ""; + + if (index === 0 && _this.props.isChildRow && _this.props.useGriddleStyles) { + columnStyles = assign(columnStyles, { paddingLeft: 10 }); + } + + if (_this.props.columnSettings.hasColumnMetadata() && typeof meta !== 'undefined' && meta !== null) { + if (typeof meta.customComponent !== 'undefined' && meta.customComponent !== null) { + var customComponent = React.createElement(meta.customComponent, { data: col[1], rowData: dataView, metadata: meta }); + returnValue = React.createElement('td', { onClick: _this.handleClick, className: meta.cssClassName, key: index, style: columnStyles }, customComponent); + } else { + returnValue = React.createElement('td', { onClick: _this.handleClick, className: meta.cssClassName, key: index, style: columnStyles }, firstColAppend, _this.formatData(col[1])); + } + } + + return returnValue || React.createElement('td', { onClick: _this.handleClick, key: index, style: columnStyles }, firstColAppend, col[1]); + }); + + // Don't compete with onRowClick, but if no onRowClick function then + // clicking on the row should trigger select + var trOnClick, tdOnClick; + if (this.props.onRowClick !== null && isFunction(this.props.onRowClick)) { + trOnClick = null; + tdOnClick = this.handleSelectClick; + } else { + if (this.props.multipleSelectionSettings && this.props.multipleSelectionSettings.isMultipleSelection) { + trOnClick = this.handleSelectClick; + tdOnClick = null; + } else { + trOnClick = null; + tdOnClick = null; + } + } + + if (nodes && this.props.multipleSelectionSettings && this.props.multipleSelectionSettings.isMultipleSelection) { + var selectedRowIds = this.props.multipleSelectionSettings.getSelectedRowIds(); + + nodes.unshift(React.createElement('td', { + key: 'selection', + style: columnStyles, + className: 'griddle-select griddle-select-cell', + onClick: tdOnClick + }, React.createElement('input', { + type: 'checkbox', + checked: this.props.multipleSelectionSettings.getIsRowChecked(dataView), + onChange: this.handleSelectionChange, + ref: 'selected' + }))); + } + + //Get the row from the row settings. + var className = that.props.rowSettings && that.props.rowSettings.getBodyRowMetadataClass(that.props.data) || "standard-row"; + + if (that.props.isChildRow) { + className = "child-row"; + } else if (that.props.hasChildren) { + className = that.props.showChildren ? this.props.parentRowExpandedClassName : this.props.parentRowCollapsedClassName; + } + + return React.createElement('tr', { onClick: trOnClick, className: className }, nodes); + } +}); + +module.exports = GridRow; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/gridRowContainer.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +var React = __webpack_require__(0); +var ColumnProperties = __webpack_require__("../../../node_modules/griddle-react/modules/columnProperties.js"); +var pick = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/pick.js"); + +var GridRowContainer = React.createClass({ + displayName: 'GridRowContainer', + + getDefaultProps: function getDefaultProps() { + return { + "useGriddleStyles": true, + "useGriddleIcons": true, + "isSubGriddle": false, + "columnSettings": null, + "rowSettings": null, + "paddingHeight": null, + "rowHeight": null, + "parentRowCollapsedClassName": "parent-row", + "parentRowExpandedClassName": "parent-row expanded", + "parentRowCollapsedComponent": "â–¶", + "parentRowExpandedComponent": "â–¼", + "onRowClick": null, + "multipleSelectionSettings": null + }; + }, + getInitialState: function getInitialState() { + return { + "data": {}, + "showChildren": false + }; + }, + componentWillReceiveProps: function componentWillReceiveProps() { + this.setShowChildren(false); + }, + toggleChildren: function toggleChildren() { + this.setShowChildren(this.state.showChildren === false); + }, + setShowChildren: function setShowChildren(visible) { + this.setState({ + showChildren: visible + }); + }, + verifyProps: function verifyProps() { + if (this.props.columnSettings === null) { + console.error("gridRowContainer: The columnSettings prop is null and it shouldn't be"); + } + }, + render: function render() { + this.verifyProps(); + var that = this; + if (typeof this.props.data === "undefined") { + return React.createElement('tbody', null); + } + var arr = []; + + var columns = this.props.columnSettings.getColumns(); + + arr.push(React.createElement(this.props.rowSettings.rowComponent, { + useGriddleStyles: this.props.useGriddleStyles, + isSubGriddle: this.props.isSubGriddle, + data: this.props.rowSettings.isCustom ? pick(this.props.data, columns) : this.props.data, + rowData: this.props.rowSettings.isCustom ? this.props.data : null, + columnSettings: this.props.columnSettings, + rowSettings: this.props.rowSettings, + hasChildren: that.props.hasChildren, + toggleChildren: that.toggleChildren, + showChildren: that.state.showChildren, + key: that.props.uniqueId + '_base_row', + useGriddleIcons: that.props.useGriddleIcons, + parentRowExpandedClassName: this.props.parentRowExpandedClassName, + parentRowCollapsedClassName: this.props.parentRowCollapsedClassName, + parentRowExpandedComponent: this.props.parentRowExpandedComponent, + parentRowCollapsedComponent: this.props.parentRowCollapsedComponent, + paddingHeight: that.props.paddingHeight, + rowHeight: that.props.rowHeight, + onRowClick: that.props.onRowClick, + multipleSelectionSettings: this.props.multipleSelectionSettings })); + + var children = null; + + if (that.state.showChildren) { + children = that.props.hasChildren && this.props.data["children"].map(function (row, index) { + var key = that.props.rowSettings.getRowKey(row, index); + + if (typeof row["children"] !== "undefined") { + var Griddle = that.constructor.Griddle; + return React.createElement('tr', { key: key, style: { paddingLeft: 5 } }, React.createElement('td', { colSpan: that.props.columnSettings.getVisibleColumnCount(), className: 'griddle-parent', style: that.props.useGriddleStyles ? { border: "none", "padding": "0 0 0 5px" } : null }, React.createElement(Griddle, { + rowMetadata: { key: 'id' }, + isSubGriddle: true, + results: [row], + columns: that.props.columnSettings.getColumns(), + tableClassName: that.props.tableClassName, + parentRowExpandedClassName: that.props.parentRowExpandedClassName, + parentRowCollapsedClassName: that.props.parentRowCollapsedClassName, + showTableHeading: false, + showPager: false, + columnMetadata: that.props.columnSettings.columnMetadata, + parentRowExpandedComponent: that.props.parentRowExpandedComponent, + parentRowCollapsedComponent: that.props.parentRowCollapsedComponent, + paddingHeight: that.props.paddingHeight, + rowHeight: that.props.rowHeight + }))); + } + + return React.createElement(that.props.rowSettings.rowComponent, { + useGriddleStyles: that.props.useGriddleStyles, + isSubGriddle: that.props.isSubGriddle, + data: row, + columnSettings: that.props.columnSettings, + isChildRow: true, + columnMetadata: that.props.columnSettings.columnMetadata, + key: key + }); + }); + } + + return that.props.hasChildren === false ? arr[0] : React.createElement('tbody', null, that.state.showChildren ? arr.concat(children) : arr); + } +}); + +module.exports = GridRowContainer; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/gridSettings.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +var React = __webpack_require__(0); +var includes = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/includes.js"); +var without = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/without.js"); +var find = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/find.js"); + +var GridSettings = React.createClass({ + displayName: 'GridSettings', + + getDefaultProps: function getDefaultProps() { + return { + "columns": [], + "columnMetadata": [], + "selectedColumns": [], + "settingsText": "", + "maxRowsText": "", + "resultsPerPage": 0, + "enableToggleCustom": false, + "useCustomComponent": false, + "useGriddleStyles": true, + "toggleCustomComponent": function toggleCustomComponent() {} + }; + }, + setPageSize: function setPageSize(event) { + var value = parseInt(event.target.value, 10); + this.props.setPageSize(value); + }, + handleChange: function handleChange(event) { + var columnName = event.target.dataset ? event.target.dataset.name : event.target.getAttribute('data-name'); + if (event.target.checked === true && includes(this.props.selectedColumns, columnName) === false) { + this.props.selectedColumns.push(columnName); + this.props.setColumns(this.props.selectedColumns); + } else { + /* redraw with the selected columns minus the one just unchecked */ + this.props.setColumns(without(this.props.selectedColumns, columnName)); + } + }, + render: function render() { + var that = this; + + var nodes = []; + //don't show column selector if we're on a custom component + if (that.props.useCustomComponent === false) { + nodes = this.props.columns.map(function (col, index) { + var checked = includes(that.props.selectedColumns, col); + //check column metadata -- if this one is locked make it disabled and don't put an onChange event + var meta = find(that.props.columnMetadata, { columnName: col }); + var displayName = col; + + if (typeof meta !== "undefined" && typeof meta.displayName !== "undefined" && meta.displayName != null) { + displayName = meta.displayName; + } + + if (typeof meta !== "undefined" && meta != null && meta.locked) { + return React.createElement('div', { className: 'column checkbox' }, React.createElement('label', null, React.createElement('input', { type: 'checkbox', disabled: true, name: 'check', checked: checked, 'data-name': col }), displayName)); + } else if (typeof meta !== "undefined" && meta != null && typeof meta.visible !== "undefined" && meta.visible === false) { + return null; + } + return React.createElement('div', { className: 'griddle-column-selection checkbox', key: col, style: that.props.useGriddleStyles ? { "float": "left", width: "20%" } : null }, React.createElement('label', null, React.createElement('input', { type: 'checkbox', name: 'check', onChange: that.handleChange, checked: checked, 'data-name': col }), displayName)); + }); + } + + var toggleCustom = that.props.enableToggleCustom ? React.createElement('div', { className: 'form-group' }, React.createElement('label', { htmlFor: 'maxRows' }, React.createElement('input', { type: 'checkbox', checked: this.props.useCustomComponent, onChange: this.props.toggleCustomComponent }), ' ', this.props.enableCustomFormatText)) : ""; + + var setPageSize = this.props.showSetPageSize ? React.createElement('div', null, React.createElement('label', { htmlFor: 'maxRows' }, this.props.maxRowsText, ':', React.createElement('select', { onChange: this.setPageSize, value: this.props.resultsPerPage }, React.createElement('option', { value: '5' }, '5'), React.createElement('option', { value: '10' }, '10'), React.createElement('option', { value: '25' }, '25'), React.createElement('option', { value: '50' }, '50'), React.createElement('option', { value: '100' }, '100')))) : ""; + + return React.createElement('div', { className: 'griddle-settings', style: this.props.useGriddleStyles ? { backgroundColor: "#FFF", border: "1px solid #DDD", color: "#222", padding: "10px", marginBottom: "10px" } : null }, React.createElement('h6', null, this.props.settingsText), React.createElement('div', { className: 'griddle-columns', style: this.props.useGriddleStyles ? { clear: "both", display: "table", width: "100%", borderBottom: "1px solid #EDEDED", marginBottom: "10px" } : null }, nodes), setPageSize, toggleCustom); + } +}); + +module.exports = GridSettings; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/gridTable.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +var React = __webpack_require__(0); +var GridTitle = __webpack_require__("../../../node_modules/griddle-react/modules/gridTitle.jsx.js"); +var GridRowContainer = __webpack_require__("../../../node_modules/griddle-react/modules/gridRowContainer.jsx.js"); +var ColumnProperties = __webpack_require__("../../../node_modules/griddle-react/modules/columnProperties.js"); +var RowProperties = __webpack_require__("../../../node_modules/griddle-react/modules/rowProperties.js"); + +var GridTable = React.createClass({ + displayName: 'GridTable', + + getDefaultProps: function getDefaultProps() { + return { + "data": [], + "columnSettings": null, + "rowSettings": null, + "sortSettings": null, + "multipleSelectionSettings": null, + "className": "", + "enableInfiniteScroll": false, + "nextPage": null, + "hasMorePages": false, + "useFixedHeader": false, + "useFixedLayout": true, + "paddingHeight": null, + "rowHeight": null, + "filterByColumn": null, + "infiniteScrollLoadTreshold": null, + "bodyHeight": null, + "useGriddleStyles": true, + "useGriddleIcons": true, + "isSubGriddle": false, + "parentRowCollapsedClassName": "parent-row", + "parentRowExpandedClassName": "parent-row expanded", + "parentRowCollapsedComponent": "â–¶", + "parentRowExpandedComponent": "â–¼", + "externalLoadingComponent": null, + "externalIsLoading": false, + "onRowClick": null + }; + }, + getInitialState: function getInitialState() { + return { + scrollTop: 0, + scrollHeight: this.props.bodyHeight, + clientHeight: this.props.bodyHeight + }; + }, + componentDidMount: function componentDidMount() { + // After the initial render, see if we need to load additional pages. + this.gridScroll(); + }, + componentDidUpdate: function componentDidUpdate(prevProps, prevState) { + // After the subsequent renders, see if we need to load additional pages. + this.gridScroll(); + }, + gridScroll: function gridScroll() { + if (this.props.enableInfiniteScroll && !this.props.externalIsLoading) { + // If the scroll height is greater than the current amount of rows displayed, update the page. + var scrollable = this.refs.scrollable; + var scrollTop = scrollable.scrollTop; + var scrollHeight = scrollable.scrollHeight; + var clientHeight = scrollable.clientHeight; + + // If the scroll position changed and the difference is greater than a row height + if (this.props.rowHeight !== null && this.state.scrollTop !== scrollTop && Math.abs(this.state.scrollTop - scrollTop) >= this.getAdjustedRowHeight()) { + var newState = { + scrollTop: scrollTop, + scrollHeight: scrollHeight, + clientHeight: clientHeight + }; + + // Set the state to the new state + this.setState(newState); + } + + // Determine the diff by subtracting the amount scrolled by the total height, taking into consideratoin + // the spacer's height. + var scrollHeightDiff = scrollHeight - (scrollTop + clientHeight) - this.props.infiniteScrollLoadTreshold; + + // Make sure that we load results a little before reaching the bottom. + var compareHeight = scrollHeightDiff * 0.6; + + if (compareHeight <= this.props.infiniteScrollLoadTreshold) { + this.props.nextPage(); + } + } + }, + verifyProps: function verifyProps() { + if (this.props.columnSettings === null) { + console.error("gridTable: The columnSettings prop is null and it shouldn't be"); + } + if (this.props.rowSettings === null) { + console.error("gridTable: The rowSettings prop is null and it shouldn't be"); + } + }, + getAdjustedRowHeight: function getAdjustedRowHeight() { + return this.props.rowHeight + this.props.paddingHeight * 2; // account for padding. + }, + getNodeContent: function getNodeContent() { + this.verifyProps(); + var that = this; + + //figure out if we need to wrap the group in one tbody or many + var anyHasChildren = false; + + // If the data is still being loaded, don't build the nodes unless this is an infinite scroll table. + if (!this.props.externalIsLoading || this.props.enableInfiniteScroll) { + var nodeData = that.props.data; + var aboveSpacerRow = null; + var belowSpacerRow = null; + var usingDefault = false; + + // If we have a row height specified, only render what's going to be visible. + if (this.props.enableInfiniteScroll && this.props.rowHeight !== null && this.refs.scrollable !== undefined) { + var adjustedHeight = that.getAdjustedRowHeight(); + var visibleRecordCount = Math.ceil(that.state.clientHeight / adjustedHeight); + + // Inspired by : http://jsfiddle.net/vjeux/KbWJ2/9/ + var displayStart = Math.max(0, Math.floor(that.state.scrollTop / adjustedHeight) - visibleRecordCount * 0.25); + var displayEnd = Math.min(displayStart + visibleRecordCount * 1.25, this.props.data.length - 1); + + // Split the amount of nodes. + nodeData = nodeData.slice(displayStart, displayEnd + 1); + + // Set the above and below nodes. + var aboveSpacerRowStyle = { height: displayStart * adjustedHeight + "px" }; + aboveSpacerRow = React.createElement('tr', { key: 'above-' + aboveSpacerRowStyle.height, style: aboveSpacerRowStyle }); + var belowSpacerRowStyle = { height: (this.props.data.length - displayEnd) * adjustedHeight + "px" }; + belowSpacerRow = React.createElement('tr', { key: 'below-' + belowSpacerRowStyle.height, style: belowSpacerRowStyle }); + } + + var nodes = nodeData.map(function (row, index) { + var hasChildren = typeof row["children"] !== "undefined" && row["children"].length > 0; + var uniqueId = that.props.rowSettings.getRowKey(row, index); + + //at least one item in the group has children. + if (hasChildren) { + anyHasChildren = hasChildren; + } + + return React.createElement(GridRowContainer, { + useGriddleStyles: that.props.useGriddleStyles, + isSubGriddle: that.props.isSubGriddle, + parentRowExpandedClassName: that.props.parentRowExpandedClassName, + parentRowCollapsedClassName: that.props.parentRowCollapsedClassName, + parentRowExpandedComponent: that.props.parentRowExpandedComponent, + parentRowCollapsedComponent: that.props.parentRowCollapsedComponent, + data: row, + key: uniqueId + '-container', + uniqueId: uniqueId, + columnSettings: that.props.columnSettings, + rowSettings: that.props.rowSettings, + paddingHeight: that.props.paddingHeight, + multipleSelectionSettings: that.props.multipleSelectionSettings, + rowHeight: that.props.rowHeight, + hasChildren: hasChildren, + tableClassName: that.props.className, + onRowClick: that.props.onRowClick + }); + }); + + // no data section + if (this.props.showNoData) { + var colSpan = this.props.columnSettings.getVisibleColumnCount(); + nodes.push(React.createElement('tr', { key: 'no-data-section' }, React.createElement('td', { colSpan: colSpan }, this.props.noDataSection))); + } + + // Add the spacer rows for nodes we're not rendering. + if (aboveSpacerRow) { + nodes.unshift(aboveSpacerRow); + } + if (belowSpacerRow) { + nodes.push(belowSpacerRow); + } + + // Send back the nodes. + return { + nodes: nodes, + anyHasChildren: anyHasChildren + }; + } else { + return null; + } + }, + render: function render() { + var that = this; + var nodes = []; + + // for if we need to wrap the group in one tbody or many + var anyHasChildren = false; + + // Grab the nodes to render + var nodeContent = this.getNodeContent(); + if (nodeContent) { + nodes = nodeContent.nodes; + anyHasChildren = nodeContent.anyHasChildren; + } + + var gridStyle = null; + var loadingContent = null; + var tableStyle = { + width: "100%" + }; + + if (this.props.useFixedLayout) { + tableStyle.tableLayout = "fixed"; + } + + if (this.props.enableInfiniteScroll) { + // If we're enabling infinite scrolling, we'll want to include the max height of the grid body + allow scrolling. + gridStyle = { + "position": "relative", + "overflowY": "scroll", + "height": this.props.bodyHeight + "px", + "width": "100%" + }; + } + + // If we're currently loading, populate the loading content + if (this.props.externalIsLoading) { + var defaultLoadingStyle = null; + var defaultColSpan = null; + + if (this.props.useGriddleStyles) { + defaultLoadingStyle = { + textAlign: "center", + paddingBottom: "40px" + }; + } + + defaultColSpan = this.props.columnSettings.getVisibleColumnCount(); + + var loadingComponent = this.props.externalLoadingComponent ? React.createElement(this.props.externalLoadingComponent, null) : React.createElement('div', null, 'Loading...'); + + loadingContent = React.createElement('tbody', null, React.createElement('tr', null, React.createElement('td', { style: defaultLoadingStyle, colSpan: defaultColSpan }, loadingComponent))); + } + + //construct the table heading component + var tableHeading = this.props.showTableHeading ? React.createElement(GridTitle, { useGriddleStyles: this.props.useGriddleStyles, useGriddleIcons: this.props.useGriddleIcons, + sortSettings: this.props.sortSettings, + multipleSelectionSettings: this.props.multipleSelectionSettings, + columnSettings: this.props.columnSettings, + filterByColumn: this.props.filterByColumn, + rowSettings: this.props.rowSettings }) : undefined; + + //check to see if any of the rows have children... if they don't wrap everything in a tbody so the browser doesn't auto do this + if (!anyHasChildren) { + nodes = React.createElement('tbody', null, nodes); + } + + var pagingContent = React.createElement('tbody', null); + if (this.props.showPager) { + var pagingStyles = this.props.useGriddleStyles ? { + padding: "0px", + backgroundColor: "#EDEDED", + border: "0px", + color: "#222", + height: this.props.showNoData ? "20px" : null + } : null; + pagingContent = React.createElement('tbody', null, React.createElement('tr', null, React.createElement('td', { colSpan: this.props.multipleSelectionSettings.isMultipleSelection ? this.props.columnSettings.getVisibleColumnCount() + 1 : this.props.columnSettings.getVisibleColumnCount(), style: pagingStyles, className: 'footer-container' }, !this.props.showNoData ? this.props.pagingContent : null))); + } + + // If we have a fixed header, split into two tables. + if (this.props.useFixedHeader) { + if (this.props.useGriddleStyles) { + tableStyle.tableLayout = "fixed"; + } + + return React.createElement('div', null, React.createElement('table', { className: this.props.className, style: this.props.useGriddleStyles && tableStyle || null }, tableHeading), React.createElement('div', { ref: 'scrollable', onScroll: this.gridScroll, style: gridStyle }, React.createElement('table', { className: this.props.className, style: this.props.useGriddleStyles && tableStyle || null }, nodes, loadingContent, pagingContent))); + } + + return React.createElement('div', { ref: 'scrollable', onScroll: this.gridScroll, style: gridStyle }, React.createElement('table', { className: this.props.className, style: this.props.useGriddleStyles && tableStyle || null }, tableHeading, nodes, loadingContent, pagingContent)); + } +}); + +module.exports = GridTable; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/gridTitle.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE + */ + + +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 React = __webpack_require__(0); +var ColumnProperties = __webpack_require__("../../../node_modules/griddle-react/modules/columnProperties.js"); +var assign = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/assign.js"); + +var DefaultHeaderComponent = React.createClass({ + displayName: 'DefaultHeaderComponent', + + render: function render() { + return React.createElement('span', null, this.props.displayName); + } +}); + +var GridTitle = React.createClass({ + displayName: 'GridTitle', + + getDefaultProps: function getDefaultProps() { + return { + "columnSettings": null, + "filterByColumn": function filterByColumn() {}, + "rowSettings": null, + "sortSettings": null, + "multipleSelectionSettings": null, + "headerStyle": null, + "useGriddleStyles": true, + "useGriddleIcons": true, + "headerStyles": {} + }; + }, + componentWillMount: function componentWillMount() { + this.verifyProps(); + }, + sort: function sort(column) { + var that = this; + return function (event) { + that.props.sortSettings.changeSort(column); + }; + }, + toggleSelectAll: function toggleSelectAll(event) { + this.props.multipleSelectionSettings.toggleSelectAll(); + }, + handleSelectionChange: function handleSelectionChange(event) { + //hack to get around warning message that's not helpful in this case + return; + }, + verifyProps: function verifyProps() { + if (this.props.columnSettings === null) { + console.error("gridTitle: The columnSettings prop is null and it shouldn't be"); + } + + if (this.props.sortSettings === null) { + console.error("gridTitle: The sortSettings prop is null and it shouldn't be"); + } + }, + render: function render() { + this.verifyProps(); + var that = this; + var titleStyles = {}; + + var nodes = this.props.columnSettings.getColumns().map(function (col, index) { + var defaultTitleStyles = {}; + var columnSort = ""; + var columnIsSortable = that.props.columnSettings.getMetadataColumnProperty(col, "sortable", true); + var sortComponent = columnIsSortable ? that.props.sortSettings.sortDefaultComponent : null; + + if (that.props.sortSettings.sortColumn == col && that.props.sortSettings.sortDirection === 'asc') { + columnSort = that.props.sortSettings.sortAscendingClassName; + sortComponent = that.props.useGriddleIcons && that.props.sortSettings.sortAscendingComponent; + } else if (that.props.sortSettings.sortColumn == col && that.props.sortSettings.sortDirection === 'desc') { + columnSort += that.props.sortSettings.sortDescendingClassName; + sortComponent = that.props.useGriddleIcons && that.props.sortSettings.sortDescendingComponent; + } + + var meta = that.props.columnSettings.getColumnMetadataByName(col); + var displayName = that.props.columnSettings.getMetadataColumnProperty(col, "displayName", col); + var HeaderComponent = that.props.columnSettings.getMetadataColumnProperty(col, "customHeaderComponent", DefaultHeaderComponent); + var headerProps = that.props.columnSettings.getMetadataColumnProperty(col, "customHeaderComponentProps", {}); + + columnSort = meta == null ? columnSort : (columnSort && columnSort + " " || columnSort) + that.props.columnSettings.getMetadataColumnProperty(col, "cssClassName", ""); + + if (that.props.useGriddleStyles) { + defaultTitleStyles = { + backgroundColor: "#EDEDEF", + border: "0px", + borderBottom: "1px solid #DDD", + color: "#222", + padding: "5px", + cursor: columnIsSortable ? "pointer" : "default" + }; + } + titleStyles = meta && meta.titleStyles ? assign({}, defaultTitleStyles, meta.titleStyles) : assign({}, defaultTitleStyles); + + var ComponentClass = displayName ? 'th' : 'td'; + return React.createElement(ComponentClass, { onClick: columnIsSortable ? that.sort(col) : null, 'data-title': col, className: columnSort, key: col, + style: titleStyles }, React.createElement(HeaderComponent, _extends({ columnName: col, displayName: displayName, + filterByColumn: that.props.filterByColumn }, headerProps)), sortComponent); + }); + + if (nodes && this.props.multipleSelectionSettings.isMultipleSelection) { + nodes.unshift(React.createElement('th', { key: 'selection', onClick: this.toggleSelectAll, style: titleStyles, className: 'griddle-select griddle-select-title' }, React.createElement('input', { + type: 'checkbox', + checked: this.props.multipleSelectionSettings.getIsSelectAllChecked(), + onChange: this.handleSelectionChange + }))); + } + + //Get the row from the row settings. + var className = that.props.rowSettings && that.props.rowSettings.getHeaderRowMetadataClass() || null; + + return React.createElement('thead', null, React.createElement('tr', { + className: className, + style: this.props.headerStyles }, nodes)); + } +}); + +module.exports = GridTitle; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/griddle.jsx.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +/* + Griddle - Simple Grid Component for React + https://github.com/DynamicTyped/Griddle + Copyright (c) 2014 Ryan Lanciaux | DynamicTyped + + See License / Disclaimer https://raw.githubusercontent.com/DynamicTyped/Griddle/master/LICENSE +*/ + + +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 React = __webpack_require__(0); +var GridTable = __webpack_require__("../../../node_modules/griddle-react/modules/gridTable.jsx.js"); +var GridFilter = __webpack_require__("../../../node_modules/griddle-react/modules/gridFilter.jsx.js"); +var GridPagination = __webpack_require__("../../../node_modules/griddle-react/modules/gridPagination.jsx.js"); +var GridSettings = __webpack_require__("../../../node_modules/griddle-react/modules/gridSettings.jsx.js"); +var GridNoData = __webpack_require__("../../../node_modules/griddle-react/modules/gridNoData.jsx.js"); +var GridRow = __webpack_require__("../../../node_modules/griddle-react/modules/gridRow.jsx.js"); +var GridRowContainer = __webpack_require__("../../../node_modules/griddle-react/modules/gridRowContainer.jsx.js"); +var CustomRowComponentContainer = __webpack_require__("../../../node_modules/griddle-react/modules/customRowComponentContainer.jsx.js"); +var CustomPaginationContainer = __webpack_require__("../../../node_modules/griddle-react/modules/customPaginationContainer.jsx.js"); +var CustomFilterContainer = __webpack_require__("../../../node_modules/griddle-react/modules/customFilterContainer.jsx.js"); +var ColumnProperties = __webpack_require__("../../../node_modules/griddle-react/modules/columnProperties.js"); +var RowProperties = __webpack_require__("../../../node_modules/griddle-react/modules/rowProperties.js"); +var deep = __webpack_require__("../../../node_modules/griddle-react/modules/deep.js"); + +var drop = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/drop.js"); +var dropRight = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/dropRight.js"); +var find = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/find.js"); +var first = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/take.js"); +var forEach = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/forEach.js"); +var initial = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/initial.js"); +var intersection = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/intersection.js"); +var isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"); +var isEmpty = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isEmpty.js"); +var isNull = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isNull.js"); +var isUndefined = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isUndefined.js"); +var omit = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/omit.js"); +var map = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/map.js"); +var extend = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/assign.js"); +var _filter = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/filter.js"); + +var _orderBy = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/orderBy.js"); +var _property = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/property.js"); +var _get = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/get.js"); + +var Griddle = React.createClass({ + displayName: 'Griddle', + + statics: { + GridTable: GridTable, + GridFilter: GridFilter, + GridPagination: GridPagination, + GridSettings: GridSettings, + GridRow: GridRow + }, + columnSettings: null, + rowSettings: null, + getDefaultProps: function getDefaultProps() { + return { + "columns": [], + "gridMetadata": null, + "columnMetadata": [], + "rowMetadata": null, + "results": [], // Used if all results are already loaded. + "initialSort": "", + "gridClassName": "", + "tableClassName": "", + "customRowComponentClassName": "", + "settingsText": "Settings", + "filterPlaceholderText": "Filter Results", + "nextText": "Next", + "previousText": "Previous", + "maxRowsText": "Rows per page", + "enableCustomFormatText": "Enable Custom Formatting", + //this column will determine which column holds subgrid data + //it will be passed through with the data object but will not be rendered + "childrenColumnName": "children", + //Any column in this list will be treated as metadata and will be passed through with the data but won't be rendered + "metadataColumns": [], + "showFilter": false, + "showSettings": false, + "useCustomRowComponent": false, + "useCustomGridComponent": false, + "useCustomPagerComponent": false, + "useCustomFilterer": false, + "useCustomFilterComponent": false, + "useGriddleStyles": true, + "useGriddleIcons": true, + "customRowComponent": null, + "customGridComponent": null, + "customPagerComponent": {}, + "customFilterComponent": null, + "customFilterer": null, + "globalData": null, + "enableToggleCustom": false, + "noDataMessage": "There is no data to display.", + "noDataClassName": "griddle-nodata", + "customNoDataComponent": null, + "customNoDataComponentProps": null, + "allowEmptyGrid": false, + "showTableHeading": true, + "showPager": true, + "useFixedHeader": false, + "useExternal": false, + "externalSetPage": null, + "externalChangeSort": null, + "externalSetFilter": null, + "externalSetPageSize": null, + "externalMaxPage": null, + "externalCurrentPage": null, + "externalSortColumn": null, + "externalSortAscending": true, + "externalLoadingComponent": null, + "externalIsLoading": false, + "enableInfiniteScroll": false, + "bodyHeight": null, + "paddingHeight": 5, + "rowHeight": 25, + "infiniteScrollLoadTreshold": 50, + "useFixedLayout": true, + "isSubGriddle": false, + "enableSort": true, + "onRowClick": null, + /* css class names */ + "sortAscendingClassName": "sort-ascending", + "sortDescendingClassName": "sort-descending", + "parentRowCollapsedClassName": "parent-row", + "parentRowExpandedClassName": "parent-row expanded", + "settingsToggleClassName": "settings", + "nextClassName": "griddle-next", + "previousClassName": "griddle-previous", + "headerStyles": {}, + /* icon components */ + "sortAscendingComponent": " â–²", + "sortDescendingComponent": " â–¼", + "sortDefaultComponent": null, + "parentRowCollapsedComponent": "â–¶", + "parentRowExpandedComponent": "â–¼", + "settingsIconComponent": "", + "nextIconComponent": "", + "previousIconComponent": "", + "isMultipleSelection": false, //currently does not support subgrids + "selectedRowIds": [], + "uniqueIdentifier": "id", + "onSelectionChange": null + }; + }, + propTypes: { + isMultipleSelection: React.PropTypes.bool, + selectedRowIds: React.PropTypes.oneOfType([React.PropTypes.arrayOf(React.PropTypes.number), React.PropTypes.arrayOf(React.PropTypes.string)]), + uniqueIdentifier: React.PropTypes.string, + onSelectionChange: React.PropTypes.func + }, + defaultFilter: function defaultFilter(results, filter) { + var that = this; + return _filter(results, function (item) { + var arr = deep.keys(item); + for (var i = 0; i < arr.length; i++) { + var isFilterable = that.columnSettings.getMetadataColumnProperty(arr[i], "filterable", true); + if (isFilterable && (deep.getAt(item, arr[i]) || "").toString().toLowerCase().indexOf(filter.toLowerCase()) >= 0) { + return true; + } + } + return false; + }); + }, + + defaultColumnFilter: function defaultColumnFilter(value, filter) { + return _filter(deep.getObjectValues(value), function (value) { + return value.toString().toLowerCase().indexOf(filter.toLowerCase()) >= 0; + }).length > 0; + }, + + filterByColumnFilters: function filterByColumnFilters(columnFilters) { + var filterFunction = this.defaultColumnFilter; + var filteredResults = Object.keys(columnFilters).reduce(function (previous, current) { + return _filter(previous, function (item) { + var value = deep.getAt(item, current || ""); + var filter = columnFilters[current]; + return filterFunction(value, filter); + }); + }, this.props.results); + + var newState = { + columnFilters: columnFilters + }; + + if (columnFilters) { + newState.filteredResults = filteredResults; + newState.maxPage = this.getMaxPage(newState.filteredResults); + } else if (this.state.filter) { + newState.filteredResults = this.props.useCustomFilterer ? this.props.customFilterer(this.props.results, filter) : this.defaultFilter(this.props.results, filter); + } else { + newState.filteredResults = null; + } + + this.setState(newState); + }, + + filterByColumn: function filterByColumn(filter, column) { + var columnFilters = this.state.columnFilters; + + //if filter is "" remove it from the columnFilters object + if (columnFilters.hasOwnProperty(column) && !filter) { + columnFilters = omit(columnFilters, column); + } else { + var newObject = {}; + newObject[column] = filter; + columnFilters = extend({}, columnFilters, newObject); + } + + this.filterByColumnFilters(columnFilters); + }, + + /* if we have a filter display the max page and results accordingly */ + setFilter: function setFilter(filter) { + if (this.props.useExternal) { + this.props.externalSetFilter(filter); + return; + } + + var that = this, + updatedState = { + page: 0, + filter: filter + }; + + // Obtain the state results. + updatedState.filteredResults = this.props.useCustomFilterer ? this.props.customFilterer(this.props.results, filter) : this.defaultFilter(this.props.results, filter); + + // Update the max page. + updatedState.maxPage = that.getMaxPage(updatedState.filteredResults); + + //if filter is null or undefined reset the filter. + if (isUndefined(filter) || isNull(filter) || isEmpty(filter)) { + updatedState.filter = filter; + updatedState.filteredResults = null; + } + + // Set the state. + that.setState(updatedState); + + this._resetSelectedRows(); + }, + setPageSize: function setPageSize(size) { + if (this.props.useExternal) { + this.setState({ + resultsPerPage: size + }); + this.props.externalSetPageSize(size); + return; + } + //make this better. + this.state.resultsPerPage = size; + this.setMaxPage(); + }, + toggleColumnChooser: function toggleColumnChooser() { + this.setState({ + showColumnChooser: !this.state.showColumnChooser + }); + }, + isNullOrUndefined: function isNullOrUndefined(value) { + return value === undefined || value === null; + }, + shouldUseCustomRowComponent: function shouldUseCustomRowComponent() { + return this.isNullOrUndefined(this.state.useCustomRowComponent) ? this.props.useCustomRowComponent : this.state.useCustomRowComponent; + }, + shouldUseCustomGridComponent: function shouldUseCustomGridComponent() { + return this.isNullOrUndefined(this.state.useCustomGridComponent) ? this.props.useCustomGridComponent : this.state.useCustomGridComponent; + }, + toggleCustomComponent: function toggleCustomComponent() { + if (this.state.customComponentType === "grid") { + this.setState({ + useCustomGridComponent: !this.shouldUseCustomGridComponent() + }); + } else if (this.state.customComponentType === "row") { + this.setState({ + useCustomRowComponent: !this.shouldUseCustomRowComponent() + }); + } + }, + getMaxPage: function getMaxPage(results, totalResults) { + if (this.props.useExternal) { + return this.props.externalMaxPage; + } + + if (!totalResults) { + totalResults = (results || this.getCurrentResults()).length; + } + var maxPage = Math.ceil(totalResults / this.state.resultsPerPage); + return maxPage; + }, + setMaxPage: function setMaxPage(results) { + var maxPage = this.getMaxPage(results); + //re-render if we have new max page value + if (this.state.maxPage !== maxPage) { + this.setState({ page: 0, maxPage: maxPage, filteredColumns: this.columnSettings.filteredColumns }); + } + }, + setPage: function setPage(number) { + if (this.props.useExternal) { + this.props.externalSetPage(number); + return; + } + + //check page size and move the filteredResults to pageSize * pageNumber + if (number * this.state.resultsPerPage <= this.state.resultsPerPage * this.state.maxPage) { + var that = this, + state = { + page: number + }; + + that.setState(state); + } + + //When infinite scrolling is enabled, uncheck the "select all" checkbox, since more unchecked rows will be appended at the end + if (this.props.enableInfiniteScroll) { + this.setState({ + isSelectAllChecked: false + }); + } + }, + setColumns: function setColumns(columns) { + this.columnSettings.filteredColumns = isArray(columns) ? columns : [columns]; + + this.setState({ + filteredColumns: this.columnSettings.filteredColumns + }); + }, + nextPage: function nextPage() { + var currentPage = this.getCurrentPage(); + if (currentPage < this.getCurrentMaxPage() - 1) { + this.setPage(currentPage + 1); + } + }, + previousPage: function previousPage() { + var currentPage = this.getCurrentPage(); + if (currentPage > 0) { + this.setPage(currentPage - 1); + } + }, + changeSort: function changeSort(column) { + if (this.props.enableSort === false) { + return; + } + + if (this.props.useExternal) { + var isAscending = this.props.externalSortColumn === column ? !this.props.externalSortAscending : true; + this.setState({ + sortColumn: column, + sortDirection: isAscending ? 'asc' : 'desc' + }); + this.props.externalChangeSort(column, isAscending); + return; + } + var columnMeta = find(this.props.columnMetadata, { columnName: column }) || {}; + var sortDirectionCycle = columnMeta.sortDirectionCycle ? columnMeta.sortDirectionCycle : [null, 'asc', 'desc']; + var sortDirection = null; + // Find the current position in the cycle (or -1). + var i = sortDirectionCycle.indexOf(this.state.sortDirection && column === this.state.sortColumn ? this.state.sortDirection : null); + + // Proceed to the next position in the cycle (or start at the beginning). + i = (i + 1) % sortDirectionCycle.length; + + if (sortDirectionCycle[i]) { + sortDirection = sortDirectionCycle[i]; + } else { + sortDirection = null; + } + + var state = { + page: 0, + sortColumn: column, + sortDirection: sortDirection + }; + + this.setState(state); + }, + componentWillReceiveProps: function componentWillReceiveProps(nextProps) { + this.setMaxPage(nextProps.results); + if (nextProps.resultsPerPage !== this.props.resultsPerPage) { + this.setPageSize(nextProps.resultsPerPage); + } + //This will updaet the column Metadata + this.columnSettings.columnMetadata = nextProps.columnMetadata; + if (nextProps.results.length > 0) { + var deepKeys = deep.keys(nextProps.results[0]); + + var is_same = this.columnSettings.allColumns.length == deepKeys.length && this.columnSettings.allColumns.every(function (element, index) { + return element === deepKeys[index]; + }); + + if (!is_same) { + this.columnSettings.allColumns = deepKeys; + } + } else if (this.columnSettings.allColumns.length > 0) { + this.columnSettings.allColumns = []; + } + + if (nextProps.selectedRowIds) { + var visibleRows = this.getDataForRender(this.getCurrentResults(nextProps.results), this.columnSettings.getColumns(), true); + + this.setState({ + isSelectAllChecked: this._getAreAllRowsChecked(nextProps.selectedRowIds, map(visibleRows, this.props.uniqueIdentifier)), + selectedRowIds: nextProps.selectedRowIds + }); + } + }, + getInitialState: function getInitialState() { + var state = { + maxPage: 0, + page: 0, + filteredResults: null, + filteredColumns: [], + filter: "", + //this sets the individual column filters + columnFilters: {}, + resultsPerPage: this.props.resultsPerPage || 5, + showColumnChooser: false, + isSelectAllChecked: false, + selectedRowIds: this.props.selectedRowIds + }; + return state; + }, + componentWillMount: function componentWillMount() { + this.verifyExternal(); + this.verifyCustom(); + + this.columnSettings = new ColumnProperties(this.props.results.length > 0 ? deep.keys(this.props.results[0]) : [], this.props.columns, this.props.childrenColumnName, this.props.columnMetadata, this.props.metadataColumns); + + this.rowSettings = new RowProperties(this.props.rowMetadata, this.props.useCustomTableRowComponent && this.props.customTableRowComponent ? this.props.customTableRowComponent : GridRow, this.props.useCustomTableRowComponent); + + if (this.props.initialSort) { + // shouldn't change Sort on init for external + if (this.props.useExternal) { + this.setState({ + sortColumn: this.props.externalSortColumn, + sortDirection: this.props.externalSortAscending ? 'asc' : 'desc' + }); + } else { + this.changeSort(this.props.initialSort); + } + } + this.setMaxPage(); + + //don't like the magic strings + if (this.shouldUseCustomGridComponent()) { + this.setState({ + customComponentType: "grid" + }); + } else if (this.shouldUseCustomRowComponent()) { + this.setState({ + customComponentType: "row" + }); + } else { + this.setState({ + filteredColumns: this.columnSettings.filteredColumns + }); + } + }, + componentDidMount: function componentDidMount() { + if (this.props.componentDidMount && typeof this.props.componentDidMount === "function") { + return this.props.componentDidMount(); + } + }, + componentDidUpdate: function componentDidUpdate() { + if (this.props.componentDidUpdate && typeof this.props.componentDidUpdate === "function") { + return this.props.componentDidUpdate(this.state); + } + }, + //todo: clean these verify methods up + verifyExternal: function verifyExternal() { + if (this.props.useExternal === true) { + //hooray for big ugly nested if + if (this.props.externalSetPage === null) { + console.error("useExternal is set to true but there is no externalSetPage function specified."); + } + + if (this.props.externalChangeSort === null) { + console.error("useExternal is set to true but there is no externalChangeSort function specified."); + } + + if (this.props.externalSetFilter === null) { + console.error("useExternal is set to true but there is no externalSetFilter function specified."); + } + + if (this.props.externalSetPageSize === null) { + console.error("useExternal is set to true but there is no externalSetPageSize function specified."); + } + + if (this.props.externalMaxPage === null) { + console.error("useExternal is set to true but externalMaxPage is not set."); + } + + if (this.props.externalCurrentPage === null) { + console.error("useExternal is set to true but externalCurrentPage is not set. Griddle will not page correctly without that property when using external data."); + } + } + }, + //TODO: Do this with propTypes + verifyCustom: function verifyCustom() { + if (this.props.useCustomGridComponent === true && this.props.customGridComponent === null) { + console.error("useCustomGridComponent is set to true but no custom component was specified."); + } + if (this.props.useCustomRowComponent === true && this.props.customRowComponent === null) { + console.error("useCustomRowComponent is set to true but no custom component was specified."); + } + if (this.props.useCustomGridComponent === true && this.props.useCustomRowComponent === true) { + console.error("Cannot currently use both customGridComponent and customRowComponent."); + } + if (this.props.useCustomFilterer === true && this.props.customFilterer === null) { + console.error("useCustomFilterer is set to true but no custom filter function was specified."); + } + if (this.props.useCustomFilterComponent === true && this.props.customFilterComponent === null) { + console.error("useCustomFilterComponent is set to true but no customFilterComponent was specified."); + } + }, + getDataForRender: function getDataForRender(data, cols, pageList) { + var _this = this; + + var that = this; + + // get the correct page size + if (this.state.sortColumn !== "") { + var column = this.state.sortColumn; + var sortColumn = _filter(this.props.columnMetadata, { columnName: column }); + var customCompareFn; + var multiSort = { + columns: [], + orders: [] + }; + + if (sortColumn.length > 0) { + customCompareFn = sortColumn[0].hasOwnProperty("customCompareFn") && sortColumn[0]["customCompareFn"]; + if (sortColumn[0]["multiSort"]) { + multiSort = sortColumn[0]["multiSort"]; + } + } + + if (this.state.sortDirection) { + if (typeof customCompareFn === 'function') { + if (customCompareFn.length === 2) { + data = data.sort(function (a, b) { + return customCompareFn(_get(a, column), _get(b, column)); + }); + + if (this.state.sortDirection === 'desc') { + data.reverse(); + } + } else if (customCompareFn.length === 1) { + data = _orderBy(data, function (item) { + return customCompareFn(_get(item, column)); + }, [this.state.sortDirection]); + } + } else { + var iteratees = [function (row) { + return (_get(row, column) || '').toString().toLowerCase(); + }]; + var orders = [this.state.sortDirection]; + multiSort.columns.forEach(function (col, i) { + iteratees.push(function (row) { + return (_get(row, col) || '').toString().toLowerCase(); + }); + if (multiSort.orders[i] === 'asc' || multiSort.orders[i] === 'desc') { + orders.push(multiSort.orders[i]); + } else { + orders.push(_this.state.sortDirection); + } + }); + + data = _orderBy(data, iteratees, orders); + } + } + } + + var currentPage = this.getCurrentPage(); + + if (!this.props.useExternal && pageList && this.state.resultsPerPage * (currentPage + 1) <= this.state.resultsPerPage * this.state.maxPage && currentPage >= 0) { + if (this.isInfiniteScrollEnabled()) { + // If we're doing infinite scroll, grab all results up to the current page. + data = first(data, (currentPage + 1) * this.state.resultsPerPage); + } else { + //the 'rest' is grabbing the whole array from index on and the 'initial' is getting the first n results + var rest = drop(data, currentPage * this.state.resultsPerPage); + data = (dropRight || initial)(rest, rest.length - this.state.resultsPerPage); + } + } + + var meta = this.columnSettings.getMetadataColumns; + + var transformedData = []; + + for (var i = 0; i < data.length; i++) { + var mappedData = data[i]; + + if (typeof mappedData[that.props.childrenColumnName] !== "undefined" && mappedData[that.props.childrenColumnName].length > 0) { + //internally we're going to use children instead of whatever it is so we don't have to pass the custom name around + mappedData["children"] = that.getDataForRender(mappedData[that.props.childrenColumnName], cols, false); + + if (that.props.childrenColumnName !== "children") { + delete mappedData[that.props.childrenColumnName]; + } + } + + transformedData.push(mappedData); + } + return transformedData; + }, + getCurrentResults: function getCurrentResults(results) { + return this.state.filteredResults || results || this.props.results; + }, + getCurrentPage: function getCurrentPage() { + return this.props.externalCurrentPage || this.state.page; + }, + getCurrentSort: function getCurrentSort() { + return this.props.useExternal ? this.props.externalSortColumn : this.state.sortColumn; + }, + getCurrentSortAscending: function getCurrentSortAscending() { + return this.props.useExternal ? this.props.externalSortAscending : this.state.sortDirection === 'asc'; + }, + getCurrentMaxPage: function getCurrentMaxPage() { + return this.props.useExternal ? this.props.externalMaxPage : this.state.maxPage; + }, + //This takes the props relating to sort and puts them in one object + getSortObject: function getSortObject() { + return { + enableSort: this.props.enableSort, + changeSort: this.changeSort, + sortColumn: this.getCurrentSort(), + sortAscending: this.getCurrentSortAscending(), + sortDirection: this.state.sortDirection, + sortAscendingClassName: this.props.sortAscendingClassName, + sortDescendingClassName: this.props.sortDescendingClassName, + sortAscendingComponent: this.props.sortAscendingComponent, + sortDescendingComponent: this.props.sortDescendingComponent, + sortDefaultComponent: this.props.sortDefaultComponent + }; + }, + _toggleSelectAll: function _toggleSelectAll() { + var visibleRows = this.getDataForRender(this.getCurrentResults(), this.columnSettings.getColumns(), true), + newIsSelectAllChecked = !this.state.isSelectAllChecked, + newSelectedRowIds = JSON.parse(JSON.stringify(this.state.selectedRowIds)); + + var self = this; + forEach(visibleRows, function (row) { + self._updateSelectedRowIds(row[self.props.uniqueIdentifier], newSelectedRowIds, newIsSelectAllChecked); + }, this); + + this.setState({ + isSelectAllChecked: newIsSelectAllChecked, + selectedRowIds: newSelectedRowIds + }); + + if (this.props.onSelectionChange) { + this.props.onSelectionChange(newSelectedRowIds, newIsSelectAllChecked); + } + }, + _toggleSelectRow: function _toggleSelectRow(row, isChecked) { + var visibleRows = this.getDataForRender(this.getCurrentResults(), this.columnSettings.getColumns(), true), + newSelectedRowIds = JSON.parse(JSON.stringify(this.state.selectedRowIds)); + + this._updateSelectedRowIds(row[this.props.uniqueIdentifier], newSelectedRowIds, isChecked); + + var newIsSelectAllChecked = this._getAreAllRowsChecked(newSelectedRowIds, map(visibleRows, this.props.uniqueIdentifier)); + + this.setState({ + isSelectAllChecked: newIsSelectAllChecked, + selectedRowIds: newSelectedRowIds + }); + + if (this.props.onSelectionChange) { + this.props.onSelectionChange(newSelectedRowIds, newIsSelectAllChecked); + } + }, + _updateSelectedRowIds: function _updateSelectedRowIds(id, selectedRowIds, isChecked) { + + var isFound; + + if (isChecked) { + isFound = find(selectedRowIds, function (item) { + return id === item; + }); + + if (isFound === undefined) { + selectedRowIds.push(id); + } + } else { + selectedRowIds.splice(selectedRowIds.indexOf(id), 1); + } + }, + _getIsSelectAllChecked: function _getIsSelectAllChecked() { + + return this.state.isSelectAllChecked; + }, + _getAreAllRowsChecked: function _getAreAllRowsChecked(selectedRowIds, visibleRowIds) { + + return visibleRowIds.length === intersection(visibleRowIds, selectedRowIds).length; + }, + _getIsRowChecked: function _getIsRowChecked(row) { + + return this.state.selectedRowIds.indexOf(row[this.props.uniqueIdentifier]) > -1 ? true : false; + }, + getSelectedRowIds: function getSelectedRowIds() { + + return this.state.selectedRowIds; + }, + _resetSelectedRows: function _resetSelectedRows() { + + this.setState({ + isSelectAllChecked: false, + selectedRowIds: [] + }); + }, + //This takes the props relating to multiple selection and puts them in one object + getMultipleSelectionObject: function getMultipleSelectionObject() { + + return { + isMultipleSelection: find(this.props.results, function (result) { + return 'children' in result; + }) ? false : this.props.isMultipleSelection, //does not support subgrids + toggleSelectAll: this._toggleSelectAll, + getIsSelectAllChecked: this._getIsSelectAllChecked, + toggleSelectRow: this._toggleSelectRow, + getSelectedRowIds: this.getSelectedRowIds, + getIsRowChecked: this._getIsRowChecked + }; + }, + isInfiniteScrollEnabled: function isInfiniteScrollEnabled() { + // If a custom pager is included, don't allow for infinite scrolling. + if (this.props.useCustomPagerComponent) { + return false; + } + + // Otherwise, send back the property. + return this.props.enableInfiniteScroll; + }, + getClearFixStyles: function getClearFixStyles() { + return { + clear: "both", + display: "table", + width: "100%" + }; + }, + getSettingsStyles: function getSettingsStyles() { + return { + "float": "left", + width: "50%", + textAlign: "right" + }; + }, + getFilterStyles: function getFilterStyles() { + return { + "float": "left", + width: "50%", + textAlign: "left", + color: "#222", + minHeight: "1px" + }; + }, + getFilter: function getFilter() { + return this.props.showFilter && this.shouldUseCustomGridComponent() === false ? this.props.useCustomFilterComponent ? React.createElement(CustomFilterContainer, { changeFilter: this.setFilter, placeholderText: this.props.filterPlaceholderText, customFilterComponent: this.props.customFilterComponent, results: this.props.results, currentResults: this.getCurrentResults() }) : React.createElement(GridFilter, { changeFilter: this.setFilter, placeholderText: this.props.filterPlaceholderText }) : ""; + }, + getSettings: function getSettings() { + return this.props.showSettings ? React.createElement('button', { type: 'button', className: this.props.settingsToggleClassName, onClick: this.toggleColumnChooser, + style: this.props.useGriddleStyles ? { background: "none", border: "none", padding: 0, margin: 0, fontSize: 14 } : null }, this.props.settingsText, this.props.settingsIconComponent) : ""; + }, + getTopSection: function getTopSection(filter, settings) { + if (this.props.showFilter === false && this.props.showSettings === false) { + return ""; + } + + var filterStyles = null, + settingsStyles = null, + topContainerStyles = null; + + if (this.props.useGriddleStyles) { + filterStyles = this.getFilterStyles(); + settingsStyles = this.getSettingsStyles(); + + topContainerStyles = this.getClearFixStyles(); + } + + return React.createElement('div', { className: 'top-section', style: topContainerStyles }, React.createElement('div', { className: 'griddle-filter', style: filterStyles }, filter), React.createElement('div', { className: 'griddle-settings-toggle', style: settingsStyles }, settings)); + }, + getPagingSection: function getPagingSection(currentPage, maxPage) { + if ((this.props.showPager && !this.isInfiniteScrollEnabled() && !this.shouldUseCustomGridComponent()) === false) { + return undefined; + } + + return React.createElement('div', { className: 'griddle-footer' }, this.props.useCustomPagerComponent ? React.createElement(CustomPaginationContainer, { customPagerComponentOptions: this.props.customPagerComponentOptions, next: this.nextPage, previous: this.previousPage, currentPage: currentPage, maxPage: maxPage, setPage: this.setPage, nextText: this.props.nextText, previousText: this.props.previousText, customPagerComponent: this.props.customPagerComponent }) : React.createElement(GridPagination, { useGriddleStyles: this.props.useGriddleStyles, next: this.nextPage, previous: this.previousPage, nextClassName: this.props.nextClassName, nextIconComponent: this.props.nextIconComponent, previousClassName: this.props.previousClassName, previousIconComponent: this.props.previousIconComponent, currentPage: currentPage, maxPage: maxPage, setPage: this.setPage, nextText: this.props.nextText, previousText: this.props.previousText })); + }, + getColumnSelectorSection: function getColumnSelectorSection(keys, cols) { + return this.state.showColumnChooser ? React.createElement(GridSettings, { columns: keys, selectedColumns: cols, setColumns: this.setColumns, settingsText: this.props.settingsText, + settingsIconComponent: this.props.settingsIconComponent, maxRowsText: this.props.maxRowsText, setPageSize: this.setPageSize, + showSetPageSize: !this.shouldUseCustomGridComponent(), resultsPerPage: this.state.resultsPerPage, enableToggleCustom: this.props.enableToggleCustom, + toggleCustomComponent: this.toggleCustomComponent, useCustomComponent: this.shouldUseCustomRowComponent() || this.shouldUseCustomGridComponent(), + useGriddleStyles: this.props.useGriddleStyles, enableCustomFormatText: this.props.enableCustomFormatText, columnMetadata: this.props.columnMetadata }) : ""; + }, + getCustomGridSection: function getCustomGridSection() { + return React.createElement(this.props.customGridComponent, _extends({ data: this.props.results, className: this.props.customGridComponentClassName }, this.props.gridMetadata)); + }, + getCustomRowSection: function getCustomRowSection(data, cols, meta, pagingContent, globalData) { + return React.createElement('div', null, React.createElement(CustomRowComponentContainer, { data: data, columns: cols, metadataColumns: meta, globalData: globalData, + className: this.props.customRowComponentClassName, customComponent: this.props.customRowComponent, + style: this.props.useGriddleStyles ? this.getClearFixStyles() : null }), this.props.showPager && pagingContent); + }, + getStandardGridSection: function getStandardGridSection(data, cols, meta, pagingContent, hasMorePages) { + var sortProperties = this.getSortObject(); + var multipleSelectionProperties = this.getMultipleSelectionObject(); + + // no data section + var showNoData = this.shouldShowNoDataSection(data); + var noDataSection = this.getNoDataSection(); + + return React.createElement('div', { className: 'griddle-body' }, React.createElement(GridTable, { useGriddleStyles: this.props.useGriddleStyles, + noDataSection: noDataSection, + showNoData: showNoData, + columnSettings: this.columnSettings, + rowSettings: this.rowSettings, + sortSettings: sortProperties, + multipleSelectionSettings: multipleSelectionProperties, + filterByColumn: this.filterByColumn, + isSubGriddle: this.props.isSubGriddle, + useGriddleIcons: this.props.useGriddleIcons, + useFixedLayout: this.props.useFixedLayout, + showPager: this.props.showPager, + pagingContent: pagingContent, + data: data, + className: this.props.tableClassName, + enableInfiniteScroll: this.isInfiniteScrollEnabled(), + nextPage: this.nextPage, + showTableHeading: this.props.showTableHeading, + useFixedHeader: this.props.useFixedHeader, + parentRowCollapsedClassName: this.props.parentRowCollapsedClassName, + parentRowExpandedClassName: this.props.parentRowExpandedClassName, + parentRowCollapsedComponent: this.props.parentRowCollapsedComponent, + parentRowExpandedComponent: this.props.parentRowExpandedComponent, + bodyHeight: this.props.bodyHeight, + paddingHeight: this.props.paddingHeight, + rowHeight: this.props.rowHeight, + infiniteScrollLoadTreshold: this.props.infiniteScrollLoadTreshold, + externalLoadingComponent: this.props.externalLoadingComponent, + externalIsLoading: this.props.externalIsLoading, + hasMorePages: hasMorePages, + onRowClick: this.props.onRowClick })); + }, + getContentSection: function getContentSection(data, cols, meta, pagingContent, hasMorePages, globalData) { + if (this.shouldUseCustomGridComponent() && this.props.customGridComponent !== null) { + return this.getCustomGridSection(); + } else if (this.shouldUseCustomRowComponent()) { + return this.getCustomRowSection(data, cols, meta, pagingContent, globalData); + } else { + return this.getStandardGridSection(data, cols, meta, pagingContent, hasMorePages); + } + }, + getNoDataSection: function getNoDataSection() { + if (this.props.customNoDataComponent != null) { + return React.createElement('div', { className: this.props.noDataClassName }, React.createElement(this.props.customNoDataComponent, this.props.customNoDataComponentProps)); + } + return React.createElement(GridNoData, { noDataMessage: this.props.noDataMessage }); + }, + shouldShowNoDataSection: function shouldShowNoDataSection(results) { + if (this.props.allowEmptyGrid) { + return false; + } + + return this.props.useExternal === false && (typeof results === 'undefined' || results.length === 0) || this.props.useExternal === true && this.props.externalIsLoading === false && results.length === 0; + }, + render: function render() { + var that = this, + results = this.getCurrentResults(); // Attempt to assign to the filtered results, if we have any. + + var headerTableClassName = this.props.tableClassName + " table-header"; + + //figure out if we want to show the filter section + var filter = this.getFilter(); + var settings = this.getSettings(); + + //if we have neither filter or settings don't need to render this stuff + var topSection = this.getTopSection(filter, settings); + + var keys = []; + var cols = this.columnSettings.getColumns(); + //figure out which columns are displayed and show only those + var data = this.getDataForRender(results, cols, true); + + var meta = this.columnSettings.getMetadataColumns(); + + if (this.props.columnMetadata) { + // Get column keys from column metadata + forEach(this.props.columnMetadata, function (meta) { + if (!(typeof meta.visible === 'boolean' && meta.visible === false)) { + keys.push(meta.columnName); + } + }); + } else { + // Grab the column keys from the first results + keys = deep.keys(omit(results[0], meta)); + } + + // sort keys by order + keys = this.columnSettings.orderColumns(keys); + + // Grab the current and max page values. + var currentPage = this.getCurrentPage(); + var maxPage = this.getCurrentMaxPage(); + + // Determine if we need to enable infinite scrolling on the table. + var hasMorePages = currentPage + 1 < maxPage; + + // Grab the paging content if it's to be displayed + var pagingContent = this.getPagingSection(currentPage, maxPage); + + var resultContent = this.getContentSection(data, cols, meta, pagingContent, hasMorePages, this.props.globalData); + + var columnSelector = this.getColumnSelectorSection(keys, cols); + + var gridClassName = this.props.gridClassName.length > 0 ? "griddle " + this.props.gridClassName : "griddle"; + //add custom to the class name so we can style it differently + gridClassName += this.shouldUseCustomRowComponent() ? " griddle-custom" : ""; + + return React.createElement('div', { className: gridClassName }, topSection, columnSelector, React.createElement('div', { className: 'griddle-container', style: this.props.useGriddleStyles && !this.props.isSubGriddle ? { border: "1px solid #DDD" } : null }, resultContent)); + } +}); + +GridRowContainer.Griddle = module.exports = Griddle; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/modules/rowProperties.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })(); + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } + +var _uniqueId = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/uniqueId.js"); + +var RowProperties = (function () { + function RowProperties() { + var rowMetadata = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; + var rowComponent = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; + var isCustom = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2]; + + _classCallCheck(this, RowProperties); + + this.rowMetadata = rowMetadata; + this.rowComponent = rowComponent; + this.isCustom = isCustom; + // assign unique Id to each griddle instance + } + + _createClass(RowProperties, [{ + key: 'getRowKey', + value: function getRowKey(row, key) { + var uniqueId; + + if (this.hasRowMetadataKey()) { + uniqueId = row[this.rowMetadata.key]; + } else { + uniqueId = _uniqueId("grid_row"); + } + + //todo: add error handling + + return uniqueId; + } + }, { + key: 'hasRowMetadataKey', + value: function hasRowMetadataKey() { + return this.hasRowMetadata() && this.rowMetadata.key !== null && this.rowMetadata.key !== undefined; + } + }, { + key: 'getBodyRowMetadataClass', + value: function getBodyRowMetadataClass(rowData) { + if (this.hasRowMetadata() && this.rowMetadata.bodyCssClassName !== null && this.rowMetadata.bodyCssClassName !== undefined) { + if (typeof this.rowMetadata.bodyCssClassName === 'function') { + return this.rowMetadata.bodyCssClassName(rowData); + } else { + return this.rowMetadata.bodyCssClassName; + } + } + return null; + } + }, { + key: 'getHeaderRowMetadataClass', + value: function getHeaderRowMetadataClass() { + return this.hasRowMetadata() && this.rowMetadata.headerCssClassName !== null && this.rowMetadata.headerCssClassName !== undefined ? this.rowMetadata.headerCssClassName : null; + } + }, { + key: 'hasRowMetadata', + value: function hasRowMetadata() { + return this.rowMetadata !== null; + } + }]); + + return RowProperties; +})(); + +module.exports = RowProperties; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_DataView.js": +/***/ (function(module, exports, __webpack_require__) { + +var getNative = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getNative.js"), + root = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_root.js"); + +/* Built-in method references that are verified to be native. */ +var DataView = getNative(root, 'DataView'); + +module.exports = DataView; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_Hash.js": +/***/ (function(module, exports, __webpack_require__) { + +var hashClear = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_hashClear.js"), + hashDelete = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_hashDelete.js"), + hashGet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_hashGet.js"), + hashHas = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_hashHas.js"), + hashSet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_hashSet.js"); + +/** + * Creates a hash object. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function Hash(entries) { + var index = -1, + length = entries == null ? 0 : entries.length; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } +} + +// Add methods to `Hash`. +Hash.prototype.clear = hashClear; +Hash.prototype['delete'] = hashDelete; +Hash.prototype.get = hashGet; +Hash.prototype.has = hashHas; +Hash.prototype.set = hashSet; + +module.exports = Hash; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_ListCache.js": +/***/ (function(module, exports, __webpack_require__) { + +var listCacheClear = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_listCacheClear.js"), + listCacheDelete = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_listCacheDelete.js"), + listCacheGet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_listCacheGet.js"), + listCacheHas = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_listCacheHas.js"), + listCacheSet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_listCacheSet.js"); + +/** + * Creates an list cache object. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function ListCache(entries) { + var index = -1, + length = entries == null ? 0 : entries.length; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } +} + +// Add methods to `ListCache`. +ListCache.prototype.clear = listCacheClear; +ListCache.prototype['delete'] = listCacheDelete; +ListCache.prototype.get = listCacheGet; +ListCache.prototype.has = listCacheHas; +ListCache.prototype.set = listCacheSet; + +module.exports = ListCache; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_Map.js": +/***/ (function(module, exports, __webpack_require__) { + +var getNative = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getNative.js"), + root = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_root.js"); + +/* Built-in method references that are verified to be native. */ +var Map = getNative(root, 'Map'); + +module.exports = Map; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_MapCache.js": +/***/ (function(module, exports, __webpack_require__) { + +var mapCacheClear = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_mapCacheClear.js"), + mapCacheDelete = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_mapCacheDelete.js"), + mapCacheGet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_mapCacheGet.js"), + mapCacheHas = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_mapCacheHas.js"), + mapCacheSet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_mapCacheSet.js"); + +/** + * Creates a map cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function MapCache(entries) { + var index = -1, + length = entries == null ? 0 : entries.length; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } +} + +// Add methods to `MapCache`. +MapCache.prototype.clear = mapCacheClear; +MapCache.prototype['delete'] = mapCacheDelete; +MapCache.prototype.get = mapCacheGet; +MapCache.prototype.has = mapCacheHas; +MapCache.prototype.set = mapCacheSet; + +module.exports = MapCache; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_Promise.js": +/***/ (function(module, exports, __webpack_require__) { + +var getNative = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getNative.js"), + root = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_root.js"); + +/* Built-in method references that are verified to be native. */ +var Promise = getNative(root, 'Promise'); + +module.exports = Promise; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_Set.js": +/***/ (function(module, exports, __webpack_require__) { + +var getNative = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getNative.js"), + root = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_root.js"); + +/* Built-in method references that are verified to be native. */ +var Set = getNative(root, 'Set'); + +module.exports = Set; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_SetCache.js": +/***/ (function(module, exports, __webpack_require__) { + +var MapCache = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_MapCache.js"), + setCacheAdd = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_setCacheAdd.js"), + setCacheHas = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_setCacheHas.js"); + +/** + * + * Creates an array cache object to store unique values. + * + * @private + * @constructor + * @param {Array} [values] The values to cache. + */ +function SetCache(values) { + var index = -1, + length = values == null ? 0 : values.length; + + this.__data__ = new MapCache; + while (++index < length) { + this.add(values[index]); + } +} + +// Add methods to `SetCache`. +SetCache.prototype.add = SetCache.prototype.push = setCacheAdd; +SetCache.prototype.has = setCacheHas; + +module.exports = SetCache; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_Stack.js": +/***/ (function(module, exports, __webpack_require__) { + +var ListCache = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_ListCache.js"), + stackClear = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_stackClear.js"), + stackDelete = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_stackDelete.js"), + stackGet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_stackGet.js"), + stackHas = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_stackHas.js"), + stackSet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_stackSet.js"); + +/** + * Creates a stack cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function Stack(entries) { + var data = this.__data__ = new ListCache(entries); + this.size = data.size; +} + +// Add methods to `Stack`. +Stack.prototype.clear = stackClear; +Stack.prototype['delete'] = stackDelete; +Stack.prototype.get = stackGet; +Stack.prototype.has = stackHas; +Stack.prototype.set = stackSet; + +module.exports = Stack; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_Symbol.js": +/***/ (function(module, exports, __webpack_require__) { + +var root = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_root.js"); + +/** Built-in value references. */ +var Symbol = root.Symbol; + +module.exports = Symbol; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_Uint8Array.js": +/***/ (function(module, exports, __webpack_require__) { + +var root = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_root.js"); + +/** Built-in value references. */ +var Uint8Array = root.Uint8Array; + +module.exports = Uint8Array; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_WeakMap.js": +/***/ (function(module, exports, __webpack_require__) { + +var getNative = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getNative.js"), + root = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_root.js"); + +/* Built-in method references that are verified to be native. */ +var WeakMap = getNative(root, 'WeakMap'); + +module.exports = WeakMap; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_apply.js": +/***/ (function(module, exports) { + +/** + * A faster alternative to `Function#apply`, this function invokes `func` + * with the `this` binding of `thisArg` and the arguments of `args`. + * + * @private + * @param {Function} func The function to invoke. + * @param {*} thisArg The `this` binding of `func`. + * @param {Array} args The arguments to invoke `func` with. + * @returns {*} Returns the result of `func`. + */ +function apply(func, thisArg, args) { + switch (args.length) { + case 0: return func.call(thisArg); + case 1: return func.call(thisArg, args[0]); + case 2: return func.call(thisArg, args[0], args[1]); + case 3: return func.call(thisArg, args[0], args[1], args[2]); + } + return func.apply(thisArg, args); +} + +module.exports = apply; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_arrayEach.js": +/***/ (function(module, exports) { + +/** + * A specialized version of `_.forEach` for arrays without support for + * iteratee shorthands. + * + * @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 == null ? 0 : array.length; + + while (++index < length) { + if (iteratee(array[index], index, array) === false) { + break; + } + } + return array; +} + +module.exports = arrayEach; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_arrayFilter.js": +/***/ (function(module, exports) { + +/** + * A specialized version of `_.filter` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + */ +function arrayFilter(array, predicate) { + var index = -1, + length = array == null ? 0 : array.length, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index]; + if (predicate(value, index, array)) { + result[resIndex++] = value; + } + } + return result; +} + +module.exports = arrayFilter; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_arrayIncludes.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIndexOf = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIndexOf.js"); + +/** + * A specialized version of `_.includes` for arrays without support for + * specifying an index to search from. + * + * @private + * @param {Array} [array] The array to inspect. + * @param {*} target The value to search for. + * @returns {boolean} Returns `true` if `target` is found, else `false`. + */ +function arrayIncludes(array, value) { + var length = array == null ? 0 : array.length; + return !!length && baseIndexOf(array, value, 0) > -1; +} + +module.exports = arrayIncludes; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_arrayIncludesWith.js": +/***/ (function(module, exports) { + +/** + * This function is like `arrayIncludes` except that it accepts a comparator. + * + * @private + * @param {Array} [array] The array to inspect. + * @param {*} target The value to search for. + * @param {Function} comparator The comparator invoked per element. + * @returns {boolean} Returns `true` if `target` is found, else `false`. + */ +function arrayIncludesWith(array, value, comparator) { + var index = -1, + length = array == null ? 0 : array.length; + + while (++index < length) { + if (comparator(value, array[index])) { + return true; + } + } + return false; +} + +module.exports = arrayIncludesWith; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_arrayLikeKeys.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseTimes = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseTimes.js"), + isArguments = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArguments.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"), + isBuffer = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isBuffer.js"), + isIndex = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isIndex.js"), + isTypedArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isTypedArray.js"); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Creates an array of the enumerable property names of the array-like `value`. + * + * @private + * @param {*} value The value to query. + * @param {boolean} inherited Specify returning inherited property names. + * @returns {Array} Returns the array of property names. + */ +function arrayLikeKeys(value, inherited) { + var isArr = isArray(value), + isArg = !isArr && isArguments(value), + isBuff = !isArr && !isArg && isBuffer(value), + isType = !isArr && !isArg && !isBuff && isTypedArray(value), + skipIndexes = isArr || isArg || isBuff || isType, + result = skipIndexes ? baseTimes(value.length, String) : [], + length = result.length; + + for (var key in value) { + if ((inherited || hasOwnProperty.call(value, key)) && + !(skipIndexes && ( + // Safari 9 has enumerable `arguments.length` in strict mode. + key == 'length' || + // Node.js 0.10 has enumerable non-index properties on buffers. + (isBuff && (key == 'offset' || key == 'parent')) || + // PhantomJS 2 has enumerable non-index properties on typed arrays. + (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) || + // Skip index properties. + isIndex(key, length) + ))) { + result.push(key); + } + } + return result; +} + +module.exports = arrayLikeKeys; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_arrayMap.js": +/***/ (function(module, exports) { + +/** + * A specialized version of `_.map` for arrays without support for iteratee + * shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ +function arrayMap(array, iteratee) { + var index = -1, + length = array == null ? 0 : array.length, + result = Array(length); + + while (++index < length) { + result[index] = iteratee(array[index], index, array); + } + return result; +} + +module.exports = arrayMap; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_arrayPush.js": +/***/ (function(module, exports) { + +/** + * Appends the elements of `values` to `array`. + * + * @private + * @param {Array} array The array to modify. + * @param {Array} values The values to append. + * @returns {Array} Returns `array`. + */ +function arrayPush(array, values) { + var index = -1, + length = values.length, + offset = array.length; + + while (++index < length) { + array[offset + index] = values[index]; + } + return array; +} + +module.exports = arrayPush; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_arraySome.js": +/***/ (function(module, exports) { + +/** + * A specialized version of `_.some` for arrays without support for iteratee + * shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + */ +function arraySome(array, predicate) { + var index = -1, + length = array == null ? 0 : array.length; + + while (++index < length) { + if (predicate(array[index], index, array)) { + return true; + } + } + return false; +} + +module.exports = arraySome; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_assignValue.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseAssignValue = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseAssignValue.js"), + eq = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/eq.js"); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Assigns `value` to `key` of `object` if the existing value is not equivalent + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ +function assignValue(object, key, value) { + var objValue = object[key]; + if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) || + (value === undefined && !(key in object))) { + baseAssignValue(object, key, value); + } +} + +module.exports = assignValue; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_assocIndexOf.js": +/***/ (function(module, exports, __webpack_require__) { + +var eq = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/eq.js"); + +/** + * Gets the index at which the `key` is found in `array` of key-value pairs. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} key The key to search for. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function assocIndexOf(array, key) { + var length = array.length; + while (length--) { + if (eq(array[length][0], key)) { + return length; + } + } + return -1; +} + +module.exports = assocIndexOf; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseAssign.js": +/***/ (function(module, exports, __webpack_require__) { + +var copyObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_copyObject.js"), + keys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keys.js"); + +/** + * The base implementation of `_.assign` without support for multiple sources + * or `customizer` functions. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @returns {Object} Returns `object`. + */ +function baseAssign(object, source) { + return object && copyObject(source, keys(source), object); +} + +module.exports = baseAssign; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseAssignIn.js": +/***/ (function(module, exports, __webpack_require__) { + +var copyObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_copyObject.js"), + keysIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keysIn.js"); + +/** + * The base implementation of `_.assignIn` without support for multiple sources + * or `customizer` functions. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @returns {Object} Returns `object`. + */ +function baseAssignIn(object, source) { + return object && copyObject(source, keysIn(source), object); +} + +module.exports = baseAssignIn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseAssignValue.js": +/***/ (function(module, exports, __webpack_require__) { + +var defineProperty = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_defineProperty.js"); + +/** + * The base implementation of `assignValue` and `assignMergeValue` without + * value checks. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ +function baseAssignValue(object, key, value) { + if (key == '__proto__' && defineProperty) { + defineProperty(object, key, { + 'configurable': true, + 'enumerable': true, + 'value': value, + 'writable': true + }); + } else { + object[key] = value; + } +} + +module.exports = baseAssignValue; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseClone.js": +/***/ (function(module, exports, __webpack_require__) { + +var Stack = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Stack.js"), + arrayEach = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayEach.js"), + assignValue = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_assignValue.js"), + baseAssign = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseAssign.js"), + baseAssignIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseAssignIn.js"), + cloneBuffer = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cloneBuffer.js"), + copyArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_copyArray.js"), + copySymbols = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_copySymbols.js"), + copySymbolsIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_copySymbolsIn.js"), + getAllKeys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getAllKeys.js"), + getAllKeysIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getAllKeysIn.js"), + getTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getTag.js"), + initCloneArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_initCloneArray.js"), + initCloneByTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_initCloneByTag.js"), + initCloneObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_initCloneObject.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"), + isBuffer = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isBuffer.js"), + isMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isMap.js"), + isObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObject.js"), + isSet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isSet.js"), + keys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keys.js"); + +/** Used to compose bitmasks for cloning. */ +var CLONE_DEEP_FLAG = 1, + CLONE_FLAT_FLAG = 2, + CLONE_SYMBOLS_FLAG = 4; + +/** `Object#toString` result references. */ +var argsTag = '[object Arguments]', + arrayTag = '[object Array]', + boolTag = '[object Boolean]', + dateTag = '[object Date]', + errorTag = '[object Error]', + funcTag = '[object Function]', + genTag = '[object GeneratorFunction]', + mapTag = '[object Map]', + numberTag = '[object Number]', + objectTag = '[object Object]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]', + weakMapTag = '[object WeakMap]'; + +var arrayBufferTag = '[object ArrayBuffer]', + dataViewTag = '[object DataView]', + 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 supported by `_.clone`. */ +var cloneableTags = {}; +cloneableTags[argsTag] = cloneableTags[arrayTag] = +cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] = +cloneableTags[boolTag] = cloneableTags[dateTag] = +cloneableTags[float32Tag] = cloneableTags[float64Tag] = +cloneableTags[int8Tag] = cloneableTags[int16Tag] = +cloneableTags[int32Tag] = cloneableTags[mapTag] = +cloneableTags[numberTag] = cloneableTags[objectTag] = +cloneableTags[regexpTag] = cloneableTags[setTag] = +cloneableTags[stringTag] = cloneableTags[symbolTag] = +cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] = +cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true; +cloneableTags[errorTag] = cloneableTags[funcTag] = +cloneableTags[weakMapTag] = false; + +/** + * The base implementation of `_.clone` and `_.cloneDeep` which tracks + * traversed objects. + * + * @private + * @param {*} value The value to clone. + * @param {boolean} bitmask The bitmask flags. + * 1 - Deep clone + * 2 - Flatten inherited properties + * 4 - Clone symbols + * @param {Function} [customizer] The function to customize cloning. + * @param {string} [key] The key of `value`. + * @param {Object} [object] The parent object of `value`. + * @param {Object} [stack] Tracks traversed objects and their clone counterparts. + * @returns {*} Returns the cloned value. + */ +function baseClone(value, bitmask, customizer, key, object, stack) { + var result, + isDeep = bitmask & CLONE_DEEP_FLAG, + isFlat = bitmask & CLONE_FLAT_FLAG, + isFull = bitmask & CLONE_SYMBOLS_FLAG; + + if (customizer) { + result = object ? customizer(value, key, object, stack) : customizer(value); + } + if (result !== undefined) { + return result; + } + if (!isObject(value)) { + return value; + } + var isArr = isArray(value); + if (isArr) { + result = initCloneArray(value); + if (!isDeep) { + return copyArray(value, result); + } + } else { + var tag = getTag(value), + isFunc = tag == funcTag || tag == genTag; + + if (isBuffer(value)) { + return cloneBuffer(value, isDeep); + } + if (tag == objectTag || tag == argsTag || (isFunc && !object)) { + result = (isFlat || isFunc) ? {} : initCloneObject(value); + if (!isDeep) { + return isFlat + ? copySymbolsIn(value, baseAssignIn(result, value)) + : copySymbols(value, baseAssign(result, value)); + } + } else { + if (!cloneableTags[tag]) { + return object ? value : {}; + } + result = initCloneByTag(value, tag, isDeep); + } + } + // Check for circular references and return its corresponding clone. + stack || (stack = new Stack); + var stacked = stack.get(value); + if (stacked) { + return stacked; + } + stack.set(value, result); + + if (isSet(value)) { + value.forEach(function(subValue) { + result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack)); + }); + + return result; + } + + if (isMap(value)) { + value.forEach(function(subValue, key) { + result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack)); + }); + + return result; + } + + var keysFunc = isFull + ? (isFlat ? getAllKeysIn : getAllKeys) + : (isFlat ? keysIn : keys); + + var props = isArr ? undefined : keysFunc(value); + arrayEach(props || value, function(subValue, key) { + if (props) { + key = subValue; + subValue = value[key]; + } + // Recursively populate clone (susceptible to call stack limits). + assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack)); + }); + return result; +} + +module.exports = baseClone; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseCreate.js": +/***/ (function(module, exports, __webpack_require__) { + +var isObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObject.js"); + +/** Built-in value references. */ +var objectCreate = Object.create; + +/** + * The base implementation of `_.create` without support for assigning + * properties to the created object. + * + * @private + * @param {Object} proto The object to inherit from. + * @returns {Object} Returns the new object. + */ +var baseCreate = (function() { + function object() {} + return function(proto) { + if (!isObject(proto)) { + return {}; + } + if (objectCreate) { + return objectCreate(proto); + } + object.prototype = proto; + var result = new object; + object.prototype = undefined; + return result; + }; +}()); + +module.exports = baseCreate; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseDifference.js": +/***/ (function(module, exports, __webpack_require__) { + +var SetCache = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_SetCache.js"), + arrayIncludes = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayIncludes.js"), + arrayIncludesWith = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayIncludesWith.js"), + arrayMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayMap.js"), + baseUnary = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseUnary.js"), + cacheHas = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cacheHas.js"); + +/** Used as the size to enable large array optimizations. */ +var LARGE_ARRAY_SIZE = 200; + +/** + * The base implementation of methods like `_.difference` without support + * for excluding multiple arrays or iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Array} values The values to exclude. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of filtered values. + */ +function baseDifference(array, values, iteratee, comparator) { + var index = -1, + includes = arrayIncludes, + isCommon = true, + length = array.length, + result = [], + valuesLength = values.length; + + if (!length) { + return result; + } + if (iteratee) { + values = arrayMap(values, baseUnary(iteratee)); + } + if (comparator) { + includes = arrayIncludesWith; + isCommon = false; + } + else if (values.length >= LARGE_ARRAY_SIZE) { + includes = cacheHas; + isCommon = false; + values = new SetCache(values); + } + outer: + while (++index < length) { + var value = array[index], + computed = iteratee == null ? value : iteratee(value); + + value = (comparator || value !== 0) ? value : 0; + if (isCommon && computed === computed) { + var valuesIndex = valuesLength; + while (valuesIndex--) { + if (values[valuesIndex] === computed) { + continue outer; + } + } + result.push(value); + } + else if (!includes(values, computed, comparator)) { + result.push(value); + } + } + return result; +} + +module.exports = baseDifference; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseEach.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseForOwn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseForOwn.js"), + createBaseEach = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_createBaseEach.js"); + +/** + * The base implementation of `_.forEach` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + */ +var baseEach = createBaseEach(baseForOwn); + +module.exports = baseEach; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseFilter.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseEach = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseEach.js"); + +/** + * The base implementation of `_.filter` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + */ +function baseFilter(collection, predicate) { + var result = []; + baseEach(collection, function(value, index, collection) { + if (predicate(value, index, collection)) { + result.push(value); + } + }); + return result; +} + +module.exports = baseFilter; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseFindIndex.js": +/***/ (function(module, exports) { + +/** + * The base implementation of `_.findIndex` and `_.findLastIndex` without + * support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} predicate The function invoked per iteration. + * @param {number} fromIndex The index to search from. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function baseFindIndex(array, predicate, fromIndex, fromRight) { + var length = array.length, + index = fromIndex + (fromRight ? 1 : -1); + + while ((fromRight ? index-- : ++index < length)) { + if (predicate(array[index], index, array)) { + return index; + } + } + return -1; +} + +module.exports = baseFindIndex; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseFlatten.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayPush = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayPush.js"), + isFlattenable = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isFlattenable.js"); + +/** + * The base implementation of `_.flatten` with support for restricting flattening. + * + * @private + * @param {Array} array The array to flatten. + * @param {number} depth The maximum recursion depth. + * @param {boolean} [predicate=isFlattenable] The function invoked per iteration. + * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks. + * @param {Array} [result=[]] The initial result value. + * @returns {Array} Returns the new flattened array. + */ +function baseFlatten(array, depth, predicate, isStrict, result) { + var index = -1, + length = array.length; + + predicate || (predicate = isFlattenable); + result || (result = []); + + while (++index < length) { + var value = array[index]; + if (depth > 0 && predicate(value)) { + if (depth > 1) { + // Recursively flatten arrays (susceptible to call stack limits). + baseFlatten(value, depth - 1, predicate, isStrict, result); + } else { + arrayPush(result, value); + } + } else if (!isStrict) { + result[result.length] = value; + } + } + return result; +} + +module.exports = baseFlatten; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseFor.js": +/***/ (function(module, exports, __webpack_require__) { + +var createBaseFor = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_createBaseFor.js"); + +/** + * The base implementation of `baseForOwn` which iterates over `object` + * properties returned by `keysFunc` and invokes `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(); + +module.exports = baseFor; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseForOwn.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseFor = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseFor.js"), + keys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keys.js"); + +/** + * The base implementation of `_.forOwn` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ +function baseForOwn(object, iteratee) { + return object && baseFor(object, iteratee, keys); +} + +module.exports = baseForOwn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseGet.js": +/***/ (function(module, exports, __webpack_require__) { + +var castPath = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_castPath.js"), + toKey = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_toKey.js"); + +/** + * The base implementation of `_.get` without support for default values. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to get. + * @returns {*} Returns the resolved value. + */ +function baseGet(object, path) { + path = castPath(path, object); + + var index = 0, + length = path.length; + + while (object != null && index < length) { + object = object[toKey(path[index++])]; + } + return (index && index == length) ? object : undefined; +} + +module.exports = baseGet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseGetAllKeys.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayPush = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayPush.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"); + +/** + * The base implementation of `getAllKeys` and `getAllKeysIn` which uses + * `keysFunc` and `symbolsFunc` to get the enumerable property names and + * symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Function} keysFunc The function to get the keys of `object`. + * @param {Function} symbolsFunc The function to get the symbols of `object`. + * @returns {Array} Returns the array of property names and symbols. + */ +function baseGetAllKeys(object, keysFunc, symbolsFunc) { + var result = keysFunc(object); + return isArray(object) ? result : arrayPush(result, symbolsFunc(object)); +} + +module.exports = baseGetAllKeys; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseGetTag.js": +/***/ (function(module, exports, __webpack_require__) { + +var Symbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Symbol.js"), + getRawTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getRawTag.js"), + objectToString = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_objectToString.js"); + +/** `Object#toString` result references. */ +var nullTag = '[object Null]', + undefinedTag = '[object Undefined]'; + +/** Built-in value references. */ +var symToStringTag = Symbol ? Symbol.toStringTag : undefined; + +/** + * The base implementation of `getTag` without fallbacks for buggy environments. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. + */ +function baseGetTag(value) { + if (value == null) { + return value === undefined ? undefinedTag : nullTag; + } + return (symToStringTag && symToStringTag in Object(value)) + ? getRawTag(value) + : objectToString(value); +} + +module.exports = baseGetTag; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseHasIn.js": +/***/ (function(module, exports) { + +/** + * The base implementation of `_.hasIn` without support for deep paths. + * + * @private + * @param {Object} [object] The object to query. + * @param {Array|string} key The key to check. + * @returns {boolean} Returns `true` if `key` exists, else `false`. + */ +function baseHasIn(object, key) { + return object != null && key in Object(object); +} + +module.exports = baseHasIn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIndexOf.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseFindIndex = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseFindIndex.js"), + baseIsNaN = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIsNaN.js"), + strictIndexOf = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_strictIndexOf.js"); + +/** + * The base implementation of `_.indexOf` without `fromIndex` bounds checks. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function baseIndexOf(array, value, fromIndex) { + return value === value + ? strictIndexOf(array, value, fromIndex) + : baseFindIndex(array, baseIsNaN, fromIndex); +} + +module.exports = baseIndexOf; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIntersection.js": +/***/ (function(module, exports, __webpack_require__) { + +var SetCache = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_SetCache.js"), + arrayIncludes = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayIncludes.js"), + arrayIncludesWith = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayIncludesWith.js"), + arrayMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayMap.js"), + baseUnary = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseUnary.js"), + cacheHas = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cacheHas.js"); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMin = Math.min; + +/** + * The base implementation of methods like `_.intersection`, without support + * for iteratee shorthands, that accepts an array of arrays to inspect. + * + * @private + * @param {Array} arrays The arrays to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of shared values. + */ +function baseIntersection(arrays, iteratee, comparator) { + var includes = comparator ? arrayIncludesWith : arrayIncludes, + length = arrays[0].length, + othLength = arrays.length, + othIndex = othLength, + caches = Array(othLength), + maxLength = Infinity, + result = []; + + while (othIndex--) { + var array = arrays[othIndex]; + if (othIndex && iteratee) { + array = arrayMap(array, baseUnary(iteratee)); + } + maxLength = nativeMin(array.length, maxLength); + caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120)) + ? new SetCache(othIndex && array) + : undefined; + } + array = arrays[0]; + + var index = -1, + seen = caches[0]; + + outer: + while (++index < length && result.length < maxLength) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + value = (comparator || value !== 0) ? value : 0; + if (!(seen + ? cacheHas(seen, computed) + : includes(result, computed, comparator) + )) { + othIndex = othLength; + while (--othIndex) { + var cache = caches[othIndex]; + if (!(cache + ? cacheHas(cache, computed) + : includes(arrays[othIndex], computed, comparator)) + ) { + continue outer; + } + } + if (seen) { + seen.push(computed); + } + result.push(value); + } + } + return result; +} + +module.exports = baseIntersection; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIsArguments.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGetTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"), + isObjectLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js"); + +/** `Object#toString` result references. */ +var argsTag = '[object Arguments]'; + +/** + * The base implementation of `_.isArguments`. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an `arguments` object, + */ +function baseIsArguments(value) { + return isObjectLike(value) && baseGetTag(value) == argsTag; +} + +module.exports = baseIsArguments; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIsEqual.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIsEqualDeep = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIsEqualDeep.js"), + isObjectLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js"); + +/** + * The base implementation of `_.isEqual` which supports partial comparisons + * and tracks traversed objects. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @param {boolean} bitmask The bitmask flags. + * 1 - Unordered comparison + * 2 - Partial comparison + * @param {Function} [customizer] The function to customize comparisons. + * @param {Object} [stack] Tracks traversed `value` and `other` objects. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + */ +function baseIsEqual(value, other, bitmask, customizer, stack) { + if (value === other) { + return true; + } + if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) { + return value !== value && other !== other; + } + return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack); +} + +module.exports = baseIsEqual; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIsEqualDeep.js": +/***/ (function(module, exports, __webpack_require__) { + +var Stack = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Stack.js"), + equalArrays = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_equalArrays.js"), + equalByTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_equalByTag.js"), + equalObjects = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_equalObjects.js"), + getTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getTag.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"), + isBuffer = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isBuffer.js"), + isTypedArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isTypedArray.js"); + +/** Used to compose bitmasks for value comparisons. */ +var COMPARE_PARTIAL_FLAG = 1; + +/** `Object#toString` result references. */ +var argsTag = '[object Arguments]', + arrayTag = '[object Array]', + objectTag = '[object Object]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * A specialized version of `baseIsEqual` for arrays and objects which performs + * deep comparisons and tracks traversed objects enabling objects with circular + * references to be compared. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details. + * @param {Function} customizer The function to customize comparisons. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Object} [stack] Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ +function baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) { + var objIsArr = isArray(object), + othIsArr = isArray(other), + objTag = objIsArr ? arrayTag : getTag(object), + othTag = othIsArr ? arrayTag : getTag(other); + + objTag = objTag == argsTag ? objectTag : objTag; + othTag = othTag == argsTag ? objectTag : othTag; + + var objIsObj = objTag == objectTag, + othIsObj = othTag == objectTag, + isSameTag = objTag == othTag; + + if (isSameTag && isBuffer(object)) { + if (!isBuffer(other)) { + return false; + } + objIsArr = true; + objIsObj = false; + } + if (isSameTag && !objIsObj) { + stack || (stack = new Stack); + return (objIsArr || isTypedArray(object)) + ? equalArrays(object, other, bitmask, customizer, equalFunc, stack) + : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack); + } + if (!(bitmask & COMPARE_PARTIAL_FLAG)) { + var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'), + othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__'); + + if (objIsWrapped || othIsWrapped) { + var objUnwrapped = objIsWrapped ? object.value() : object, + othUnwrapped = othIsWrapped ? other.value() : other; + + stack || (stack = new Stack); + return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack); + } + } + if (!isSameTag) { + return false; + } + stack || (stack = new Stack); + return equalObjects(object, other, bitmask, customizer, equalFunc, stack); +} + +module.exports = baseIsEqualDeep; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIsMap.js": +/***/ (function(module, exports, __webpack_require__) { + +var getTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getTag.js"), + isObjectLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js"); + +/** `Object#toString` result references. */ +var mapTag = '[object Map]'; + +/** + * The base implementation of `_.isMap` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a map, else `false`. + */ +function baseIsMap(value) { + return isObjectLike(value) && getTag(value) == mapTag; +} + +module.exports = baseIsMap; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIsMatch.js": +/***/ (function(module, exports, __webpack_require__) { + +var Stack = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Stack.js"), + baseIsEqual = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIsEqual.js"); + +/** Used to compose bitmasks for value comparisons. */ +var COMPARE_PARTIAL_FLAG = 1, + COMPARE_UNORDERED_FLAG = 2; + +/** + * The base implementation of `_.isMatch` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to inspect. + * @param {Object} source The object of property values to match. + * @param {Array} matchData The property names, values, and compare flags to match. + * @param {Function} [customizer] The function to customize comparisons. + * @returns {boolean} Returns `true` if `object` is a match, else `false`. + */ +function baseIsMatch(object, source, matchData, customizer) { + var index = matchData.length, + length = index, + noCustomizer = !customizer; + + if (object == null) { + return !length; + } + object = Object(object); + while (index--) { + var data = matchData[index]; + if ((noCustomizer && data[2]) + ? data[1] !== object[data[0]] + : !(data[0] in object) + ) { + return false; + } + } + while (++index < length) { + data = matchData[index]; + var key = data[0], + objValue = object[key], + srcValue = data[1]; + + if (noCustomizer && data[2]) { + if (objValue === undefined && !(key in object)) { + return false; + } + } else { + var stack = new Stack; + if (customizer) { + var result = customizer(objValue, srcValue, key, object, source, stack); + } + if (!(result === undefined + ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack) + : result + )) { + return false; + } + } + } + return true; +} + +module.exports = baseIsMatch; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIsNaN.js": +/***/ (function(module, exports) { + +/** + * The base implementation of `_.isNaN` without support for number objects. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`. + */ +function baseIsNaN(value) { + return value !== value; +} + +module.exports = baseIsNaN; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIsNative.js": +/***/ (function(module, exports, __webpack_require__) { + +var isFunction = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isFunction.js"), + isMasked = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isMasked.js"), + isObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObject.js"), + toSource = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_toSource.js"); + +/** + * Used to match `RegExp` + * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns). + */ +var reRegExpChar = /[\\^$.*+?()[\]{}|]/g; + +/** Used to detect host constructors (Safari). */ +var reIsHostCtor = /^\[object .+?Constructor\]$/; + +/** Used for built-in method references. */ +var funcProto = Function.prototype, + objectProto = Object.prototype; + +/** Used to resolve the decompiled source of functions. */ +var funcToString = funcProto.toString; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** Used to detect if a method is native. */ +var reIsNative = RegExp('^' + + funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\$&') + .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$' +); + +/** + * The base implementation of `_.isNative` without bad shim checks. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a native function, + * else `false`. + */ +function baseIsNative(value) { + if (!isObject(value) || isMasked(value)) { + return false; + } + var pattern = isFunction(value) ? reIsNative : reIsHostCtor; + return pattern.test(toSource(value)); +} + +module.exports = baseIsNative; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIsSet.js": +/***/ (function(module, exports, __webpack_require__) { + +var getTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getTag.js"), + isObjectLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js"); + +/** `Object#toString` result references. */ +var setTag = '[object Set]'; + +/** + * The base implementation of `_.isSet` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a set, else `false`. + */ +function baseIsSet(value) { + return isObjectLike(value) && getTag(value) == setTag; +} + +module.exports = baseIsSet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIsTypedArray.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGetTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"), + isLength = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isLength.js"), + isObjectLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js"); + +/** `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]', + dataViewTag = '[object DataView]', + 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[dataViewTag] = typedArrayTags[dateTag] = +typedArrayTags[errorTag] = typedArrayTags[funcTag] = +typedArrayTags[mapTag] = typedArrayTags[numberTag] = +typedArrayTags[objectTag] = typedArrayTags[regexpTag] = +typedArrayTags[setTag] = typedArrayTags[stringTag] = +typedArrayTags[weakMapTag] = false; + +/** + * The base implementation of `_.isTypedArray` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a typed array, else `false`. + */ +function baseIsTypedArray(value) { + return isObjectLike(value) && + isLength(value.length) && !!typedArrayTags[baseGetTag(value)]; +} + +module.exports = baseIsTypedArray; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseIteratee.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseMatches = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseMatches.js"), + baseMatchesProperty = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseMatchesProperty.js"), + identity = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/identity.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"), + property = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/property.js"); + +/** + * The base implementation of `_.iteratee`. + * + * @private + * @param {*} [value=_.identity] The value to convert to an iteratee. + * @returns {Function} Returns the iteratee. + */ +function baseIteratee(value) { + // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9. + // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details. + if (typeof value == 'function') { + return value; + } + if (value == null) { + return identity; + } + if (typeof value == 'object') { + return isArray(value) + ? baseMatchesProperty(value[0], value[1]) + : baseMatches(value); + } + return property(value); +} + +module.exports = baseIteratee; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseKeys.js": +/***/ (function(module, exports, __webpack_require__) { + +var isPrototype = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isPrototype.js"), + nativeKeys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_nativeKeys.js"); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * The base implementation of `_.keys` which doesn't treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ +function baseKeys(object) { + if (!isPrototype(object)) { + return nativeKeys(object); + } + var result = []; + for (var key in Object(object)) { + if (hasOwnProperty.call(object, key) && key != 'constructor') { + result.push(key); + } + } + return result; +} + +module.exports = baseKeys; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseKeysIn.js": +/***/ (function(module, exports, __webpack_require__) { + +var isObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObject.js"), + isPrototype = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isPrototype.js"), + nativeKeysIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_nativeKeysIn.js"); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ +function baseKeysIn(object) { + if (!isObject(object)) { + return nativeKeysIn(object); + } + var isProto = isPrototype(object), + result = []; + + for (var key in object) { + if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { + result.push(key); + } + } + return result; +} + +module.exports = baseKeysIn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseMap.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseEach = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseEach.js"), + isArrayLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js"); + +/** + * The base implementation of `_.map` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ +function baseMap(collection, iteratee) { + var index = -1, + result = isArrayLike(collection) ? Array(collection.length) : []; + + baseEach(collection, function(value, key, collection) { + result[++index] = iteratee(value, key, collection); + }); + return result; +} + +module.exports = baseMap; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseMatches.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIsMatch = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIsMatch.js"), + getMatchData = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getMatchData.js"), + matchesStrictComparable = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_matchesStrictComparable.js"); + +/** + * The base implementation of `_.matches` which doesn't clone `source`. + * + * @private + * @param {Object} source The object of property values to match. + * @returns {Function} Returns the new spec function. + */ +function baseMatches(source) { + var matchData = getMatchData(source); + if (matchData.length == 1 && matchData[0][2]) { + return matchesStrictComparable(matchData[0][0], matchData[0][1]); + } + return function(object) { + return object === source || baseIsMatch(object, source, matchData); + }; +} + +module.exports = baseMatches; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseMatchesProperty.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIsEqual = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIsEqual.js"), + get = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/get.js"), + hasIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/hasIn.js"), + isKey = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isKey.js"), + isStrictComparable = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isStrictComparable.js"), + matchesStrictComparable = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_matchesStrictComparable.js"), + toKey = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_toKey.js"); + +/** Used to compose bitmasks for value comparisons. */ +var COMPARE_PARTIAL_FLAG = 1, + COMPARE_UNORDERED_FLAG = 2; + +/** + * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`. + * + * @private + * @param {string} path The path of the property to get. + * @param {*} srcValue The value to match. + * @returns {Function} Returns the new spec function. + */ +function baseMatchesProperty(path, srcValue) { + if (isKey(path) && isStrictComparable(srcValue)) { + return matchesStrictComparable(toKey(path), srcValue); + } + return function(object) { + var objValue = get(object, path); + return (objValue === undefined && objValue === srcValue) + ? hasIn(object, path) + : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG); + }; +} + +module.exports = baseMatchesProperty; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseOrderBy.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayMap.js"), + baseIteratee = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIteratee.js"), + baseMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseMap.js"), + baseSortBy = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseSortBy.js"), + baseUnary = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseUnary.js"), + compareMultiple = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_compareMultiple.js"), + identity = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/identity.js"); + +/** + * The base implementation of `_.orderBy` without param guards. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by. + * @param {string[]} orders The sort orders of `iteratees`. + * @returns {Array} Returns the new sorted array. + */ +function baseOrderBy(collection, iteratees, orders) { + var index = -1; + iteratees = arrayMap(iteratees.length ? iteratees : [identity], baseUnary(baseIteratee)); + + var result = baseMap(collection, function(value, key, collection) { + var criteria = arrayMap(iteratees, function(iteratee) { + return iteratee(value); + }); + return { 'criteria': criteria, 'index': ++index, 'value': value }; + }); + + return baseSortBy(result, function(object, other) { + return compareMultiple(object, other, orders); + }); +} + +module.exports = baseOrderBy; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_basePick.js": +/***/ (function(module, exports, __webpack_require__) { + +var basePickBy = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_basePickBy.js"), + hasIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/hasIn.js"); + +/** + * The base implementation of `_.pick` without support for individual + * property identifiers. + * + * @private + * @param {Object} object The source object. + * @param {string[]} paths The property paths to pick. + * @returns {Object} Returns the new object. + */ +function basePick(object, paths) { + return basePickBy(object, paths, function(value, path) { + return hasIn(object, path); + }); +} + +module.exports = basePick; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_basePickBy.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGet.js"), + baseSet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseSet.js"), + castPath = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_castPath.js"); + +/** + * The base implementation of `_.pickBy` without support for iteratee shorthands. + * + * @private + * @param {Object} object The source object. + * @param {string[]} paths The property paths to pick. + * @param {Function} predicate The function invoked per property. + * @returns {Object} Returns the new object. + */ +function basePickBy(object, paths, predicate) { + var index = -1, + length = paths.length, + result = {}; + + while (++index < length) { + var path = paths[index], + value = baseGet(object, path); + + if (predicate(value, path)) { + baseSet(result, castPath(path, object), value); + } + } + return result; +} + +module.exports = basePickBy; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseProperty.js": +/***/ (function(module, exports) { + +/** + * 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 accessor function. + */ +function baseProperty(key) { + return function(object) { + return object == null ? undefined : object[key]; + }; +} + +module.exports = baseProperty; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_basePropertyDeep.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGet.js"); + +/** + * A specialized version of `baseProperty` which supports deep paths. + * + * @private + * @param {Array|string} path The path of the property to get. + * @returns {Function} Returns the new accessor function. + */ +function basePropertyDeep(path) { + return function(object) { + return baseGet(object, path); + }; +} + +module.exports = basePropertyDeep; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseRest.js": +/***/ (function(module, exports, __webpack_require__) { + +var identity = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/identity.js"), + overRest = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_overRest.js"), + setToString = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_setToString.js"); + +/** + * The base implementation of `_.rest` which doesn't validate or coerce arguments. + * + * @private + * @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. + */ +function baseRest(func, start) { + return setToString(overRest(func, start, identity), func + ''); +} + +module.exports = baseRest; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseSet.js": +/***/ (function(module, exports, __webpack_require__) { + +var assignValue = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_assignValue.js"), + castPath = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_castPath.js"), + isIndex = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isIndex.js"), + isObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObject.js"), + toKey = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_toKey.js"); + +/** + * The base implementation of `_.set`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {*} value The value to set. + * @param {Function} [customizer] The function to customize path creation. + * @returns {Object} Returns `object`. + */ +function baseSet(object, path, value, customizer) { + if (!isObject(object)) { + return object; + } + path = castPath(path, object); + + var index = -1, + length = path.length, + lastIndex = length - 1, + nested = object; + + while (nested != null && ++index < length) { + var key = toKey(path[index]), + newValue = value; + + if (index != lastIndex) { + var objValue = nested[key]; + newValue = customizer ? customizer(objValue, key, nested) : undefined; + if (newValue === undefined) { + newValue = isObject(objValue) + ? objValue + : (isIndex(path[index + 1]) ? [] : {}); + } + } + assignValue(nested, key, newValue); + nested = nested[key]; + } + return object; +} + +module.exports = baseSet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseSetToString.js": +/***/ (function(module, exports, __webpack_require__) { + +var constant = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/constant.js"), + defineProperty = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_defineProperty.js"), + identity = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/identity.js"); + +/** + * The base implementation of `setToString` without support for hot loop shorting. + * + * @private + * @param {Function} func The function to modify. + * @param {Function} string The `toString` result. + * @returns {Function} Returns `func`. + */ +var baseSetToString = !defineProperty ? identity : function(func, string) { + return defineProperty(func, 'toString', { + 'configurable': true, + 'enumerable': false, + 'value': constant(string), + 'writable': true + }); +}; + +module.exports = baseSetToString; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseSlice.js": +/***/ (function(module, exports) { + +/** + * The base implementation of `_.slice` without an iteratee call guard. + * + * @private + * @param {Array} array The array to slice. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the slice of `array`. + */ +function baseSlice(array, start, end) { + var index = -1, + length = array.length; + + if (start < 0) { + start = -start > length ? 0 : (length + start); + } + end = end > length ? length : end; + if (end < 0) { + end += length; + } + length = start > end ? 0 : ((end - start) >>> 0); + start >>>= 0; + + var result = Array(length); + while (++index < length) { + result[index] = array[index + start]; + } + return result; +} + +module.exports = baseSlice; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseSortBy.js": +/***/ (function(module, exports) { + +/** + * The base implementation of `_.sortBy` which uses `comparer` to define the + * sort order of `array` and replaces criteria objects with their corresponding + * values. + * + * @private + * @param {Array} array The array to sort. + * @param {Function} comparer The function to define sort order. + * @returns {Array} Returns `array`. + */ +function baseSortBy(array, comparer) { + var length = array.length; + + array.sort(comparer); + while (length--) { + array[length] = array[length].value; + } + return array; +} + +module.exports = baseSortBy; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseTimes.js": +/***/ (function(module, exports) { + +/** + * The base implementation of `_.times` without support for iteratee shorthands + * or max array length checks. + * + * @private + * @param {number} n The number of times to invoke `iteratee`. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the array of results. + */ +function baseTimes(n, iteratee) { + var index = -1, + result = Array(n); + + while (++index < n) { + result[index] = iteratee(index); + } + return result; +} + +module.exports = baseTimes; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseToPairs.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayMap.js"); + +/** + * The base implementation of `_.toPairs` and `_.toPairsIn` which creates an array + * of key-value pairs for `object` corresponding to the property names of `props`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} props The property names to get values for. + * @returns {Object} Returns the key-value pairs. + */ +function baseToPairs(object, props) { + return arrayMap(props, function(key) { + return [key, object[key]]; + }); +} + +module.exports = baseToPairs; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseToString.js": +/***/ (function(module, exports, __webpack_require__) { + +var Symbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Symbol.js"), + arrayMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayMap.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"), + isSymbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isSymbol.js"); + +/** Used as references for various `Number` constants. */ +var INFINITY = 1 / 0; + +/** Used to convert symbols to primitives and strings. */ +var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolToString = symbolProto ? symbolProto.toString : undefined; + +/** + * The base implementation of `_.toString` which doesn't convert nullish + * values to empty strings. + * + * @private + * @param {*} value The value to process. + * @returns {string} Returns the string. + */ +function baseToString(value) { + // Exit early for strings to avoid a performance hit in some environments. + if (typeof value == 'string') { + return value; + } + if (isArray(value)) { + // Recursively convert values (susceptible to call stack limits). + return arrayMap(value, baseToString) + ''; + } + if (isSymbol(value)) { + return symbolToString ? symbolToString.call(value) : ''; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; +} + +module.exports = baseToString; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseUnary.js": +/***/ (function(module, exports) { + +/** + * The base implementation of `_.unary` without support for storing metadata. + * + * @private + * @param {Function} func The function to cap arguments for. + * @returns {Function} Returns the new capped function. + */ +function baseUnary(func) { + return function(value) { + return func(value); + }; +} + +module.exports = baseUnary; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseUnset.js": +/***/ (function(module, exports, __webpack_require__) { + +var castPath = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_castPath.js"), + last = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/last.js"), + parent = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_parent.js"), + toKey = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_toKey.js"); + +/** + * The base implementation of `_.unset`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The property path to unset. + * @returns {boolean} Returns `true` if the property is deleted, else `false`. + */ +function baseUnset(object, path) { + path = castPath(path, object); + object = parent(object, path); + return object == null || delete object[toKey(last(path))]; +} + +module.exports = baseUnset; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseValues.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayMap.js"); + +/** + * The base implementation of `_.values` and `_.valuesIn` which creates an + * array of `object` property values corresponding to the property names + * of `props`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} props The property names to get values for. + * @returns {Object} Returns the array of property values. + */ +function baseValues(object, props) { + return arrayMap(props, function(key) { + return object[key]; + }); +} + +module.exports = baseValues; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_baseZipObject.js": +/***/ (function(module, exports) { + +/** + * This base implementation of `_.zipObject` which assigns values using `assignFunc`. + * + * @private + * @param {Array} props The property identifiers. + * @param {Array} values The property values. + * @param {Function} assignFunc The function to assign values. + * @returns {Object} Returns the new object. + */ +function baseZipObject(props, values, assignFunc) { + var index = -1, + length = props.length, + valsLength = values.length, + result = {}; + + while (++index < length) { + var value = index < valsLength ? values[index] : undefined; + assignFunc(result, props[index], value); + } + return result; +} + +module.exports = baseZipObject; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_cacheHas.js": +/***/ (function(module, exports) { + +/** + * Checks if a `cache` value for `key` exists. + * + * @private + * @param {Object} cache The cache to query. + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function cacheHas(cache, key) { + return cache.has(key); +} + +module.exports = cacheHas; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_castArrayLikeObject.js": +/***/ (function(module, exports, __webpack_require__) { + +var isArrayLikeObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLikeObject.js"); + +/** + * Casts `value` to an empty array if it's not an array like object. + * + * @private + * @param {*} value The value to inspect. + * @returns {Array|Object} Returns the cast array-like object. + */ +function castArrayLikeObject(value) { + return isArrayLikeObject(value) ? value : []; +} + +module.exports = castArrayLikeObject; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_castFunction.js": +/***/ (function(module, exports, __webpack_require__) { + +var identity = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/identity.js"); + +/** + * Casts `value` to `identity` if it's not a function. + * + * @private + * @param {*} value The value to inspect. + * @returns {Function} Returns cast function. + */ +function castFunction(value) { + return typeof value == 'function' ? value : identity; +} + +module.exports = castFunction; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_castPath.js": +/***/ (function(module, exports, __webpack_require__) { + +var isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"), + isKey = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isKey.js"), + stringToPath = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_stringToPath.js"), + toString = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/toString.js"); + +/** + * Casts `value` to a path array if it's not one. + * + * @private + * @param {*} value The value to inspect. + * @param {Object} [object] The object to query keys on. + * @returns {Array} Returns the cast property path array. + */ +function castPath(value, object) { + if (isArray(value)) { + return value; + } + return isKey(value, object) ? [value] : stringToPath(toString(value)); +} + +module.exports = castPath; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_cloneArrayBuffer.js": +/***/ (function(module, exports, __webpack_require__) { + +var Uint8Array = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Uint8Array.js"); + +/** + * Creates a clone of `arrayBuffer`. + * + * @private + * @param {ArrayBuffer} arrayBuffer The array buffer to clone. + * @returns {ArrayBuffer} Returns the cloned array buffer. + */ +function cloneArrayBuffer(arrayBuffer) { + var result = new arrayBuffer.constructor(arrayBuffer.byteLength); + new Uint8Array(result).set(new Uint8Array(arrayBuffer)); + return result; +} + +module.exports = cloneArrayBuffer; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_cloneBuffer.js": +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_root.js"); + +/** Detect free variable `exports`. */ +var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports; + +/** Detect free variable `module`. */ +var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; + +/** Detect the popular CommonJS extension `module.exports`. */ +var moduleExports = freeModule && freeModule.exports === freeExports; + +/** Built-in value references. */ +var Buffer = moduleExports ? root.Buffer : undefined, + allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined; + +/** + * Creates a clone of `buffer`. + * + * @private + * @param {Buffer} buffer The buffer to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Buffer} Returns the cloned buffer. + */ +function cloneBuffer(buffer, isDeep) { + if (isDeep) { + return buffer.slice(); + } + var length = buffer.length, + result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length); + + buffer.copy(result); + return result; +} + +module.exports = cloneBuffer; + +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__("../../../node_modules/webpack/buildin/module.js")(module))) + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_cloneDataView.js": +/***/ (function(module, exports, __webpack_require__) { + +var cloneArrayBuffer = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cloneArrayBuffer.js"); + +/** + * Creates a clone of `dataView`. + * + * @private + * @param {Object} dataView The data view to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned data view. + */ +function cloneDataView(dataView, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer; + return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength); +} + +module.exports = cloneDataView; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_cloneRegExp.js": +/***/ (function(module, exports) { + +/** Used to match `RegExp` flags from their coerced string values. */ +var reFlags = /\w*$/; + +/** + * Creates a clone of `regexp`. + * + * @private + * @param {Object} regexp The regexp to clone. + * @returns {Object} Returns the cloned regexp. + */ +function cloneRegExp(regexp) { + var result = new regexp.constructor(regexp.source, reFlags.exec(regexp)); + result.lastIndex = regexp.lastIndex; + return result; +} + +module.exports = cloneRegExp; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_cloneSymbol.js": +/***/ (function(module, exports, __webpack_require__) { + +var Symbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Symbol.js"); + +/** Used to convert symbols to primitives and strings. */ +var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolValueOf = symbolProto ? symbolProto.valueOf : undefined; + +/** + * Creates a clone of the `symbol` object. + * + * @private + * @param {Object} symbol The symbol object to clone. + * @returns {Object} Returns the cloned symbol object. + */ +function cloneSymbol(symbol) { + return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {}; +} + +module.exports = cloneSymbol; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_cloneTypedArray.js": +/***/ (function(module, exports, __webpack_require__) { + +var cloneArrayBuffer = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cloneArrayBuffer.js"); + +/** + * Creates a clone of `typedArray`. + * + * @private + * @param {Object} typedArray The typed array to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned typed array. + */ +function cloneTypedArray(typedArray, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer; + return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length); +} + +module.exports = cloneTypedArray; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_compareAscending.js": +/***/ (function(module, exports, __webpack_require__) { + +var isSymbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isSymbol.js"); + +/** + * Compares values to sort them in ascending order. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {number} Returns the sort order indicator for `value`. + */ +function compareAscending(value, other) { + if (value !== other) { + var valIsDefined = value !== undefined, + valIsNull = value === null, + valIsReflexive = value === value, + valIsSymbol = isSymbol(value); + + var othIsDefined = other !== undefined, + othIsNull = other === null, + othIsReflexive = other === other, + othIsSymbol = isSymbol(other); + + if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) || + (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) || + (valIsNull && othIsDefined && othIsReflexive) || + (!valIsDefined && othIsReflexive) || + !valIsReflexive) { + return 1; + } + if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) || + (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) || + (othIsNull && valIsDefined && valIsReflexive) || + (!othIsDefined && valIsReflexive) || + !othIsReflexive) { + return -1; + } + } + return 0; +} + +module.exports = compareAscending; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_compareMultiple.js": +/***/ (function(module, exports, __webpack_require__) { + +var compareAscending = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_compareAscending.js"); + +/** + * Used by `_.orderBy` to compare multiple properties of a value to another + * and stable sort them. + * + * If `orders` is unspecified, all values are sorted in ascending order. Otherwise, + * specify an order of "desc" for descending or "asc" for ascending sort order + * of corresponding values. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {boolean[]|string[]} orders The order to sort by for each property. + * @returns {number} Returns the sort order indicator for `object`. + */ +function compareMultiple(object, other, orders) { + var index = -1, + objCriteria = object.criteria, + othCriteria = other.criteria, + length = objCriteria.length, + ordersLength = orders.length; + + while (++index < length) { + var result = compareAscending(objCriteria[index], othCriteria[index]); + if (result) { + if (index >= ordersLength) { + return result; + } + var order = orders[index]; + return result * (order == 'desc' ? -1 : 1); + } + } + // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications + // that causes it, under certain circumstances, to provide the same value for + // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247 + // for more details. + // + // This also ensures a stable sort in V8 and other engines. + // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details. + return object.index - other.index; +} + +module.exports = compareMultiple; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_copyArray.js": +/***/ (function(module, exports) { + +/** + * 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 copyArray(source, array) { + var index = -1, + length = source.length; + + array || (array = Array(length)); + while (++index < length) { + array[index] = source[index]; + } + return array; +} + +module.exports = copyArray; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_copyObject.js": +/***/ (function(module, exports, __webpack_require__) { + +var assignValue = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_assignValue.js"), + baseAssignValue = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseAssignValue.js"); + +/** + * Copies properties of `source` to `object`. + * + * @private + * @param {Object} source The object to copy properties from. + * @param {Array} props The property identifiers to copy. + * @param {Object} [object={}] The object to copy properties to. + * @param {Function} [customizer] The function to customize copied values. + * @returns {Object} Returns `object`. + */ +function copyObject(source, props, object, customizer) { + var isNew = !object; + object || (object = {}); + + var index = -1, + length = props.length; + + while (++index < length) { + var key = props[index]; + + var newValue = customizer + ? customizer(object[key], source[key], key, object, source) + : undefined; + + if (newValue === undefined) { + newValue = source[key]; + } + if (isNew) { + baseAssignValue(object, key, newValue); + } else { + assignValue(object, key, newValue); + } + } + return object; +} + +module.exports = copyObject; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_copySymbols.js": +/***/ (function(module, exports, __webpack_require__) { + +var copyObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_copyObject.js"), + getSymbols = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getSymbols.js"); + +/** + * Copies own symbols of `source` to `object`. + * + * @private + * @param {Object} source The object to copy symbols from. + * @param {Object} [object={}] The object to copy symbols to. + * @returns {Object} Returns `object`. + */ +function copySymbols(source, object) { + return copyObject(source, getSymbols(source), object); +} + +module.exports = copySymbols; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_copySymbolsIn.js": +/***/ (function(module, exports, __webpack_require__) { + +var copyObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_copyObject.js"), + getSymbolsIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getSymbolsIn.js"); + +/** + * Copies own and inherited symbols of `source` to `object`. + * + * @private + * @param {Object} source The object to copy symbols from. + * @param {Object} [object={}] The object to copy symbols to. + * @returns {Object} Returns `object`. + */ +function copySymbolsIn(source, object) { + return copyObject(source, getSymbolsIn(source), object); +} + +module.exports = copySymbolsIn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_coreJsData.js": +/***/ (function(module, exports, __webpack_require__) { + +var root = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_root.js"); + +/** Used to detect overreaching core-js shims. */ +var coreJsData = root['__core-js_shared__']; + +module.exports = coreJsData; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_createAssigner.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseRest = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseRest.js"), + isIterateeCall = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isIterateeCall.js"); + +/** + * Creates a function like `_.assign`. + * + * @private + * @param {Function} assigner The function to assign values. + * @returns {Function} Returns the new assigner function. + */ +function createAssigner(assigner) { + return baseRest(function(object, sources) { + var index = -1, + length = sources.length, + customizer = length > 1 ? sources[length - 1] : undefined, + guard = length > 2 ? sources[2] : undefined; + + customizer = (assigner.length > 3 && typeof customizer == 'function') + ? (length--, customizer) + : undefined; + + if (guard && isIterateeCall(sources[0], sources[1], guard)) { + customizer = length < 3 ? undefined : customizer; + length = 1; + } + object = Object(object); + while (++index < length) { + var source = sources[index]; + if (source) { + assigner(object, source, index, customizer); + } + } + return object; + }); +} + +module.exports = createAssigner; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_createBaseEach.js": +/***/ (function(module, exports, __webpack_require__) { + +var isArrayLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js"); + +/** + * Creates a `baseEach` or `baseEachRight` function. + * + * @private + * @param {Function} eachFunc The function to iterate over a collection. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. + */ +function createBaseEach(eachFunc, fromRight) { + return function(collection, iteratee) { + if (collection == null) { + return collection; + } + if (!isArrayLike(collection)) { + return eachFunc(collection, iteratee); + } + var length = collection.length, + index = fromRight ? length : -1, + iterable = Object(collection); + + while ((fromRight ? index-- : ++index < length)) { + if (iteratee(iterable[index], index, iterable) === false) { + break; + } + } + return collection; + }; +} + +module.exports = createBaseEach; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_createBaseFor.js": +/***/ (function(module, exports) { + +/** + * Creates a base function for methods like `_.forIn` and `_.forOwn`. + * + * @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 = createBaseFor; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_createFind.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIteratee = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIteratee.js"), + isArrayLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js"), + keys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keys.js"); + +/** + * Creates a `_.find` or `_.findLast` function. + * + * @private + * @param {Function} findIndexFunc The function to find the collection index. + * @returns {Function} Returns the new find function. + */ +function createFind(findIndexFunc) { + return function(collection, predicate, fromIndex) { + var iterable = Object(collection); + if (!isArrayLike(collection)) { + var iteratee = baseIteratee(predicate, 3); + collection = keys(collection); + predicate = function(key) { return iteratee(iterable[key], key, iterable); }; + } + var index = findIndexFunc(collection, predicate, fromIndex); + return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined; + }; +} + +module.exports = createFind; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_createToPairs.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseToPairs = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseToPairs.js"), + getTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getTag.js"), + mapToArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_mapToArray.js"), + setToPairs = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_setToPairs.js"); + +/** `Object#toString` result references. */ +var mapTag = '[object Map]', + setTag = '[object Set]'; + +/** + * Creates a `_.toPairs` or `_.toPairsIn` function. + * + * @private + * @param {Function} keysFunc The function to get the keys of a given object. + * @returns {Function} Returns the new pairs function. + */ +function createToPairs(keysFunc) { + return function(object) { + var tag = getTag(object); + if (tag == mapTag) { + return mapToArray(object); + } + if (tag == setTag) { + return setToPairs(object); + } + return baseToPairs(object, keysFunc(object)); + }; +} + +module.exports = createToPairs; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_customOmitClone.js": +/***/ (function(module, exports, __webpack_require__) { + +var isPlainObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isPlainObject.js"); + +/** + * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain + * objects. + * + * @private + * @param {*} value The value to inspect. + * @param {string} key The key of the property to inspect. + * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`. + */ +function customOmitClone(value) { + return isPlainObject(value) ? undefined : value; +} + +module.exports = customOmitClone; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_defineProperty.js": +/***/ (function(module, exports, __webpack_require__) { + +var getNative = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getNative.js"); + +var defineProperty = (function() { + try { + var func = getNative(Object, 'defineProperty'); + func({}, '', {}); + return func; + } catch (e) {} +}()); + +module.exports = defineProperty; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_equalArrays.js": +/***/ (function(module, exports, __webpack_require__) { + +var SetCache = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_SetCache.js"), + arraySome = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arraySome.js"), + cacheHas = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cacheHas.js"); + +/** Used to compose bitmasks for value comparisons. */ +var COMPARE_PARTIAL_FLAG = 1, + COMPARE_UNORDERED_FLAG = 2; + +/** + * A specialized version of `baseIsEqualDeep` for arrays with support for + * partial deep comparisons. + * + * @private + * @param {Array} array The array to compare. + * @param {Array} other The other array to compare. + * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details. + * @param {Function} customizer The function to customize comparisons. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Object} stack Tracks traversed `array` and `other` objects. + * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`. + */ +function equalArrays(array, other, bitmask, customizer, equalFunc, stack) { + var isPartial = bitmask & COMPARE_PARTIAL_FLAG, + arrLength = array.length, + othLength = other.length; + + if (arrLength != othLength && !(isPartial && othLength > arrLength)) { + return false; + } + // Assume cyclic values are equal. + var stacked = stack.get(array); + if (stacked && stack.get(other)) { + return stacked == other; + } + var index = -1, + result = true, + seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined; + + stack.set(array, other); + stack.set(other, array); + + // Ignore non-index properties. + while (++index < arrLength) { + var arrValue = array[index], + othValue = other[index]; + + if (customizer) { + var compared = isPartial + ? customizer(othValue, arrValue, index, other, array, stack) + : customizer(arrValue, othValue, index, array, other, stack); + } + if (compared !== undefined) { + if (compared) { + continue; + } + result = false; + break; + } + // Recursively compare arrays (susceptible to call stack limits). + if (seen) { + if (!arraySome(other, function(othValue, othIndex) { + if (!cacheHas(seen, othIndex) && + (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) { + return seen.push(othIndex); + } + })) { + result = false; + break; + } + } else if (!( + arrValue === othValue || + equalFunc(arrValue, othValue, bitmask, customizer, stack) + )) { + result = false; + break; + } + } + stack['delete'](array); + stack['delete'](other); + return result; +} + +module.exports = equalArrays; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_equalByTag.js": +/***/ (function(module, exports, __webpack_require__) { + +var Symbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Symbol.js"), + Uint8Array = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Uint8Array.js"), + eq = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/eq.js"), + equalArrays = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_equalArrays.js"), + mapToArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_mapToArray.js"), + setToArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_setToArray.js"); + +/** Used to compose bitmasks for value comparisons. */ +var COMPARE_PARTIAL_FLAG = 1, + COMPARE_UNORDERED_FLAG = 2; + +/** `Object#toString` result references. */ +var boolTag = '[object Boolean]', + dateTag = '[object Date]', + errorTag = '[object Error]', + mapTag = '[object Map]', + numberTag = '[object Number]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]'; + +var arrayBufferTag = '[object ArrayBuffer]', + dataViewTag = '[object DataView]'; + +/** Used to convert symbols to primitives and strings. */ +var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolValueOf = symbolProto ? symbolProto.valueOf : undefined; + +/** + * A specialized version of `baseIsEqualDeep` for comparing objects of + * the same `toStringTag`. + * + * **Note:** This function only supports comparing values with tags of + * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {string} tag The `toStringTag` of the objects to compare. + * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details. + * @param {Function} customizer The function to customize comparisons. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Object} stack Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ +function equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) { + switch (tag) { + case dataViewTag: + if ((object.byteLength != other.byteLength) || + (object.byteOffset != other.byteOffset)) { + return false; + } + object = object.buffer; + other = other.buffer; + + case arrayBufferTag: + if ((object.byteLength != other.byteLength) || + !equalFunc(new Uint8Array(object), new Uint8Array(other))) { + return false; + } + return true; + + case boolTag: + case dateTag: + case numberTag: + // Coerce booleans to `1` or `0` and dates to milliseconds. + // Invalid dates are coerced to `NaN`. + return eq(+object, +other); + + case errorTag: + return object.name == other.name && object.message == other.message; + + case regexpTag: + case stringTag: + // Coerce regexes to strings and treat strings, primitives and objects, + // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring + // for more details. + return object == (other + ''); + + case mapTag: + var convert = mapToArray; + + case setTag: + var isPartial = bitmask & COMPARE_PARTIAL_FLAG; + convert || (convert = setToArray); + + if (object.size != other.size && !isPartial) { + return false; + } + // Assume cyclic values are equal. + var stacked = stack.get(object); + if (stacked) { + return stacked == other; + } + bitmask |= COMPARE_UNORDERED_FLAG; + + // Recursively compare objects (susceptible to call stack limits). + stack.set(object, other); + var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack); + stack['delete'](object); + return result; + + case symbolTag: + if (symbolValueOf) { + return symbolValueOf.call(object) == symbolValueOf.call(other); + } + } + return false; +} + +module.exports = equalByTag; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_equalObjects.js": +/***/ (function(module, exports, __webpack_require__) { + +var getAllKeys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getAllKeys.js"); + +/** Used to compose bitmasks for value comparisons. */ +var COMPARE_PARTIAL_FLAG = 1; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * A specialized version of `baseIsEqualDeep` for objects with support for + * partial deep comparisons. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details. + * @param {Function} customizer The function to customize comparisons. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Object} stack Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ +function equalObjects(object, other, bitmask, customizer, equalFunc, stack) { + var isPartial = bitmask & COMPARE_PARTIAL_FLAG, + objProps = getAllKeys(object), + objLength = objProps.length, + othProps = getAllKeys(other), + othLength = othProps.length; + + if (objLength != othLength && !isPartial) { + return false; + } + var index = objLength; + while (index--) { + var key = objProps[index]; + if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) { + return false; + } + } + // Assume cyclic values are equal. + var stacked = stack.get(object); + if (stacked && stack.get(other)) { + return stacked == other; + } + var result = true; + stack.set(object, other); + stack.set(other, object); + + var skipCtor = isPartial; + while (++index < objLength) { + key = objProps[index]; + var objValue = object[key], + othValue = other[key]; + + if (customizer) { + var compared = isPartial + ? customizer(othValue, objValue, key, other, object, stack) + : customizer(objValue, othValue, key, object, other, stack); + } + // Recursively compare objects (susceptible to call stack limits). + if (!(compared === undefined + ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack)) + : compared + )) { + result = false; + break; + } + skipCtor || (skipCtor = key == 'constructor'); + } + if (result && !skipCtor) { + var objCtor = object.constructor, + othCtor = other.constructor; + + // Non `Object` object instances with different constructors are not equal. + if (objCtor != othCtor && + ('constructor' in object && 'constructor' in other) && + !(typeof objCtor == 'function' && objCtor instanceof objCtor && + typeof othCtor == 'function' && othCtor instanceof othCtor)) { + result = false; + } + } + stack['delete'](object); + stack['delete'](other); + return result; +} + +module.exports = equalObjects; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_flatRest.js": +/***/ (function(module, exports, __webpack_require__) { + +var flatten = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/flatten.js"), + overRest = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_overRest.js"), + setToString = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_setToString.js"); + +/** + * A specialized version of `baseRest` which flattens the rest array. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @returns {Function} Returns the new function. + */ +function flatRest(func) { + return setToString(overRest(func, undefined, flatten), func + ''); +} + +module.exports = flatRest; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_freeGlobal.js": +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(global) {/** Detect free variable `global` from Node.js. */ +var freeGlobal = typeof global == 'object' && global && global.Object === Object && global; + +module.exports = freeGlobal; + +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__("../../../node_modules/webpack/buildin/global.js"))) + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getAllKeys.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGetAllKeys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGetAllKeys.js"), + getSymbols = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getSymbols.js"), + keys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keys.js"); + +/** + * Creates an array of own enumerable property names and symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names and symbols. + */ +function getAllKeys(object) { + return baseGetAllKeys(object, keys, getSymbols); +} + +module.exports = getAllKeys; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getAllKeysIn.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGetAllKeys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGetAllKeys.js"), + getSymbolsIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getSymbolsIn.js"), + keysIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keysIn.js"); + +/** + * Creates an array of own and inherited enumerable property names and + * symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names and symbols. + */ +function getAllKeysIn(object) { + return baseGetAllKeys(object, keysIn, getSymbolsIn); +} + +module.exports = getAllKeysIn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getMapData.js": +/***/ (function(module, exports, __webpack_require__) { + +var isKeyable = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isKeyable.js"); + +/** + * Gets the data for `map`. + * + * @private + * @param {Object} map The map to query. + * @param {string} key The reference key. + * @returns {*} Returns the map data. + */ +function getMapData(map, key) { + var data = map.__data__; + return isKeyable(key) + ? data[typeof key == 'string' ? 'string' : 'hash'] + : data.map; +} + +module.exports = getMapData; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getMatchData.js": +/***/ (function(module, exports, __webpack_require__) { + +var isStrictComparable = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isStrictComparable.js"), + keys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keys.js"); + +/** + * Gets the property names, values, and compare flags of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the match data of `object`. + */ +function getMatchData(object) { + var result = keys(object), + length = result.length; + + while (length--) { + var key = result[length], + value = object[key]; + + result[length] = [key, value, isStrictComparable(value)]; + } + return result; +} + +module.exports = getMatchData; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getNative.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIsNative = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIsNative.js"), + getValue = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getValue.js"); + +/** + * 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 = getValue(object, key); + return baseIsNative(value) ? value : undefined; +} + +module.exports = getNative; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getPrototype.js": +/***/ (function(module, exports, __webpack_require__) { + +var overArg = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_overArg.js"); + +/** Built-in value references. */ +var getPrototype = overArg(Object.getPrototypeOf, Object); + +module.exports = getPrototype; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getRawTag.js": +/***/ (function(module, exports, __webpack_require__) { + +var Symbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Symbol.js"); + +/** Used for built-in 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/7.0/#sec-object.prototype.tostring) + * of values. + */ +var nativeObjectToString = objectProto.toString; + +/** Built-in value references. */ +var symToStringTag = Symbol ? Symbol.toStringTag : undefined; + +/** + * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the raw `toStringTag`. + */ +function getRawTag(value) { + var isOwn = hasOwnProperty.call(value, symToStringTag), + tag = value[symToStringTag]; + + try { + value[symToStringTag] = undefined; + var unmasked = true; + } catch (e) {} + + var result = nativeObjectToString.call(value); + if (unmasked) { + if (isOwn) { + value[symToStringTag] = tag; + } else { + delete value[symToStringTag]; + } + } + return result; +} + +module.exports = getRawTag; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getSymbols.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayFilter = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayFilter.js"), + stubArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/stubArray.js"); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Built-in value references. */ +var propertyIsEnumerable = objectProto.propertyIsEnumerable; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeGetSymbols = Object.getOwnPropertySymbols; + +/** + * Creates an array of the own enumerable symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of symbols. + */ +var getSymbols = !nativeGetSymbols ? stubArray : function(object) { + if (object == null) { + return []; + } + object = Object(object); + return arrayFilter(nativeGetSymbols(object), function(symbol) { + return propertyIsEnumerable.call(object, symbol); + }); +}; + +module.exports = getSymbols; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getSymbolsIn.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayPush = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayPush.js"), + getPrototype = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getPrototype.js"), + getSymbols = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getSymbols.js"), + stubArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/stubArray.js"); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeGetSymbols = Object.getOwnPropertySymbols; + +/** + * Creates an array of the own and inherited enumerable symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of symbols. + */ +var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) { + var result = []; + while (object) { + arrayPush(result, getSymbols(object)); + object = getPrototype(object); + } + return result; +}; + +module.exports = getSymbolsIn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getTag.js": +/***/ (function(module, exports, __webpack_require__) { + +var DataView = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_DataView.js"), + Map = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Map.js"), + Promise = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Promise.js"), + Set = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Set.js"), + WeakMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_WeakMap.js"), + baseGetTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"), + toSource = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_toSource.js"); + +/** `Object#toString` result references. */ +var mapTag = '[object Map]', + objectTag = '[object Object]', + promiseTag = '[object Promise]', + setTag = '[object Set]', + weakMapTag = '[object WeakMap]'; + +var dataViewTag = '[object DataView]'; + +/** Used to detect maps, sets, and weakmaps. */ +var dataViewCtorString = toSource(DataView), + mapCtorString = toSource(Map), + promiseCtorString = toSource(Promise), + setCtorString = toSource(Set), + weakMapCtorString = toSource(WeakMap); + +/** + * Gets the `toStringTag` of `value`. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. + */ +var getTag = baseGetTag; + +// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6. +if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) || + (Map && getTag(new Map) != mapTag) || + (Promise && getTag(Promise.resolve()) != promiseTag) || + (Set && getTag(new Set) != setTag) || + (WeakMap && getTag(new WeakMap) != weakMapTag)) { + getTag = function(value) { + var result = baseGetTag(value), + Ctor = result == objectTag ? value.constructor : undefined, + ctorString = Ctor ? toSource(Ctor) : ''; + + if (ctorString) { + switch (ctorString) { + case dataViewCtorString: return dataViewTag; + case mapCtorString: return mapTag; + case promiseCtorString: return promiseTag; + case setCtorString: return setTag; + case weakMapCtorString: return weakMapTag; + } + } + return result; + }; +} + +module.exports = getTag; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_getValue.js": +/***/ (function(module, exports) { + +/** + * Gets the value at `key` of `object`. + * + * @private + * @param {Object} [object] The object to query. + * @param {string} key The key of the property to get. + * @returns {*} Returns the property value. + */ +function getValue(object, key) { + return object == null ? undefined : object[key]; +} + +module.exports = getValue; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_hasPath.js": +/***/ (function(module, exports, __webpack_require__) { + +var castPath = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_castPath.js"), + isArguments = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArguments.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"), + isIndex = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isIndex.js"), + isLength = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isLength.js"), + toKey = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_toKey.js"); + +/** + * Checks if `path` exists on `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @param {Function} hasFunc The function to check properties. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + */ +function hasPath(object, path, hasFunc) { + path = castPath(path, object); + + var index = -1, + length = path.length, + result = false; + + while (++index < length) { + var key = toKey(path[index]); + if (!(result = object != null && hasFunc(object, key))) { + break; + } + object = object[key]; + } + if (result || ++index != length) { + return result; + } + length = object == null ? 0 : object.length; + return !!length && isLength(length) && isIndex(key, length) && + (isArray(object) || isArguments(object)); +} + +module.exports = hasPath; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_hashClear.js": +/***/ (function(module, exports, __webpack_require__) { + +var nativeCreate = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_nativeCreate.js"); + +/** + * Removes all key-value entries from the hash. + * + * @private + * @name clear + * @memberOf Hash + */ +function hashClear() { + this.__data__ = nativeCreate ? nativeCreate(null) : {}; + this.size = 0; +} + +module.exports = hashClear; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_hashDelete.js": +/***/ (function(module, exports) { + +/** + * Removes `key` and its value from the hash. + * + * @private + * @name delete + * @memberOf Hash + * @param {Object} hash The hash to modify. + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function hashDelete(key) { + var result = this.has(key) && delete this.__data__[key]; + this.size -= result ? 1 : 0; + return result; +} + +module.exports = hashDelete; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_hashGet.js": +/***/ (function(module, exports, __webpack_require__) { + +var nativeCreate = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_nativeCreate.js"); + +/** Used to stand-in for `undefined` hash values. */ +var HASH_UNDEFINED = '__lodash_hash_undefined__'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Gets the hash value for `key`. + * + * @private + * @name get + * @memberOf Hash + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function hashGet(key) { + var data = this.__data__; + if (nativeCreate) { + var result = data[key]; + return result === HASH_UNDEFINED ? undefined : result; + } + return hasOwnProperty.call(data, key) ? data[key] : undefined; +} + +module.exports = hashGet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_hashHas.js": +/***/ (function(module, exports, __webpack_require__) { + +var nativeCreate = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_nativeCreate.js"); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Checks if a hash value for `key` exists. + * + * @private + * @name has + * @memberOf Hash + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function hashHas(key) { + var data = this.__data__; + return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key); +} + +module.exports = hashHas; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_hashSet.js": +/***/ (function(module, exports, __webpack_require__) { + +var nativeCreate = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_nativeCreate.js"); + +/** Used to stand-in for `undefined` hash values. */ +var HASH_UNDEFINED = '__lodash_hash_undefined__'; + +/** + * Sets the hash `key` to `value`. + * + * @private + * @name set + * @memberOf Hash + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the hash instance. + */ +function hashSet(key, value) { + var data = this.__data__; + this.size += this.has(key) ? 0 : 1; + data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value; + return this; +} + +module.exports = hashSet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_initCloneArray.js": +/***/ (function(module, exports) { + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Initializes an array clone. + * + * @private + * @param {Array} array The array to clone. + * @returns {Array} Returns the initialized clone. + */ +function initCloneArray(array) { + var length = array.length, + result = new array.constructor(length); + + // Add properties assigned by `RegExp#exec`. + if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) { + result.index = array.index; + result.input = array.input; + } + return result; +} + +module.exports = initCloneArray; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_initCloneByTag.js": +/***/ (function(module, exports, __webpack_require__) { + +var cloneArrayBuffer = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cloneArrayBuffer.js"), + cloneDataView = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cloneDataView.js"), + cloneRegExp = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cloneRegExp.js"), + cloneSymbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cloneSymbol.js"), + cloneTypedArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_cloneTypedArray.js"); + +/** `Object#toString` result references. */ +var boolTag = '[object Boolean]', + dateTag = '[object Date]', + mapTag = '[object Map]', + numberTag = '[object Number]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]'; + +var arrayBufferTag = '[object ArrayBuffer]', + dataViewTag = '[object DataView]', + 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]'; + +/** + * Initializes an object clone based on its `toStringTag`. + * + * **Note:** This function only supports cloning values with tags of + * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`. + * + * @private + * @param {Object} object The object to clone. + * @param {string} tag The `toStringTag` of the object to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the initialized clone. + */ +function initCloneByTag(object, tag, isDeep) { + var Ctor = object.constructor; + switch (tag) { + case arrayBufferTag: + return cloneArrayBuffer(object); + + case boolTag: + case dateTag: + return new Ctor(+object); + + case dataViewTag: + return cloneDataView(object, isDeep); + + case float32Tag: case float64Tag: + case int8Tag: case int16Tag: case int32Tag: + case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag: + return cloneTypedArray(object, isDeep); + + case mapTag: + return new Ctor; + + case numberTag: + case stringTag: + return new Ctor(object); + + case regexpTag: + return cloneRegExp(object); + + case setTag: + return new Ctor; + + case symbolTag: + return cloneSymbol(object); + } +} + +module.exports = initCloneByTag; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_initCloneObject.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseCreate = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseCreate.js"), + getPrototype = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getPrototype.js"), + isPrototype = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isPrototype.js"); + +/** + * Initializes an object clone. + * + * @private + * @param {Object} object The object to clone. + * @returns {Object} Returns the initialized clone. + */ +function initCloneObject(object) { + return (typeof object.constructor == 'function' && !isPrototype(object)) + ? baseCreate(getPrototype(object)) + : {}; +} + +module.exports = initCloneObject; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_isFlattenable.js": +/***/ (function(module, exports, __webpack_require__) { + +var Symbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Symbol.js"), + isArguments = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArguments.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"); + +/** Built-in value references. */ +var spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined; + +/** + * Checks if `value` is a flattenable `arguments` object or array. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is flattenable, else `false`. + */ +function isFlattenable(value) { + return isArray(value) || isArguments(value) || + !!(spreadableSymbol && value && value[spreadableSymbol]); +} + +module.exports = isFlattenable; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_isIndex.js": +/***/ (function(module, exports) { + +/** Used as references for various `Number` constants. */ +var MAX_SAFE_INTEGER = 9007199254740991; + +/** Used to detect unsigned integer values. */ +var reIsUint = /^(?:0|[1-9]\d*)$/; + +/** + * 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) { + var type = typeof value; + length = length == null ? MAX_SAFE_INTEGER : length; + + return !!length && + (type == 'number' || + (type != 'symbol' && reIsUint.test(value))) && + (value > -1 && value % 1 == 0 && value < length); +} + +module.exports = isIndex; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_isIterateeCall.js": +/***/ (function(module, exports, __webpack_require__) { + +var eq = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/eq.js"), + isArrayLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js"), + isIndex = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isIndex.js"), + isObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObject.js"); + +/** + * Checks if the given 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) + ) { + return eq(object[index], value); + } + return false; +} + +module.exports = isIterateeCall; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_isKey.js": +/***/ (function(module, exports, __webpack_require__) { + +var isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"), + isSymbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isSymbol.js"); + +/** Used to match property names within property paths. */ +var reIsDeepProp = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, + reIsPlainProp = /^\w*$/; + +/** + * Checks if `value` is a property name and not a property path. + * + * @private + * @param {*} value The value to check. + * @param {Object} [object] The object to query keys on. + * @returns {boolean} Returns `true` if `value` is a property name, else `false`. + */ +function isKey(value, object) { + if (isArray(value)) { + return false; + } + var type = typeof value; + if (type == 'number' || type == 'symbol' || type == 'boolean' || + value == null || isSymbol(value)) { + return true; + } + return reIsPlainProp.test(value) || !reIsDeepProp.test(value) || + (object != null && value in Object(object)); +} + +module.exports = isKey; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_isKeyable.js": +/***/ (function(module, exports) { + +/** + * Checks if `value` is suitable for use as unique object key. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is suitable, else `false`. + */ +function isKeyable(value) { + var type = typeof value; + return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean') + ? (value !== '__proto__') + : (value === null); +} + +module.exports = isKeyable; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_isMasked.js": +/***/ (function(module, exports, __webpack_require__) { + +var coreJsData = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_coreJsData.js"); + +/** Used to detect methods masquerading as native. */ +var maskSrcKey = (function() { + var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || ''); + return uid ? ('Symbol(src)_1.' + uid) : ''; +}()); + +/** + * Checks if `func` has its source masked. + * + * @private + * @param {Function} func The function to check. + * @returns {boolean} Returns `true` if `func` is masked, else `false`. + */ +function isMasked(func) { + return !!maskSrcKey && (maskSrcKey in func); +} + +module.exports = isMasked; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_isPrototype.js": +/***/ (function(module, exports) { + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Checks if `value` is likely a prototype object. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a prototype, else `false`. + */ +function isPrototype(value) { + var Ctor = value && value.constructor, + proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto; + + return value === proto; +} + +module.exports = isPrototype; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_isStrictComparable.js": +/***/ (function(module, exports, __webpack_require__) { + +var isObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObject.js"); + +/** + * Checks if `value` is suitable for strict equality comparisons, i.e. `===`. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` if suitable for strict + * equality comparisons, else `false`. + */ +function isStrictComparable(value) { + return value === value && !isObject(value); +} + +module.exports = isStrictComparable; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_listCacheClear.js": +/***/ (function(module, exports) { + +/** + * Removes all key-value entries from the list cache. + * + * @private + * @name clear + * @memberOf ListCache + */ +function listCacheClear() { + this.__data__ = []; + this.size = 0; +} + +module.exports = listCacheClear; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_listCacheDelete.js": +/***/ (function(module, exports, __webpack_require__) { + +var assocIndexOf = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_assocIndexOf.js"); + +/** Used for built-in method references. */ +var arrayProto = Array.prototype; + +/** Built-in value references. */ +var splice = arrayProto.splice; + +/** + * Removes `key` and its value from the list cache. + * + * @private + * @name delete + * @memberOf ListCache + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function listCacheDelete(key) { + var data = this.__data__, + index = assocIndexOf(data, key); + + if (index < 0) { + return false; + } + var lastIndex = data.length - 1; + if (index == lastIndex) { + data.pop(); + } else { + splice.call(data, index, 1); + } + --this.size; + return true; +} + +module.exports = listCacheDelete; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_listCacheGet.js": +/***/ (function(module, exports, __webpack_require__) { + +var assocIndexOf = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_assocIndexOf.js"); + +/** + * Gets the list cache value for `key`. + * + * @private + * @name get + * @memberOf ListCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function listCacheGet(key) { + var data = this.__data__, + index = assocIndexOf(data, key); + + return index < 0 ? undefined : data[index][1]; +} + +module.exports = listCacheGet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_listCacheHas.js": +/***/ (function(module, exports, __webpack_require__) { + +var assocIndexOf = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_assocIndexOf.js"); + +/** + * Checks if a list cache value for `key` exists. + * + * @private + * @name has + * @memberOf ListCache + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function listCacheHas(key) { + return assocIndexOf(this.__data__, key) > -1; +} + +module.exports = listCacheHas; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_listCacheSet.js": +/***/ (function(module, exports, __webpack_require__) { + +var assocIndexOf = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_assocIndexOf.js"); + +/** + * Sets the list cache `key` to `value`. + * + * @private + * @name set + * @memberOf ListCache + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the list cache instance. + */ +function listCacheSet(key, value) { + var data = this.__data__, + index = assocIndexOf(data, key); + + if (index < 0) { + ++this.size; + data.push([key, value]); + } else { + data[index][1] = value; + } + return this; +} + +module.exports = listCacheSet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_mapCacheClear.js": +/***/ (function(module, exports, __webpack_require__) { + +var Hash = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Hash.js"), + ListCache = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_ListCache.js"), + Map = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Map.js"); + +/** + * Removes all key-value entries from the map. + * + * @private + * @name clear + * @memberOf MapCache + */ +function mapCacheClear() { + this.size = 0; + this.__data__ = { + 'hash': new Hash, + 'map': new (Map || ListCache), + 'string': new Hash + }; +} + +module.exports = mapCacheClear; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_mapCacheDelete.js": +/***/ (function(module, exports, __webpack_require__) { + +var getMapData = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getMapData.js"); + +/** + * Removes `key` and its value from the map. + * + * @private + * @name delete + * @memberOf MapCache + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function mapCacheDelete(key) { + var result = getMapData(this, key)['delete'](key); + this.size -= result ? 1 : 0; + return result; +} + +module.exports = mapCacheDelete; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_mapCacheGet.js": +/***/ (function(module, exports, __webpack_require__) { + +var getMapData = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getMapData.js"); + +/** + * Gets the map value for `key`. + * + * @private + * @name get + * @memberOf MapCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function mapCacheGet(key) { + return getMapData(this, key).get(key); +} + +module.exports = mapCacheGet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_mapCacheHas.js": +/***/ (function(module, exports, __webpack_require__) { + +var getMapData = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getMapData.js"); + +/** + * Checks if a map value for `key` exists. + * + * @private + * @name has + * @memberOf MapCache + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function mapCacheHas(key) { + return getMapData(this, key).has(key); +} + +module.exports = mapCacheHas; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_mapCacheSet.js": +/***/ (function(module, exports, __webpack_require__) { + +var getMapData = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getMapData.js"); + +/** + * Sets the map `key` to `value`. + * + * @private + * @name set + * @memberOf MapCache + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the map cache instance. + */ +function mapCacheSet(key, value) { + var data = getMapData(this, key), + size = data.size; + + data.set(key, value); + this.size += data.size == size ? 0 : 1; + return this; +} + +module.exports = mapCacheSet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_mapToArray.js": +/***/ (function(module, exports) { + +/** + * Converts `map` to its key-value pairs. + * + * @private + * @param {Object} map The map to convert. + * @returns {Array} Returns the key-value pairs. + */ +function mapToArray(map) { + var index = -1, + result = Array(map.size); + + map.forEach(function(value, key) { + result[++index] = [key, value]; + }); + return result; +} + +module.exports = mapToArray; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_matchesStrictComparable.js": +/***/ (function(module, exports) { + +/** + * A specialized version of `matchesProperty` for source values suitable + * for strict equality comparisons, i.e. `===`. + * + * @private + * @param {string} key The key of the property to get. + * @param {*} srcValue The value to match. + * @returns {Function} Returns the new spec function. + */ +function matchesStrictComparable(key, srcValue) { + return function(object) { + if (object == null) { + return false; + } + return object[key] === srcValue && + (srcValue !== undefined || (key in Object(object))); + }; +} + +module.exports = matchesStrictComparable; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_memoizeCapped.js": +/***/ (function(module, exports, __webpack_require__) { + +var memoize = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/memoize.js"); + +/** Used as the maximum memoize cache size. */ +var MAX_MEMOIZE_SIZE = 500; + +/** + * A specialized version of `_.memoize` which clears the memoized function's + * cache when it exceeds `MAX_MEMOIZE_SIZE`. + * + * @private + * @param {Function} func The function to have its output memoized. + * @returns {Function} Returns the new memoized function. + */ +function memoizeCapped(func) { + var result = memoize(func, function(key) { + if (cache.size === MAX_MEMOIZE_SIZE) { + cache.clear(); + } + return key; + }); + + var cache = result.cache; + return result; +} + +module.exports = memoizeCapped; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_nativeCreate.js": +/***/ (function(module, exports, __webpack_require__) { + +var getNative = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getNative.js"); + +/* Built-in method references that are verified to be native. */ +var nativeCreate = getNative(Object, 'create'); + +module.exports = nativeCreate; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_nativeKeys.js": +/***/ (function(module, exports, __webpack_require__) { + +var overArg = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_overArg.js"); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeKeys = overArg(Object.keys, Object); + +module.exports = nativeKeys; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_nativeKeysIn.js": +/***/ (function(module, exports) { + +/** + * This function is like + * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys) + * except that it includes inherited enumerable properties. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ +function nativeKeysIn(object) { + var result = []; + if (object != null) { + for (var key in Object(object)) { + result.push(key); + } + } + return result; +} + +module.exports = nativeKeysIn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_nodeUtil.js": +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(module) {var freeGlobal = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_freeGlobal.js"); + +/** Detect free variable `exports`. */ +var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports; + +/** Detect free variable `module`. */ +var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; + +/** Detect the popular CommonJS extension `module.exports`. */ +var moduleExports = freeModule && freeModule.exports === freeExports; + +/** Detect free variable `process` from Node.js. */ +var freeProcess = moduleExports && freeGlobal.process; + +/** Used to access faster Node.js helpers. */ +var nodeUtil = (function() { + try { + // Use `util.types` for Node.js 10+. + var types = freeModule && freeModule.require && freeModule.require('util').types; + + if (types) { + return types; + } + + // Legacy `process.binding('util')` for Node.js < 10. + return freeProcess && freeProcess.binding && freeProcess.binding('util'); + } catch (e) {} +}()); + +module.exports = nodeUtil; + +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__("../../../node_modules/webpack/buildin/module.js")(module))) + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_objectToString.js": +/***/ (function(module, exports) { + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var nativeObjectToString = objectProto.toString; + +/** + * Converts `value` to a string using `Object.prototype.toString`. + * + * @private + * @param {*} value The value to convert. + * @returns {string} Returns the converted string. + */ +function objectToString(value) { + return nativeObjectToString.call(value); +} + +module.exports = objectToString; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_overArg.js": +/***/ (function(module, exports) { + +/** + * Creates a unary function that invokes `func` with its argument transformed. + * + * @private + * @param {Function} func The function to wrap. + * @param {Function} transform The argument transform. + * @returns {Function} Returns the new function. + */ +function overArg(func, transform) { + return function(arg) { + return func(transform(arg)); + }; +} + +module.exports = overArg; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_overRest.js": +/***/ (function(module, exports, __webpack_require__) { + +var apply = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_apply.js"); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max; + +/** + * A specialized version of `baseRest` which transforms the rest array. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @param {Function} transform The rest array transform. + * @returns {Function} Returns the new function. + */ +function overRest(func, start, transform) { + start = nativeMax(start === undefined ? (func.length - 1) : start, 0); + return function() { + var args = arguments, + index = -1, + length = nativeMax(args.length - start, 0), + array = Array(length); + + while (++index < length) { + array[index] = args[start + index]; + } + index = -1; + var otherArgs = Array(start + 1); + while (++index < start) { + otherArgs[index] = args[index]; + } + otherArgs[start] = transform(array); + return apply(func, this, otherArgs); + }; +} + +module.exports = overRest; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_parent.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGet.js"), + baseSlice = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseSlice.js"); + +/** + * Gets the parent value at `path` of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} path The path to get the parent value of. + * @returns {*} Returns the parent value. + */ +function parent(object, path) { + return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1)); +} + +module.exports = parent; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_root.js": +/***/ (function(module, exports, __webpack_require__) { + +var freeGlobal = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_freeGlobal.js"); + +/** Detect free variable `self`. */ +var freeSelf = typeof self == 'object' && self && self.Object === Object && self; + +/** Used as a reference to the global object. */ +var root = freeGlobal || freeSelf || Function('return this')(); + +module.exports = root; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_setCacheAdd.js": +/***/ (function(module, exports) { + +/** Used to stand-in for `undefined` hash values. */ +var HASH_UNDEFINED = '__lodash_hash_undefined__'; + +/** + * Adds `value` to the array cache. + * + * @private + * @name add + * @memberOf SetCache + * @alias push + * @param {*} value The value to cache. + * @returns {Object} Returns the cache instance. + */ +function setCacheAdd(value) { + this.__data__.set(value, HASH_UNDEFINED); + return this; +} + +module.exports = setCacheAdd; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_setCacheHas.js": +/***/ (function(module, exports) { + +/** + * Checks if `value` is in the array cache. + * + * @private + * @name has + * @memberOf SetCache + * @param {*} value The value to search for. + * @returns {number} Returns `true` if `value` is found, else `false`. + */ +function setCacheHas(value) { + return this.__data__.has(value); +} + +module.exports = setCacheHas; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_setToArray.js": +/***/ (function(module, exports) { + +/** + * Converts `set` to an array of its values. + * + * @private + * @param {Object} set The set to convert. + * @returns {Array} Returns the values. + */ +function setToArray(set) { + var index = -1, + result = Array(set.size); + + set.forEach(function(value) { + result[++index] = value; + }); + return result; +} + +module.exports = setToArray; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_setToPairs.js": +/***/ (function(module, exports) { + +/** + * Converts `set` to its value-value pairs. + * + * @private + * @param {Object} set The set to convert. + * @returns {Array} Returns the value-value pairs. + */ +function setToPairs(set) { + var index = -1, + result = Array(set.size); + + set.forEach(function(value) { + result[++index] = [value, value]; + }); + return result; +} + +module.exports = setToPairs; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_setToString.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseSetToString = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseSetToString.js"), + shortOut = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_shortOut.js"); + +/** + * Sets the `toString` method of `func` to return `string`. + * + * @private + * @param {Function} func The function to modify. + * @param {Function} string The `toString` result. + * @returns {Function} Returns `func`. + */ +var setToString = shortOut(baseSetToString); + +module.exports = setToString; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_shortOut.js": +/***/ (function(module, exports) { + +/** Used to detect hot functions by number of calls within a span of milliseconds. */ +var HOT_COUNT = 800, + HOT_SPAN = 16; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeNow = Date.now; + +/** + * Creates a function that'll short out and invoke `identity` instead + * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN` + * milliseconds. + * + * @private + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new shortable function. + */ +function shortOut(func) { + var count = 0, + lastCalled = 0; + + return function() { + var stamp = nativeNow(), + remaining = HOT_SPAN - (stamp - lastCalled); + + lastCalled = stamp; + if (remaining > 0) { + if (++count >= HOT_COUNT) { + return arguments[0]; + } + } else { + count = 0; + } + return func.apply(undefined, arguments); + }; +} + +module.exports = shortOut; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_stackClear.js": +/***/ (function(module, exports, __webpack_require__) { + +var ListCache = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_ListCache.js"); + +/** + * Removes all key-value entries from the stack. + * + * @private + * @name clear + * @memberOf Stack + */ +function stackClear() { + this.__data__ = new ListCache; + this.size = 0; +} + +module.exports = stackClear; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_stackDelete.js": +/***/ (function(module, exports) { + +/** + * Removes `key` and its value from the stack. + * + * @private + * @name delete + * @memberOf Stack + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function stackDelete(key) { + var data = this.__data__, + result = data['delete'](key); + + this.size = data.size; + return result; +} + +module.exports = stackDelete; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_stackGet.js": +/***/ (function(module, exports) { + +/** + * Gets the stack value for `key`. + * + * @private + * @name get + * @memberOf Stack + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function stackGet(key) { + return this.__data__.get(key); +} + +module.exports = stackGet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_stackHas.js": +/***/ (function(module, exports) { + +/** + * Checks if a stack value for `key` exists. + * + * @private + * @name has + * @memberOf Stack + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function stackHas(key) { + return this.__data__.has(key); +} + +module.exports = stackHas; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_stackSet.js": +/***/ (function(module, exports, __webpack_require__) { + +var ListCache = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_ListCache.js"), + Map = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_Map.js"), + MapCache = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_MapCache.js"); + +/** Used as the size to enable large array optimizations. */ +var LARGE_ARRAY_SIZE = 200; + +/** + * Sets the stack `key` to `value`. + * + * @private + * @name set + * @memberOf Stack + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the stack cache instance. + */ +function stackSet(key, value) { + var data = this.__data__; + if (data instanceof ListCache) { + var pairs = data.__data__; + if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) { + pairs.push([key, value]); + this.size = ++data.size; + return this; + } + data = this.__data__ = new MapCache(pairs); + } + data.set(key, value); + this.size = data.size; + return this; +} + +module.exports = stackSet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_strictIndexOf.js": +/***/ (function(module, exports) { + +/** + * A specialized version of `_.indexOf` which performs strict equality + * comparisons of values, i.e. `===`. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function strictIndexOf(array, value, fromIndex) { + var index = fromIndex - 1, + length = array.length; + + while (++index < length) { + if (array[index] === value) { + return index; + } + } + return -1; +} + +module.exports = strictIndexOf; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_stringToPath.js": +/***/ (function(module, exports, __webpack_require__) { + +var memoizeCapped = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_memoizeCapped.js"); + +/** Used to match property names within property paths. */ +var rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g; + +/** Used to match backslashes in property paths. */ +var reEscapeChar = /\\(\\)?/g; + +/** + * Converts `string` to a property path array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the property path array. + */ +var stringToPath = memoizeCapped(function(string) { + var result = []; + if (string.charCodeAt(0) === 46 /* . */) { + result.push(''); + } + string.replace(rePropName, function(match, number, quote, subString) { + result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match)); + }); + return result; +}); + +module.exports = stringToPath; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_toKey.js": +/***/ (function(module, exports, __webpack_require__) { + +var isSymbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isSymbol.js"); + +/** Used as references for various `Number` constants. */ +var INFINITY = 1 / 0; + +/** + * Converts `value` to a string key if it's not a string or symbol. + * + * @private + * @param {*} value The value to inspect. + * @returns {string|symbol} Returns the key. + */ +function toKey(value) { + if (typeof value == 'string' || isSymbol(value)) { + return value; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; +} + +module.exports = toKey; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/_toSource.js": +/***/ (function(module, exports) { + +/** Used for built-in method references. */ +var funcProto = Function.prototype; + +/** Used to resolve the decompiled source of functions. */ +var funcToString = funcProto.toString; + +/** + * Converts `func` to its source code. + * + * @private + * @param {Function} func The function to convert. + * @returns {string} Returns the source code. + */ +function toSource(func) { + if (func != null) { + try { + return funcToString.call(func); + } catch (e) {} + try { + return (func + ''); + } catch (e) {} + } + return ''; +} + +module.exports = toSource; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/assign.js": +/***/ (function(module, exports, __webpack_require__) { + +var assignValue = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_assignValue.js"), + copyObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_copyObject.js"), + createAssigner = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_createAssigner.js"), + isArrayLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js"), + isPrototype = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isPrototype.js"), + keys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keys.js"); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Assigns own enumerable string keyed properties of source objects to the + * destination object. Source objects are applied from left to right. + * Subsequent sources overwrite property assignments of previous sources. + * + * **Note:** This method mutates `object` and is loosely based on + * [`Object.assign`](https://mdn.io/Object/assign). + * + * @static + * @memberOf _ + * @since 0.10.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.assignIn + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * function Bar() { + * this.c = 3; + * } + * + * Foo.prototype.b = 2; + * Bar.prototype.d = 4; + * + * _.assign({ 'a': 0 }, new Foo, new Bar); + * // => { 'a': 1, 'c': 3 } + */ +var assign = createAssigner(function(object, source) { + if (isPrototype(source) || isArrayLike(source)) { + copyObject(source, keys(source), object); + return; + } + for (var key in source) { + if (hasOwnProperty.call(source, key)) { + assignValue(object, key, source[key]); + } + } +}); + +module.exports = assign; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/constant.js": +/***/ (function(module, exports) { + +/** + * Creates a function that returns `value`. + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Util + * @param {*} value The value to return from the new function. + * @returns {Function} Returns the new constant function. + * @example + * + * var objects = _.times(2, _.constant({ 'a': 1 })); + * + * console.log(objects); + * // => [{ 'a': 1 }, { 'a': 1 }] + * + * console.log(objects[0] === objects[1]); + * // => true + */ +function constant(value) { + return function() { + return value; + }; +} + +module.exports = constant; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/defaults.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseRest = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseRest.js"), + eq = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/eq.js"), + isIterateeCall = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isIterateeCall.js"), + keysIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keysIn.js"); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Assigns own and inherited enumerable string keyed properties of source + * objects to the destination object for all destination properties that + * resolve to `undefined`. Source objects are applied from left to right. + * Once a property is set, additional values of the same property are ignored. + * + * **Note:** This method mutates `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.defaultsDeep + * @example + * + * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ +var defaults = baseRest(function(object, sources) { + object = Object(object); + + var index = -1; + var length = sources.length; + var guard = length > 2 ? sources[2] : undefined; + + if (guard && isIterateeCall(sources[0], sources[1], guard)) { + length = 1; + } + + while (++index < length) { + var source = sources[index]; + var props = keysIn(source); + var propsIndex = -1; + var propsLength = props.length; + + while (++propsIndex < propsLength) { + var key = props[propsIndex]; + var value = object[key]; + + if (value === undefined || + (eq(value, objectProto[key]) && !hasOwnProperty.call(object, key))) { + object[key] = source[key]; + } + } + } + + return object; +}); + +module.exports = defaults; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/difference.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseDifference = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseDifference.js"), + baseFlatten = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseFlatten.js"), + baseRest = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseRest.js"), + isArrayLikeObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLikeObject.js"); + +/** + * Creates an array of `array` values not included in the other given arrays + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. The order and references of result values are + * determined by the first array. + * + * **Note:** Unlike `_.pullAll`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...Array} [values] The values to exclude. + * @returns {Array} Returns the new array of filtered values. + * @see _.without, _.xor + * @example + * + * _.difference([2, 1], [2, 3]); + * // => [1] + */ +var difference = baseRest(function(array, values) { + return isArrayLikeObject(array) + ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true)) + : []; +}); + +module.exports = difference; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/drop.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseSlice = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseSlice.js"), + toInteger = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/toInteger.js"); + +/** + * Creates a slice of `array` with `n` elements dropped from the beginning. + * + * @static + * @memberOf _ + * @since 0.5.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to drop. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.drop([1, 2, 3]); + * // => [2, 3] + * + * _.drop([1, 2, 3], 2); + * // => [3] + * + * _.drop([1, 2, 3], 5); + * // => [] + * + * _.drop([1, 2, 3], 0); + * // => [1, 2, 3] + */ +function drop(array, n, guard) { + var length = array == null ? 0 : array.length; + if (!length) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + return baseSlice(array, n < 0 ? 0 : n, length); +} + +module.exports = drop; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/dropRight.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseSlice = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseSlice.js"), + toInteger = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/toInteger.js"); + +/** + * Creates a slice of `array` with `n` elements dropped from the end. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to drop. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.dropRight([1, 2, 3]); + * // => [1, 2] + * + * _.dropRight([1, 2, 3], 2); + * // => [1] + * + * _.dropRight([1, 2, 3], 5); + * // => [] + * + * _.dropRight([1, 2, 3], 0); + * // => [1, 2, 3] + */ +function dropRight(array, n, guard) { + var length = array == null ? 0 : array.length; + if (!length) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + n = length - n; + return baseSlice(array, 0, n < 0 ? 0 : n); +} + +module.exports = dropRight; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/eq.js": +/***/ (function(module, exports) { + +/** + * Performs a + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * comparison between two values to determine if they are equivalent. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * var object = { 'a': 1 }; + * var other = { 'a': 1 }; + * + * _.eq(object, object); + * // => true + * + * _.eq(object, other); + * // => false + * + * _.eq('a', 'a'); + * // => true + * + * _.eq('a', Object('a')); + * // => false + * + * _.eq(NaN, NaN); + * // => true + */ +function eq(value, other) { + return value === other || (value !== value && other !== other); +} + +module.exports = eq; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/filter.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayFilter = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayFilter.js"), + baseFilter = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseFilter.js"), + baseIteratee = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIteratee.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"); + +/** + * Iterates over elements of `collection`, returning an array of all elements + * `predicate` returns truthy for. The predicate is invoked with three + * arguments: (value, index|key, collection). + * + * **Note:** Unlike `_.remove`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + * @see _.reject + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * _.filter(users, function(o) { return !o.active; }); + * // => objects for ['fred'] + * + * // The `_.matches` iteratee shorthand. + * _.filter(users, { 'age': 36, 'active': true }); + * // => objects for ['barney'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.filter(users, ['active', false]); + * // => objects for ['fred'] + * + * // The `_.property` iteratee shorthand. + * _.filter(users, 'active'); + * // => objects for ['barney'] + */ +function filter(collection, predicate) { + var func = isArray(collection) ? arrayFilter : baseFilter; + return func(collection, baseIteratee(predicate, 3)); +} + +module.exports = filter; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/find.js": +/***/ (function(module, exports, __webpack_require__) { + +var createFind = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_createFind.js"), + findIndex = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/findIndex.js"); + +/** + * Iterates over elements of `collection`, returning the first element + * `predicate` returns truthy for. The predicate is invoked with three + * arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @param {number} [fromIndex=0] The index to search from. + * @returns {*} Returns the matched element, else `undefined`. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false }, + * { 'user': 'pebbles', 'age': 1, 'active': true } + * ]; + * + * _.find(users, function(o) { return o.age < 40; }); + * // => object for 'barney' + * + * // The `_.matches` iteratee shorthand. + * _.find(users, { 'age': 1, 'active': true }); + * // => object for 'pebbles' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.find(users, ['active', false]); + * // => object for 'fred' + * + * // The `_.property` iteratee shorthand. + * _.find(users, 'active'); + * // => object for 'barney' + */ +var find = createFind(findIndex); + +module.exports = find; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/findIndex.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseFindIndex = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseFindIndex.js"), + baseIteratee = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIteratee.js"), + toInteger = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/toInteger.js"); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max; + +/** + * This method is like `_.find` except that it returns the index of the first + * element `predicate` returns truthy for instead of the element itself. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @param {number} [fromIndex=0] The index to search from. + * @returns {number} Returns the index of the found element, else `-1`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': false }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': true } + * ]; + * + * _.findIndex(users, function(o) { return o.user == 'barney'; }); + * // => 0 + * + * // The `_.matches` iteratee shorthand. + * _.findIndex(users, { 'user': 'fred', 'active': false }); + * // => 1 + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findIndex(users, ['active', false]); + * // => 0 + * + * // The `_.property` iteratee shorthand. + * _.findIndex(users, 'active'); + * // => 2 + */ +function findIndex(array, predicate, fromIndex) { + var length = array == null ? 0 : array.length; + if (!length) { + return -1; + } + var index = fromIndex == null ? 0 : toInteger(fromIndex); + if (index < 0) { + index = nativeMax(length + index, 0); + } + return baseFindIndex(array, baseIteratee(predicate, 3), index); +} + +module.exports = findIndex; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/flatten.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseFlatten = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseFlatten.js"); + +/** + * Flattens `array` a single level deep. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to flatten. + * @returns {Array} Returns the new flattened array. + * @example + * + * _.flatten([1, [2, [3, [4]], 5]]); + * // => [1, 2, [3, [4]], 5] + */ +function flatten(array) { + var length = array == null ? 0 : array.length; + return length ? baseFlatten(array, 1) : []; +} + +module.exports = flatten; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/forEach.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayEach = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayEach.js"), + baseEach = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseEach.js"), + castFunction = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_castFunction.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"); + +/** + * Iterates over elements of `collection` and invokes `iteratee` for each element. + * The iteratee is invoked with three arguments: (value, index|key, collection). + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * **Note:** As with other "Collections" methods, objects with a "length" + * property are iterated like arrays. To avoid this behavior use `_.forIn` + * or `_.forOwn` for object iteration. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @alias each + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + * @see _.forEachRight + * @example + * + * _.forEach([1, 2], function(value) { + * console.log(value); + * }); + * // => Logs `1` then `2`. + * + * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a' then 'b' (iteration order is not guaranteed). + */ +function forEach(collection, iteratee) { + var func = isArray(collection) ? arrayEach : baseEach; + return func(collection, castFunction(iteratee)); +} + +module.exports = forEach; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/forOwn.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseForOwn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseForOwn.js"), + castFunction = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_castFunction.js"); + +/** + * Iterates over own enumerable string keyed properties of an object and + * invokes `iteratee` for each property. The iteratee is invoked with three + * arguments: (value, key, object). Iteratee functions may exit iteration + * early by explicitly returning `false`. + * + * @static + * @memberOf _ + * @since 0.3.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forOwnRight + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forOwn(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a' then 'b' (iteration order is not guaranteed). + */ +function forOwn(object, iteratee) { + return object && baseForOwn(object, castFunction(iteratee)); +} + +module.exports = forOwn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/get.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGet.js"); + +/** + * Gets the value at `path` of `object`. If the resolved value is + * `undefined`, the `defaultValue` is returned in its place. + * + * @static + * @memberOf _ + * @since 3.7.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to get. + * @param {*} [defaultValue] The value returned for `undefined` resolved values. + * @returns {*} Returns the resolved value. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }] }; + * + * _.get(object, 'a[0].b.c'); + * // => 3 + * + * _.get(object, ['a', '0', 'b', 'c']); + * // => 3 + * + * _.get(object, 'a.b.c', 'default'); + * // => 'default' + */ +function get(object, path, defaultValue) { + var result = object == null ? undefined : baseGet(object, path); + return result === undefined ? defaultValue : result; +} + +module.exports = get; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/hasIn.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseHasIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseHasIn.js"), + hasPath = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_hasPath.js"); + +/** + * Checks if `path` is a direct or inherited property of `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + * @example + * + * var object = _.create({ 'a': _.create({ 'b': 2 }) }); + * + * _.hasIn(object, 'a'); + * // => true + * + * _.hasIn(object, 'a.b'); + * // => true + * + * _.hasIn(object, ['a', 'b']); + * // => true + * + * _.hasIn(object, 'b'); + * // => false + */ +function hasIn(object, path) { + return object != null && hasPath(object, path, baseHasIn); +} + +module.exports = hasIn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/identity.js": +/***/ (function(module, exports) { + +/** + * This method returns the first argument it receives. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Util + * @param {*} value Any value. + * @returns {*} Returns `value`. + * @example + * + * var object = { 'a': 1 }; + * + * console.log(_.identity(object) === object); + * // => true + */ +function identity(value) { + return value; +} + +module.exports = identity; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/includes.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIndexOf = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIndexOf.js"), + isArrayLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js"), + isString = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isString.js"), + toInteger = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/toInteger.js"), + values = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/values.js"); + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeMax = Math.max; + +/** + * Checks if `value` is in `collection`. If `collection` is a string, it's + * checked for a substring of `value`, otherwise + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * is used for equality comparisons. If `fromIndex` is negative, it's used as + * the offset from the end of `collection`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object|string} collection The collection to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=0] The index to search from. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`. + * @returns {boolean} Returns `true` if `value` is found, else `false`. + * @example + * + * _.includes([1, 2, 3], 1); + * // => true + * + * _.includes([1, 2, 3], 1, 2); + * // => false + * + * _.includes({ 'a': 1, 'b': 2 }, 1); + * // => true + * + * _.includes('abcd', 'bc'); + * // => true + */ +function includes(collection, value, fromIndex, guard) { + collection = isArrayLike(collection) ? collection : values(collection); + fromIndex = (fromIndex && !guard) ? toInteger(fromIndex) : 0; + + var length = collection.length; + if (fromIndex < 0) { + fromIndex = nativeMax(length + fromIndex, 0); + } + return isString(collection) + ? (fromIndex <= length && collection.indexOf(value, fromIndex) > -1) + : (!!length && baseIndexOf(collection, value, fromIndex) > -1); +} + +module.exports = includes; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/initial.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseSlice = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseSlice.js"); + +/** + * Gets all but the last element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.initial([1, 2, 3]); + * // => [1, 2] + */ +function initial(array) { + var length = array == null ? 0 : array.length; + return length ? baseSlice(array, 0, -1) : []; +} + +module.exports = initial; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/intersection.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayMap.js"), + baseIntersection = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIntersection.js"), + baseRest = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseRest.js"), + castArrayLikeObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_castArrayLikeObject.js"); + +/** + * Creates an array of unique values that are included in all given arrays + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. The order and references of result values are + * determined by the first array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @returns {Array} Returns the new array of intersecting values. + * @example + * + * _.intersection([2, 1], [2, 3]); + * // => [2] + */ +var intersection = baseRest(function(arrays) { + var mapped = arrayMap(arrays, castArrayLikeObject); + return (mapped.length && mapped[0] === arrays[0]) + ? baseIntersection(mapped) + : []; +}); + +module.exports = intersection; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isArguments.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIsArguments = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIsArguments.js"), + isObjectLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js"); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** Built-in value references. */ +var propertyIsEnumerable = objectProto.propertyIsEnumerable; + +/** + * Checks if `value` is likely an `arguments` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an `arguments` object, + * else `false`. + * @example + * + * _.isArguments(function() { return arguments; }()); + * // => true + * + * _.isArguments([1, 2, 3]); + * // => false + */ +var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) { + return isObjectLike(value) && hasOwnProperty.call(value, 'callee') && + !propertyIsEnumerable.call(value, 'callee'); +}; + +module.exports = isArguments; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isArray.js": +/***/ (function(module, exports) { + +/** + * Checks if `value` is classified as an `Array` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array, else `false`. + * @example + * + * _.isArray([1, 2, 3]); + * // => true + * + * _.isArray(document.body.children); + * // => false + * + * _.isArray('abc'); + * // => false + * + * _.isArray(_.noop); + * // => false + */ +var isArray = Array.isArray; + +module.exports = isArray; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js": +/***/ (function(module, exports, __webpack_require__) { + +var isFunction = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isFunction.js"), + isLength = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isLength.js"); + +/** + * 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 _ + * @since 4.0.0 + * @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 && isLength(value.length) && !isFunction(value); +} + +module.exports = isArrayLike; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isArrayLikeObject.js": +/***/ (function(module, exports, __webpack_require__) { + +var isArrayLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js"), + isObjectLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js"); + +/** + * This method is like `_.isArrayLike` except that it also checks if `value` + * is an object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @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); +} + +module.exports = isArrayLikeObject; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isBuffer.js": +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(module) {var root = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_root.js"), + stubFalse = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/stubFalse.js"); + +/** Detect free variable `exports`. */ +var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports; + +/** Detect free variable `module`. */ +var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; + +/** Detect the popular CommonJS extension `module.exports`. */ +var moduleExports = freeModule && freeModule.exports === freeExports; + +/** Built-in value references. */ +var Buffer = moduleExports ? root.Buffer : undefined; + +/* Built-in method references for those with the same name as other `lodash` methods. */ +var nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined; + +/** + * Checks if `value` is a buffer. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a buffer, else `false`. + * @example + * + * _.isBuffer(new Buffer(2)); + * // => true + * + * _.isBuffer(new Uint8Array(2)); + * // => false + */ +var isBuffer = nativeIsBuffer || stubFalse; + +module.exports = isBuffer; + +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__("../../../node_modules/webpack/buildin/module.js")(module))) + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isEmpty.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseKeys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseKeys.js"), + getTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getTag.js"), + isArguments = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArguments.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"), + isArrayLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js"), + isBuffer = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isBuffer.js"), + isPrototype = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isPrototype.js"), + isTypedArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isTypedArray.js"); + +/** `Object#toString` result references. */ +var mapTag = '[object Map]', + setTag = '[object Set]'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Checks if `value` is an empty object, collection, map, or set. + * + * Objects are considered empty if they have no own enumerable string keyed + * properties. + * + * Array-like values such as `arguments` objects, arrays, buffers, strings, or + * jQuery-like collections are considered empty if they have a `length` of `0`. + * Similarly, maps and sets are considered empty if they have a `size` of `0`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is empty, else `false`. + * @example + * + * _.isEmpty(null); + * // => true + * + * _.isEmpty(true); + * // => true + * + * _.isEmpty(1); + * // => true + * + * _.isEmpty([1, 2, 3]); + * // => false + * + * _.isEmpty({ 'a': 1 }); + * // => false + */ +function isEmpty(value) { + if (value == null) { + return true; + } + if (isArrayLike(value) && + (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' || + isBuffer(value) || isTypedArray(value) || isArguments(value))) { + return !value.length; + } + var tag = getTag(value); + if (tag == mapTag || tag == setTag) { + return !value.size; + } + if (isPrototype(value)) { + return !baseKeys(value).length; + } + for (var key in value) { + if (hasOwnProperty.call(value, key)) { + return false; + } + } + return true; +} + +module.exports = isEmpty; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isFunction.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGetTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"), + isObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObject.js"); + +/** `Object#toString` result references. */ +var asyncTag = '[object AsyncFunction]', + funcTag = '[object Function]', + genTag = '[object GeneratorFunction]', + proxyTag = '[object Proxy]'; + +/** + * Checks if `value` is classified as a `Function` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a function, else `false`. + * @example + * + * _.isFunction(_); + * // => true + * + * _.isFunction(/abc/); + * // => false + */ +function isFunction(value) { + if (!isObject(value)) { + return false; + } + // The use of `Object#toString` avoids issues with the `typeof` operator + // in Safari 9 which returns 'object' for typed arrays and other constructors. + var tag = baseGetTag(value); + return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag; +} + +module.exports = isFunction; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isLength.js": +/***/ (function(module, exports) { + +/** Used as references for various `Number` constants. */ +var MAX_SAFE_INTEGER = 9007199254740991; + +/** + * Checks if `value` is a valid array-like length. + * + * **Note:** This method is loosely based on + * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @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; +} + +module.exports = isLength; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isMap.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIsMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIsMap.js"), + baseUnary = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseUnary.js"), + nodeUtil = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_nodeUtil.js"); + +/* Node.js helper references. */ +var nodeIsMap = nodeUtil && nodeUtil.isMap; + +/** + * Checks if `value` is classified as a `Map` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a map, else `false`. + * @example + * + * _.isMap(new Map); + * // => true + * + * _.isMap(new WeakMap); + * // => false + */ +var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap; + +module.exports = isMap; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isNull.js": +/***/ (function(module, exports) { + +/** + * Checks if `value` is `null`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `null`, else `false`. + * @example + * + * _.isNull(null); + * // => true + * + * _.isNull(void 0); + * // => false + */ +function isNull(value) { + return value === null; +} + +module.exports = isNull; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isObject.js": +/***/ (function(module, exports) { + +/** + * Checks if `value` is the + * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types) + * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) + * + * @static + * @memberOf _ + * @since 0.1.0 + * @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) { + var type = typeof value; + return value != null && (type == 'object' || type == 'function'); +} + +module.exports = isObject; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js": +/***/ (function(module, exports) { + +/** + * 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 _ + * @since 4.0.0 + * @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 != null && typeof value == 'object'; +} + +module.exports = isObjectLike; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isPlainObject.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGetTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"), + getPrototype = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getPrototype.js"), + isObjectLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js"); + +/** `Object#toString` result references. */ +var objectTag = '[object Object]'; + +/** Used for built-in method references. */ +var funcProto = Function.prototype, + objectProto = Object.prototype; + +/** Used to resolve the decompiled source of functions. */ +var funcToString = funcProto.toString; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** Used to infer the `Object` constructor. */ +var objectCtorString = funcToString.call(Object); + +/** + * Checks if `value` is a plain object, that is, an object created by the + * `Object` constructor or one with a `[[Prototype]]` of `null`. + * + * @static + * @memberOf _ + * @since 0.8.0 + * @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) { + if (!isObjectLike(value) || baseGetTag(value) != objectTag) { + return false; + } + var proto = getPrototype(value); + if (proto === null) { + return true; + } + var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor; + return typeof Ctor == 'function' && Ctor instanceof Ctor && + funcToString.call(Ctor) == objectCtorString; +} + +module.exports = isPlainObject; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isSet.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIsSet = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIsSet.js"), + baseUnary = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseUnary.js"), + nodeUtil = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_nodeUtil.js"); + +/* Node.js helper references. */ +var nodeIsSet = nodeUtil && nodeUtil.isSet; + +/** + * Checks if `value` is classified as a `Set` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a set, else `false`. + * @example + * + * _.isSet(new Set); + * // => true + * + * _.isSet(new WeakSet); + * // => false + */ +var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet; + +module.exports = isSet; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isString.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGetTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"), + isObjectLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js"); + +/** `Object#toString` result references. */ +var stringTag = '[object String]'; + +/** + * Checks if `value` is classified as a `String` primitive or object. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a string, else `false`. + * @example + * + * _.isString('abc'); + * // => true + * + * _.isString(1); + * // => false + */ +function isString(value) { + return typeof value == 'string' || + (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag); +} + +module.exports = isString; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isSymbol.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGetTag = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseGetTag.js"), + isObjectLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObjectLike.js"); + +/** `Object#toString` result references. */ +var symbolTag = '[object Symbol]'; + +/** + * Checks if `value` is classified as a `Symbol` primitive or object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a symbol, else `false`. + * @example + * + * _.isSymbol(Symbol.iterator); + * // => true + * + * _.isSymbol('abc'); + * // => false + */ +function isSymbol(value) { + return typeof value == 'symbol' || + (isObjectLike(value) && baseGetTag(value) == symbolTag); +} + +module.exports = isSymbol; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isTypedArray.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIsTypedArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIsTypedArray.js"), + baseUnary = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseUnary.js"), + nodeUtil = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_nodeUtil.js"); + +/* Node.js helper references. */ +var nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray; + +/** + * Checks if `value` is classified as a typed array. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a typed array, else `false`. + * @example + * + * _.isTypedArray(new Uint8Array); + * // => true + * + * _.isTypedArray([]); + * // => false + */ +var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray; + +module.exports = isTypedArray; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/isUndefined.js": +/***/ (function(module, exports) { + +/** + * Checks if `value` is `undefined`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`. + * @example + * + * _.isUndefined(void 0); + * // => true + * + * _.isUndefined(null); + * // => false + */ +function isUndefined(value) { + return value === undefined; +} + +module.exports = isUndefined; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/keys.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayLikeKeys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayLikeKeys.js"), + baseKeys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseKeys.js"), + isArrayLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js"); + +/** + * 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/7.0/#sec-object.keys) + * for more details. + * + * @static + * @since 0.1.0 + * @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'] + */ +function keys(object) { + return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object); +} + +module.exports = keys; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/keysIn.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayLikeKeys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayLikeKeys.js"), + baseKeysIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseKeysIn.js"), + isArrayLike = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLike.js"); + +/** + * Creates an array of the own and inherited enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @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) { + return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object); +} + +module.exports = keysIn; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/last.js": +/***/ (function(module, exports) { + +/** + * Gets the last element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @returns {*} Returns the last element of `array`. + * @example + * + * _.last([1, 2, 3]); + * // => 3 + */ +function last(array) { + var length = array == null ? 0 : array.length; + return length ? array[length - 1] : undefined; +} + +module.exports = last; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/map.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayMap.js"), + baseIteratee = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseIteratee.js"), + baseMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseMap.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"); + +/** + * Creates an array of values by running each element in `collection` thru + * `iteratee`. The iteratee is invoked with three arguments: + * (value, index|key, collection). + * + * Many lodash methods are guarded to work as iteratees for methods like + * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`. + * + * The guarded methods are: + * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`, + * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`, + * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`, + * `template`, `trim`, `trimEnd`, `trimStart`, and `words` + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + * @example + * + * function square(n) { + * return n * n; + * } + * + * _.map([4, 8], square); + * // => [16, 64] + * + * _.map({ 'a': 4, 'b': 8 }, square); + * // => [16, 64] (iteration order is not guaranteed) + * + * var users = [ + * { 'user': 'barney' }, + * { 'user': 'fred' } + * ]; + * + * // The `_.property` iteratee shorthand. + * _.map(users, 'user'); + * // => ['barney', 'fred'] + */ +function map(collection, iteratee) { + var func = isArray(collection) ? arrayMap : baseMap; + return func(collection, baseIteratee(iteratee, 3)); +} + +module.exports = map; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/memoize.js": +/***/ (function(module, exports, __webpack_require__) { + +var MapCache = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_MapCache.js"); + +/** Error message constants. */ +var FUNC_ERROR_TEXT = 'Expected a function'; + +/** + * Creates a function that memoizes the result of `func`. If `resolver` is + * provided, it determines the cache key for storing the result based on the + * arguments provided to the memoized function. By default, the first argument + * provided to the memoized function is used as the map cache key. The `func` + * is invoked with the `this` binding of the memoized function. + * + * **Note:** The cache is exposed as the `cache` property on the memoized + * function. Its creation may be customized by replacing the `_.memoize.Cache` + * constructor with one whose instances implement the + * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object) + * method interface of `clear`, `delete`, `get`, `has`, and `set`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to have its output memoized. + * @param {Function} [resolver] The function to resolve the cache key. + * @returns {Function} Returns the new memoized function. + * @example + * + * var object = { 'a': 1, 'b': 2 }; + * var other = { 'c': 3, 'd': 4 }; + * + * var values = _.memoize(_.values); + * values(object); + * // => [1, 2] + * + * values(other); + * // => [3, 4] + * + * object.a = 2; + * values(object); + * // => [1, 2] + * + * // Modify the result cache. + * values.cache.set(object, ['a', 'b']); + * values(object); + * // => ['a', 'b'] + * + * // Replace `_.memoize.Cache`. + * _.memoize.Cache = WeakMap; + */ +function memoize(func, resolver) { + if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) { + throw new TypeError(FUNC_ERROR_TEXT); + } + var memoized = function() { + var args = arguments, + key = resolver ? resolver.apply(this, args) : args[0], + cache = memoized.cache; + + if (cache.has(key)) { + return cache.get(key); + } + var result = func.apply(this, args); + memoized.cache = cache.set(key, result) || cache; + return result; + }; + memoized.cache = new (memoize.Cache || MapCache); + return memoized; +} + +// Expose `MapCache`. +memoize.Cache = MapCache; + +module.exports = memoize; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/omit.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayMap = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_arrayMap.js"), + baseClone = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseClone.js"), + baseUnset = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseUnset.js"), + castPath = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_castPath.js"), + copyObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_copyObject.js"), + customOmitClone = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_customOmitClone.js"), + flatRest = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_flatRest.js"), + getAllKeysIn = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_getAllKeysIn.js"); + +/** Used to compose bitmasks for cloning. */ +var CLONE_DEEP_FLAG = 1, + CLONE_FLAT_FLAG = 2, + CLONE_SYMBOLS_FLAG = 4; + +/** + * The opposite of `_.pick`; this method creates an object composed of the + * own and inherited enumerable property paths of `object` that are not omitted. + * + * **Note:** This method is considerably slower than `_.pick`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The source object. + * @param {...(string|string[])} [paths] The property paths to omit. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.omit(object, ['a', 'c']); + * // => { 'b': '2' } + */ +var omit = flatRest(function(object, paths) { + var result = {}; + if (object == null) { + return result; + } + var isDeep = false; + paths = arrayMap(paths, function(path) { + path = castPath(path, object); + isDeep || (isDeep = path.length > 1); + return path; + }); + copyObject(object, getAllKeysIn(object), result); + if (isDeep) { + result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone); + } + var length = paths.length; + while (length--) { + baseUnset(result, paths[length]); + } + return result; +}); + +module.exports = omit; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/orderBy.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseOrderBy = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseOrderBy.js"), + isArray = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArray.js"); + +/** + * This method is like `_.sortBy` except that it allows specifying the sort + * orders of the iteratees to sort by. If `orders` is unspecified, all values + * are sorted in ascending order. Otherwise, specify an order of "desc" for + * descending or "asc" for ascending sort order of corresponding values. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Array[]|Function[]|Object[]|string[]} [iteratees=[_.identity]] + * The iteratees to sort by. + * @param {string[]} [orders] The sort orders of `iteratees`. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`. + * @returns {Array} Returns the new sorted array. + * @example + * + * var users = [ + * { 'user': 'fred', 'age': 48 }, + * { 'user': 'barney', 'age': 34 }, + * { 'user': 'fred', 'age': 40 }, + * { 'user': 'barney', 'age': 36 } + * ]; + * + * // Sort by `user` in ascending order and by `age` in descending order. + * _.orderBy(users, ['user', 'age'], ['asc', 'desc']); + * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]] + */ +function orderBy(collection, iteratees, orders, guard) { + if (collection == null) { + return []; + } + if (!isArray(iteratees)) { + iteratees = iteratees == null ? [] : [iteratees]; + } + orders = guard ? undefined : orders; + if (!isArray(orders)) { + orders = orders == null ? [] : [orders]; + } + return baseOrderBy(collection, iteratees, orders); +} + +module.exports = orderBy; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/pick.js": +/***/ (function(module, exports, __webpack_require__) { + +var basePick = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_basePick.js"), + flatRest = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_flatRest.js"); + +/** + * Creates an object composed of the picked `object` properties. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The source object. + * @param {...(string|string[])} [paths] The property paths to pick. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.pick(object, ['a', 'c']); + * // => { 'a': 1, 'c': 3 } + */ +var pick = flatRest(function(object, paths) { + return object == null ? {} : basePick(object, paths); +}); + +module.exports = pick; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/property.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseProperty = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseProperty.js"), + basePropertyDeep = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_basePropertyDeep.js"), + isKey = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isKey.js"), + toKey = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_toKey.js"); + +/** + * Creates a function that returns the value at `path` of a given object. + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Util + * @param {Array|string} path The path of the property to get. + * @returns {Function} Returns the new accessor function. + * @example + * + * var objects = [ + * { 'a': { 'b': 2 } }, + * { 'a': { 'b': 1 } } + * ]; + * + * _.map(objects, _.property('a.b')); + * // => [2, 1] + * + * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b'); + * // => [1, 2] + */ +function property(path) { + return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path); +} + +module.exports = property; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/sortBy.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseFlatten = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseFlatten.js"), + baseOrderBy = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseOrderBy.js"), + baseRest = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseRest.js"), + isIterateeCall = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_isIterateeCall.js"); + +/** + * Creates an array of elements, sorted in ascending order by the results of + * running each element in a collection thru each iteratee. This method + * performs a stable sort, that is, it preserves the original sort order of + * equal elements. The iteratees are invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {...(Function|Function[])} [iteratees=[_.identity]] + * The iteratees to sort by. + * @returns {Array} Returns the new sorted array. + * @example + * + * var users = [ + * { 'user': 'fred', 'age': 48 }, + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 40 }, + * { 'user': 'barney', 'age': 34 } + * ]; + * + * _.sortBy(users, [function(o) { return o.user; }]); + * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]] + * + * _.sortBy(users, ['user', 'age']); + * // => objects for [['barney', 34], ['barney', 36], ['fred', 40], ['fred', 48]] + */ +var sortBy = baseRest(function(collection, iteratees) { + if (collection == null) { + return []; + } + var length = iteratees.length; + if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) { + iteratees = []; + } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) { + iteratees = [iteratees[0]]; + } + return baseOrderBy(collection, baseFlatten(iteratees, 1), []); +}); + +module.exports = sortBy; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/stubArray.js": +/***/ (function(module, exports) { + +/** + * This method returns a new empty array. + * + * @static + * @memberOf _ + * @since 4.13.0 + * @category Util + * @returns {Array} Returns the new empty array. + * @example + * + * var arrays = _.times(2, _.stubArray); + * + * console.log(arrays); + * // => [[], []] + * + * console.log(arrays[0] === arrays[1]); + * // => false + */ +function stubArray() { + return []; +} + +module.exports = stubArray; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/stubFalse.js": +/***/ (function(module, exports) { + +/** + * This method returns `false`. + * + * @static + * @memberOf _ + * @since 4.13.0 + * @category Util + * @returns {boolean} Returns `false`. + * @example + * + * _.times(2, _.stubFalse); + * // => [false, false] + */ +function stubFalse() { + return false; +} + +module.exports = stubFalse; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/take.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseSlice = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseSlice.js"), + toInteger = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/toInteger.js"); + +/** + * Creates a slice of `array` with `n` elements taken from the beginning. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to take. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.take([1, 2, 3]); + * // => [1] + * + * _.take([1, 2, 3], 2); + * // => [1, 2] + * + * _.take([1, 2, 3], 5); + * // => [1, 2, 3] + * + * _.take([1, 2, 3], 0); + * // => [] + */ +function take(array, n, guard) { + if (!(array && array.length)) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + return baseSlice(array, 0, n < 0 ? 0 : n); +} + +module.exports = take; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/toFinite.js": +/***/ (function(module, exports, __webpack_require__) { + +var toNumber = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/toNumber.js"); + +/** Used as references for various `Number` constants. */ +var INFINITY = 1 / 0, + MAX_INTEGER = 1.7976931348623157e+308; + +/** + * Converts `value` to a finite number. + * + * @static + * @memberOf _ + * @since 4.12.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted number. + * @example + * + * _.toFinite(3.2); + * // => 3.2 + * + * _.toFinite(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toFinite(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toFinite('3.2'); + * // => 3.2 + */ +function toFinite(value) { + if (!value) { + return value === 0 ? value : 0; + } + value = toNumber(value); + if (value === INFINITY || value === -INFINITY) { + var sign = (value < 0 ? -1 : 1); + return sign * MAX_INTEGER; + } + return value === value ? value : 0; +} + +module.exports = toFinite; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/toInteger.js": +/***/ (function(module, exports, __webpack_require__) { + +var toFinite = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/toFinite.js"); + +/** + * Converts `value` to an integer. + * + * **Note:** This method is loosely based on + * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. + * @example + * + * _.toInteger(3.2); + * // => 3 + * + * _.toInteger(Number.MIN_VALUE); + * // => 0 + * + * _.toInteger(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toInteger('3.2'); + * // => 3 + */ +function toInteger(value) { + var result = toFinite(value), + remainder = result % 1; + + return result === result ? (remainder ? result - remainder : result) : 0; +} + +module.exports = toInteger; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/toNumber.js": +/***/ (function(module, exports, __webpack_require__) { + +var isObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isObject.js"), + isSymbol = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isSymbol.js"); + +/** Used as references for various `Number` constants. */ +var NAN = 0 / 0; + +/** Used to match leading and trailing whitespace. */ +var reTrim = /^\s+|\s+$/g; + +/** Used to detect bad signed hexadecimal string values. */ +var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; + +/** Used to detect binary string values. */ +var reIsBinary = /^0b[01]+$/i; + +/** Used to detect octal string values. */ +var reIsOctal = /^0o[0-7]+$/i; + +/** Built-in method references without a dependency on `root`. */ +var freeParseInt = parseInt; + +/** + * Converts `value` to a number. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to process. + * @returns {number} Returns the number. + * @example + * + * _.toNumber(3.2); + * // => 3.2 + * + * _.toNumber(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toNumber(Infinity); + * // => Infinity + * + * _.toNumber('3.2'); + * // => 3.2 + */ +function toNumber(value) { + if (typeof value == 'number') { + return value; + } + if (isSymbol(value)) { + return NAN; + } + if (isObject(value)) { + var other = typeof value.valueOf == 'function' ? value.valueOf() : value; + value = isObject(other) ? (other + '') : other; + } + if (typeof value != 'string') { + return value === 0 ? value : +value; + } + value = value.replace(reTrim, ''); + var isBinary = reIsBinary.test(value); + return (isBinary || reIsOctal.test(value)) + ? freeParseInt(value.slice(2), isBinary ? 2 : 8) + : (reIsBadHex.test(value) ? NAN : +value); +} + +module.exports = toNumber; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/toPairs.js": +/***/ (function(module, exports, __webpack_require__) { + +var createToPairs = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_createToPairs.js"), + keys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keys.js"); + +/** + * Creates an array of own enumerable string keyed-value pairs for `object` + * which can be consumed by `_.fromPairs`. If `object` is a map or set, its + * entries are returned. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias entries + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the key-value pairs. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.toPairs(new Foo); + * // => [['a', 1], ['b', 2]] (iteration order is not guaranteed) + */ +var toPairs = createToPairs(keys); + +module.exports = toPairs; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/toString.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseToString = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseToString.js"); + +/** + * Converts `value` to a string. An empty string is returned for `null` + * and `undefined` values. The sign of `-0` is preserved. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {string} Returns the converted string. + * @example + * + * _.toString(null); + * // => '' + * + * _.toString(-0); + * // => '-0' + * + * _.toString([1, 2, 3]); + * // => '1,2,3' + */ +function toString(value) { + return value == null ? '' : baseToString(value); +} + +module.exports = toString; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/uniqueId.js": +/***/ (function(module, exports, __webpack_require__) { + +var toString = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/toString.js"); + +/** Used to generate unique IDs. */ +var idCounter = 0; + +/** + * Generates a unique ID. If `prefix` is given, the ID is appended to it. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Util + * @param {string} [prefix=''] The value to prefix the ID with. + * @returns {string} Returns the unique ID. + * @example + * + * _.uniqueId('contact_'); + * // => 'contact_104' + * + * _.uniqueId(); + * // => '105' + */ +function uniqueId(prefix) { + var id = ++idCounter; + return toString(prefix) + id; +} + +module.exports = uniqueId; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/values.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseValues = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseValues.js"), + keys = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/keys.js"); + +/** + * Creates an array of the own enumerable string keyed property values of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property values. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.values(new Foo); + * // => [1, 2] (iteration order is not guaranteed) + * + * _.values('hi'); + * // => ['h', 'i'] + */ +function values(object) { + return object == null ? [] : baseValues(object, keys(object)); +} + +module.exports = values; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/without.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseDifference = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseDifference.js"), + baseRest = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseRest.js"), + isArrayLikeObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/isArrayLikeObject.js"); + +/** + * Creates an array excluding all given values using + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * **Note:** Unlike `_.pull`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...*} [values] The values to exclude. + * @returns {Array} Returns the new array of filtered values. + * @see _.difference, _.xor + * @example + * + * _.without([2, 1, 2, 3], 1, 2); + * // => [3] + */ +var without = baseRest(function(array, values) { + return isArrayLikeObject(array) + ? baseDifference(array, values) + : []; +}); + +module.exports = without; + + +/***/ }), + +/***/ "../../../node_modules/griddle-react/node_modules/lodash/zipObject.js": +/***/ (function(module, exports, __webpack_require__) { + +var assignValue = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_assignValue.js"), + baseZipObject = __webpack_require__("../../../node_modules/griddle-react/node_modules/lodash/_baseZipObject.js"); + +/** + * This method is like `_.fromPairs` except that it accepts two arrays, + * one of property identifiers and one of corresponding values. + * + * @static + * @memberOf _ + * @since 0.4.0 + * @category Array + * @param {Array} [props=[]] The property identifiers. + * @param {Array} [values=[]] The property values. + * @returns {Object} Returns the new object. + * @example + * + * _.zipObject(['a', 'b'], [1, 2]); + * // => { 'a': 1, 'b': 2 } + */ +function zipObject(props, values) { + return baseZipObject(props || [], values || [], assignValue); +} + +module.exports = zipObject; + + +/***/ }), + +/***/ "../../../node_modules/react-selectable/dist/react-selectable.js": +/***/ (function(module, exports, __webpack_require__) { + +(function webpackUniversalModuleDefinition(root, factory) { + if(true) + module.exports = factory(__webpack_require__(0), __webpack_require__(5)); + else if(typeof define === 'function' && define.amd) + define(["react", "react-dom"], factory); + else { + var a = typeof exports === 'object' ? factory(require("react"), require("react-dom")) : factory(root["React"], root["ReactDOM"]); + for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i]; + } +})(this, function(__WEBPACK_EXTERNAL_MODULE_2__, __WEBPACK_EXTERNAL_MODULE_3__) { +return /******/ (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'; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + exports.nodeInRoot = exports.isNodeIn = exports.createSelectable = exports.SelectableGroup = undefined; + + var _selectableGroup = __webpack_require__(1); + + var _selectableGroup2 = _interopRequireDefault(_selectableGroup); + + var _createSelectable = __webpack_require__(9); + + var _createSelectable2 = _interopRequireDefault(_createSelectable); + + var _isNodeIn = __webpack_require__(5); + + var _isNodeIn2 = _interopRequireDefault(_isNodeIn); + + var _nodeInRoot = __webpack_require__(4); + + var _nodeInRoot2 = _interopRequireDefault(_nodeInRoot); + + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + exports.SelectableGroup = _selectableGroup2.default; + exports.createSelectable = _createSelectable2.default; + exports.isNodeIn = _isNodeIn2.default; + exports.nodeInRoot = _nodeInRoot2.default; + +/***/ }), +/* 1 */ +/***/ (function(module, exports, __webpack_require__) { + + 'use strict'; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + + 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; }; }(); + + var _react = __webpack_require__(2); + + var _react2 = _interopRequireDefault(_react); + + var _reactDom = __webpack_require__(3); + + var _reactDom2 = _interopRequireDefault(_reactDom); + + var _nodeInRoot = __webpack_require__(4); + + var _nodeInRoot2 = _interopRequireDefault(_nodeInRoot); + + var _isNodeIn = __webpack_require__(5); + + var _isNodeIn2 = _interopRequireDefault(_isNodeIn); + + var _getBoundsForNode = __webpack_require__(6); + + var _getBoundsForNode2 = _interopRequireDefault(_getBoundsForNode); + + var _doObjectsCollide = __webpack_require__(7); + + var _doObjectsCollide2 = _interopRequireDefault(_doObjectsCollide); + + var _lodash = __webpack_require__(8); + + var _lodash2 = _interopRequireDefault(_lodash); + + 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"); } } + + function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + + function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + + var SelectableGroup = function (_React$Component) { + _inherits(SelectableGroup, _React$Component); + + function SelectableGroup(props) { + _classCallCheck(this, SelectableGroup); + + var _this = _possibleConstructorReturn(this, (SelectableGroup.__proto__ || Object.getPrototypeOf(SelectableGroup)).call(this, props)); + + _this.state = { + isBoxSelecting: false, + boxWidth: 0, + boxHeight: 0 + }; + + _this._mouseDownData = null; + _this._rect = null; + _this._registry = []; + + _this._openSelector = _this._openSelector.bind(_this); + _this._mouseDown = _this._mouseDown.bind(_this); + _this._mouseUp = _this._mouseUp.bind(_this); + _this._selectElements = _this._selectElements.bind(_this); + _this._registerSelectable = _this._registerSelectable.bind(_this); + _this._unregisterSelectable = _this._unregisterSelectable.bind(_this); + + _this._throttledSelect = (0, _lodash2.default)(_this._selectElements, 50); + return _this; + } + + _createClass(SelectableGroup, [{ + key: 'getChildContext', + value: function getChildContext() { + return { + selectable: { + register: this._registerSelectable, + unregister: this._unregisterSelectable + } + }; + } + }, { + key: 'componentDidMount', + value: function componentDidMount() { + this._applyMousedown(this.props.enabled); + this._rect = this._getInitialCoordinates(); + } + + /** + * Remove global event listeners + */ + + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + this._applyMousedown(false); + } + }, { + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(nextProps) { + if (nextProps.enabled !== this.props.enabled) { + this._applyMousedown(nextProps.enabled); + } + } + }, { + key: '_registerSelectable', + value: function _registerSelectable(key, domNode) { + this._registry.push({ key: key, domNode: domNode }); + } + }, { + key: '_unregisterSelectable', + value: function _unregisterSelectable(key) { + this._registry = this._registry.filter(function (data) { + return data.key !== key; + }); + } + }, { + key: '_applyMousedown', + value: function _applyMousedown(apply) { + var funcName = apply ? 'addEventListener' : 'removeEventListener'; + _reactDom2.default.findDOMNode(this)[funcName]('mousedown', this._mouseDown); + } + + /** + * Called while moving the mouse with the button down. Changes the boundaries + * of the selection box + */ + + }, { + key: '_openSelector', + value: function _openSelector(e) { + var w = Math.abs(this._mouseDownData.initialW - e.pageX + this._rect.x); + var h = Math.abs(this._mouseDownData.initialH - e.pageY + this._rect.y); + + this.setState({ + isBoxSelecting: true, + boxWidth: w, + boxHeight: h, + boxLeft: Math.min(e.pageX - this._rect.x, this._mouseDownData.initialW), + boxTop: Math.min(e.pageY - this._rect.y, this._mouseDownData.initialH) + }); + + if (this.props.selectOnMouseMove) this._throttledSelect(e); + } + }, { + key: '_getInitialCoordinates', + value: function _getInitialCoordinates() { + var style = window.getComputedStyle(document.body); + var t = style.getPropertyValue('margin-top'); + var l = style.getPropertyValue('margin-left'); + var mLeft = parseInt(l.slice(0, l.length - 2), 10); + var mTop = parseInt(t.slice(0, t.length - 2), 10); + + var bodyRect = document.body.getBoundingClientRect(); + var elemRect = _reactDom2.default.findDOMNode(this).getBoundingClientRect(); + return { x: Math.round(elemRect.left - bodyRect.left + mLeft), y: Math.round(elemRect.top - bodyRect.top + mTop) }; + } + + /** + * Called when a user presses the mouse button. Determines if a select box should + * be added, and if so, attach event listeners + */ + + }, { + key: '_mouseDown', + value: function _mouseDown(e) { + // Disable if target is control by react-dnd + if ((0, _isNodeIn2.default)(e.target, function (node) { + return !!node.draggable; + })) return; + + var node = _reactDom2.default.findDOMNode(this); + var collides = void 0, + offsetData = void 0, + distanceData = void 0; + window.addEventListener('mouseup', this._mouseUp); + + // Right clicks + if (e.which === 3 || e.button === 2) return; + + if (!(0, _nodeInRoot2.default)(e.target, node)) { + offsetData = (0, _getBoundsForNode2.default)(node); + collides = (0, _doObjectsCollide2.default)({ + top: offsetData.top, + left: offsetData.left, + bottom: offsetData.offsetHeight, + right: offsetData.offsetWidth + }, { + top: e.pageY - this._rect.y, + left: e.pageX - this._rect.x, + offsetWidth: 0, + offsetHeight: 0 + }); + if (!collides) return; + } + this._rect = this._getInitialCoordinates(); + + this._mouseDownData = { + boxLeft: e.pageX - this._rect.x, + boxTop: e.pageY - this._rect.y, + initialW: e.pageX - this._rect.x, + initialH: e.pageY - this._rect.y + }; + + if (this.props.preventDefault) e.preventDefault(); + + window.addEventListener('mousemove', this._openSelector); + } + + /** + * Called when the user has completed selection + */ + + }, { + key: '_mouseUp', + value: function _mouseUp(e) { + e.stopPropagation(); + window.removeEventListener('mousemove', this._openSelector); + window.removeEventListener('mouseup', this._mouseUp); + + if (!this._mouseDownData) return; + + // Mouse up when not box selecting is a heuristic for a "click" + if (this.props.onNonItemClick && !this.state.isBoxSelecting) { + if (!this._registry.some(function (_ref) { + var domNode = _ref.domNode; + return (0, _nodeInRoot2.default)(e.target, domNode); + })) { + this.props.onNonItemClick(e); + } + } + + this._selectElements(e); + + this._mouseDownData = null; + this.setState({ + isBoxSelecting: false, + boxWidth: 0, + boxHeight: 0 + }); + } + + /** + * Selects multiple children given x/y coords of the mouse + */ + + }, { + key: '_selectElements', + value: function _selectElements(e) { + var currentItems = [], + selectbox = _reactDom2.default.findDOMNode(this.refs.selectbox), + tolerance = this.props.tolerance; + + + if (!selectbox) return; + + this._registry.forEach(function (itemData) { + if (itemData.domNode && (0, _doObjectsCollide2.default)(selectbox, itemData.domNode, tolerance) && !currentItems.includes(itemData.key)) { + currentItems.push(itemData.key); + } + }); + + this.props.onSelection(currentItems, e); + } + + /** + * Renders the component + * @return {ReactComponent} + */ + + }, { + key: 'render', + value: function render() { + var Component = this.props.component; + + if (!this.props.enabled) { + return _react2.default.createElement( + Component, + { className: this.props.className }, + this.props.children + ); + } + + var boxStyle = { + left: this.state.boxLeft, + top: this.state.boxTop, + width: this.state.boxWidth, + height: this.state.boxHeight, + zIndex: 9000, + position: this.props.fixedPosition ? 'fixed' : 'absolute', + cursor: 'default' + }; + + var spanStyle = { + backgroundColor: 'transparent', + border: '1px dashed #999', + width: '100%', + height: '100%', + float: 'left' + }; + + var wrapperStyle = { + position: 'relative', + overflow: 'visible' + }; + + return _react2.default.createElement( + Component, + { className: this.props.className, style: wrapperStyle }, + this.state.isBoxSelecting && _react2.default.createElement( + 'div', + { style: boxStyle, ref: 'selectbox' }, + _react2.default.createElement('span', { style: spanStyle }) + ), + this.props.children + ); + } + }]); + + return SelectableGroup; + }(_react2.default.Component); + + SelectableGroup.propTypes = { + + /** + * Event that will fire when items are selected. Passes an array of keys + */ + onSelection: _react2.default.PropTypes.func, + + /** + * The component that will represent the Selectable DOM node + */ + component: _react2.default.PropTypes.node, + + /** + * Amount of forgiveness an item will offer to the selectbox before registering + * a selection, i.e. if only 1px of the item is in the selection, it shouldn't be + * included. + */ + tolerance: _react2.default.PropTypes.number, + + /** + * In some cases, it the bounding box may need fixed positioning, if your layout + * is relying on fixed positioned elements, for instance. + * @type boolean + */ + fixedPosition: _react2.default.PropTypes.bool, + + /** + * Enable to fire the onSelection callback while the mouse is moving. Throttled to 50ms + * for performance in IE/Edge + * @type boolean + */ + selectOnMouseMove: _react2.default.PropTypes.bool, + + /** + * Allows to enable/disable preventing the default action of the onmousedown event (with e.preventDefault). + * True by default. Disable if your app needs to capture this event for other functionalities. + * @type boolean + */ + preventDefault: _react2.default.PropTypes.bool, + + /** + * Triggered when the user clicks in the component, but not on an item, e.g. whitespace + * + * @type {Function} + */ + onNonItemClick: _react2.default.PropTypes.func, + + /** + * If false, all of the selectble features are turned off. + * @type {[type]} + */ + enabled: _react2.default.PropTypes.bool, + + /** + * A CSS class to add to the containing element + * @type {string} + */ + className: _react2.default.PropTypes.string + + }; + + SelectableGroup.defaultProps = { + onSelection: function onSelection() {}, + component: 'div', + tolerance: 0, + fixedPosition: false, + selectOnMouseMove: false, + preventDefault: true, + enabled: true + }; + + SelectableGroup.childContextTypes = { + selectable: _react2.default.PropTypes.object + }; + + exports.default = SelectableGroup; + +/***/ }), +/* 2 */ +/***/ (function(module, exports) { + + module.exports = __WEBPACK_EXTERNAL_MODULE_2__; + +/***/ }), +/* 3 */ +/***/ (function(module, exports) { + + module.exports = __WEBPACK_EXTERNAL_MODULE_3__; + +/***/ }), +/* 4 */ +/***/ (function(module, exports, __webpack_require__) { + + 'use strict'; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + + var _isNodeIn = __webpack_require__(5); + + var _isNodeIn2 = _interopRequireDefault(_isNodeIn); + + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + var isNodeInRoot = function isNodeInRoot(node, root) { + return (0, _isNodeIn2.default)(node, function (currentNode) { + return currentNode === root; + }); + }; + + exports.default = isNodeInRoot; + +/***/ }), +/* 5 */ +/***/ (function(module, exports) { + + 'use strict'; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + var isNodeIn = function isNodeIn(node, predicate) { + if (typeof predicate !== 'function') { + throw new Error('isNodeIn second parameter must be a function'); + } + + var currentNode = node; + while (currentNode) { + if (predicate(currentNode)) { + return true; + } + currentNode = currentNode.parentNode; + } + + return false; + }; + + exports.default = isNodeIn; + +/***/ }), +/* 6 */ +/***/ (function(module, exports) { + + "use strict"; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + + /** + * Given a node, get everything needed to calculate its boundaries + * @param {HTMLElement} node + * @return {Object} + */ + exports.default = function (node) { + var rect = node.getBoundingClientRect(); + + return { + top: rect.top + document.body.scrollTop, + left: rect.left + document.body.scrollLeft, + offsetWidth: node.offsetWidth, + offsetHeight: node.offsetHeight + }; + }; + +/***/ }), +/* 7 */ +/***/ (function(module, exports, __webpack_require__) { + + 'use strict'; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + + var _getBoundsForNode = __webpack_require__(6); + + var _getBoundsForNode2 = _interopRequireDefault(_getBoundsForNode); + + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + + /** + * Given offsets, widths, and heights of two objects, determine if they collide (overlap). + * @param {int} aTop The top position of the first object + * @param {int} aLeft The left position of the first object + * @param {int} bTop The top position of the second object + * @param {int} bLeft The left position of the second object + * @param {int} aWidth The width of the first object + * @param {int} aHeight The height of the first object + * @param {int} bWidth The width of the second object + * @param {int} bHeight The height of the second object + * @return {bool} + */ + var coordsCollide = function coordsCollide(aTop, aLeft, bTop, bLeft, aWidth, aHeight, bWidth, bHeight, tolerance) { + if (typeof tolerance === 'undefined') { + tolerance = 0; + } + + return !( + // 'a' bottom doesn't touch 'b' top + aTop + aHeight - tolerance < bTop || + // 'a' top doesn't touch 'b' bottom + aTop + tolerance > bTop + bHeight || + // 'a' right doesn't touch 'b' left + aLeft + aWidth - tolerance < bLeft || + // 'a' left doesn't touch 'b' right + aLeft + tolerance > bLeft + bWidth); + }; + + /** + * Given two objects containing "top", "left", "offsetWidth" and "offsetHeight" + * properties, determine if they collide. + * @param {Object|HTMLElement} a + * @param {Object|HTMLElement} b + * @return {bool} + */ + + exports.default = function (a, b, tolerance) { + var aObj = a instanceof HTMLElement ? (0, _getBoundsForNode2.default)(a) : a, + bObj = b instanceof HTMLElement ? (0, _getBoundsForNode2.default)(b) : b; + + return coordsCollide(aObj.top, aObj.left, bObj.top, bObj.left, aObj.offsetWidth, aObj.offsetHeight, bObj.offsetWidth, bObj.offsetHeight, tolerance); + }; + +/***/ }), +/* 8 */ +/***/ (function(module, exports) { + + /* WEBPACK VAR INJECTION */(function(global) {'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 && obj !== Symbol.prototype ? "symbol" : typeof obj; }; + + /** + * lodash (Custom Build) + * Build: `lodash modularize exports="npm" -o ./` + * Copyright jQuery Foundation and other contributors + * Released under MIT license + * Based on Underscore.js 1.8.3 + * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors + */ + + /** Used as the `TypeError` message for "Functions" methods. */ + var FUNC_ERROR_TEXT = 'Expected a function'; + + /** Used as references for various `Number` constants. */ + var NAN = 0 / 0; + + /** `Object#toString` result references. */ + var symbolTag = '[object Symbol]'; + + /** Used to match leading and trailing whitespace. */ + var reTrim = /^\s+|\s+$/g; + + /** Used to detect bad signed hexadecimal string values. */ + var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; + + /** Used to detect binary string values. */ + var reIsBinary = /^0b[01]+$/i; + + /** Used to detect octal string values. */ + var reIsOctal = /^0o[0-7]+$/i; + + /** Built-in method references without a dependency on `root`. */ + var freeParseInt = parseInt; + + /** Detect free variable `global` from Node.js. */ + var freeGlobal = (typeof global === 'undefined' ? 'undefined' : _typeof(global)) == 'object' && global && global.Object === Object && global; + + /** Detect free variable `self`. */ + var freeSelf = (typeof self === 'undefined' ? 'undefined' : _typeof(self)) == 'object' && self && self.Object === Object && self; + + /** Used as a reference to the global object. */ + var root = freeGlobal || freeSelf || Function('return this')(); + + /** Used for built-in method references. */ + var objectProto = Object.prototype; + + /** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ + var objectToString = objectProto.toString; + + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeMax = Math.max, + nativeMin = Math.min; + + /** + * Gets the timestamp of the number of milliseconds that have elapsed since + * the Unix epoch (1 January 1970 00:00:00 UTC). + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Date + * @returns {number} Returns the timestamp. + * @example + * + * _.defer(function(stamp) { + * console.log(_.now() - stamp); + * }, _.now()); + * // => Logs the number of milliseconds it took for the deferred invocation. + */ + var now = function now() { + return root.Date.now(); + }; + + /** + * Creates a debounced function that delays invoking `func` until after `wait` + * milliseconds have elapsed since the last time the debounced function was + * invoked. The debounced function comes with a `cancel` method to cancel + * delayed `func` invocations and a `flush` method to immediately invoke them. + * Provide `options` to indicate whether `func` should be invoked on the + * leading and/or trailing edge of the `wait` timeout. The `func` is invoked + * with the last arguments provided to the debounced function. Subsequent + * calls to the debounced function return the result of the last `func` + * invocation. + * + * **Note:** If `leading` and `trailing` options are `true`, `func` is + * invoked on the trailing edge of the timeout only if the debounced function + * is invoked more than once during the `wait` timeout. + * + * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred + * until to the next tick, similar to `setTimeout` with a timeout of `0`. + * + * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/) + * for details over the differences between `_.debounce` and `_.throttle`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to debounce. + * @param {number} [wait=0] The number of milliseconds to delay. + * @param {Object} [options={}] The options object. + * @param {boolean} [options.leading=false] + * Specify invoking on the leading edge of the timeout. + * @param {number} [options.maxWait] + * The maximum time `func` is allowed to be delayed before it's invoked. + * @param {boolean} [options.trailing=true] + * Specify invoking on the trailing edge of the timeout. + * @returns {Function} Returns the new debounced function. + * @example + * + * // Avoid costly calculations while the window size is in flux. + * jQuery(window).on('resize', _.debounce(calculateLayout, 150)); + * + * // Invoke `sendMail` when clicked, debouncing subsequent calls. + * jQuery(element).on('click', _.debounce(sendMail, 300, { + * 'leading': true, + * 'trailing': false + * })); + * + * // Ensure `batchLog` is invoked once after 1 second of debounced calls. + * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 }); + * var source = new EventSource('/stream'); + * jQuery(source).on('message', debounced); + * + * // Cancel the trailing debounced invocation. + * jQuery(window).on('popstate', debounced.cancel); + */ + function debounce(func, wait, options) { + var lastArgs, + lastThis, + maxWait, + result, + timerId, + lastCallTime, + lastInvokeTime = 0, + leading = false, + maxing = false, + trailing = true; + + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + wait = toNumber(wait) || 0; + if (isObject(options)) { + leading = !!options.leading; + maxing = 'maxWait' in options; + maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait; + trailing = 'trailing' in options ? !!options.trailing : trailing; + } + + function invokeFunc(time) { + var args = lastArgs, + thisArg = lastThis; + + lastArgs = lastThis = undefined; + lastInvokeTime = time; + result = func.apply(thisArg, args); + return result; + } + + function leadingEdge(time) { + // Reset any `maxWait` timer. + lastInvokeTime = time; + // Start the timer for the trailing edge. + timerId = setTimeout(timerExpired, wait); + // Invoke the leading edge. + return leading ? invokeFunc(time) : result; + } + + function remainingWait(time) { + var timeSinceLastCall = time - lastCallTime, + timeSinceLastInvoke = time - lastInvokeTime, + result = wait - timeSinceLastCall; + + return maxing ? nativeMin(result, maxWait - timeSinceLastInvoke) : result; + } + + function shouldInvoke(time) { + var timeSinceLastCall = time - lastCallTime, + timeSinceLastInvoke = time - lastInvokeTime; + + // Either this is the first call, activity has stopped and we're at the + // trailing edge, the system time has gone backwards and we're treating + // it as the trailing edge, or we've hit the `maxWait` limit. + return lastCallTime === undefined || timeSinceLastCall >= wait || timeSinceLastCall < 0 || maxing && timeSinceLastInvoke >= maxWait; + } + + function timerExpired() { + var time = now(); + if (shouldInvoke(time)) { + return trailingEdge(time); + } + // Restart the timer. + timerId = setTimeout(timerExpired, remainingWait(time)); + } + + function trailingEdge(time) { + timerId = undefined; + + // Only invoke if we have `lastArgs` which means `func` has been + // debounced at least once. + if (trailing && lastArgs) { + return invokeFunc(time); + } + lastArgs = lastThis = undefined; + return result; + } + + function cancel() { + if (timerId !== undefined) { + clearTimeout(timerId); + } + lastInvokeTime = 0; + lastArgs = lastCallTime = lastThis = timerId = undefined; + } + + function flush() { + return timerId === undefined ? result : trailingEdge(now()); + } + + function debounced() { + var time = now(), + isInvoking = shouldInvoke(time); + + lastArgs = arguments; + lastThis = this; + lastCallTime = time; + + if (isInvoking) { + if (timerId === undefined) { + return leadingEdge(lastCallTime); + } + if (maxing) { + // Handle invocations in a tight loop. + timerId = setTimeout(timerExpired, wait); + return invokeFunc(lastCallTime); + } + } + if (timerId === undefined) { + timerId = setTimeout(timerExpired, wait); + } + return result; + } + debounced.cancel = cancel; + debounced.flush = flush; + return debounced; + } + + /** + * Creates a throttled function that only invokes `func` at most once per + * every `wait` milliseconds. The throttled function comes with a `cancel` + * method to cancel delayed `func` invocations and a `flush` method to + * immediately invoke them. Provide `options` to indicate whether `func` + * should be invoked on the leading and/or trailing edge of the `wait` + * timeout. The `func` is invoked with the last arguments provided to the + * throttled function. Subsequent calls to the throttled function return the + * result of the last `func` invocation. + * + * **Note:** If `leading` and `trailing` options are `true`, `func` is + * invoked on the trailing edge of the timeout only if the throttled function + * is invoked more than once during the `wait` timeout. + * + * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred + * until to the next tick, similar to `setTimeout` with a timeout of `0`. + * + * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/) + * for details over the differences between `_.throttle` and `_.debounce`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to throttle. + * @param {number} [wait=0] The number of milliseconds to throttle invocations to. + * @param {Object} [options={}] The options object. + * @param {boolean} [options.leading=true] + * Specify invoking on the leading edge of the timeout. + * @param {boolean} [options.trailing=true] + * Specify invoking on the trailing edge of the timeout. + * @returns {Function} Returns the new throttled function. + * @example + * + * // Avoid excessively updating the position while scrolling. + * jQuery(window).on('scroll', _.throttle(updatePosition, 100)); + * + * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes. + * var throttled = _.throttle(renewToken, 300000, { 'trailing': false }); + * jQuery(element).on('click', throttled); + * + * // Cancel the trailing throttled invocation. + * jQuery(window).on('popstate', throttled.cancel); + */ + function throttle(func, wait, options) { + var leading = true, + trailing = true; + + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + if (isObject(options)) { + leading = 'leading' in options ? !!options.leading : leading; + trailing = 'trailing' in options ? !!options.trailing : trailing; + } + return debounce(func, wait, { + 'leading': leading, + 'maxWait': wait, + 'trailing': trailing + }); + } + + /** + * Checks if `value` is the + * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types) + * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) + * + * @static + * @memberOf _ + * @since 0.1.0 + * @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) { + var type = typeof value === 'undefined' ? 'undefined' : _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 _ + * @since 4.0.0 + * @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 === 'undefined' ? 'undefined' : _typeof(value)) == 'object'; + } + + /** + * Checks if `value` is classified as a `Symbol` primitive or object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a symbol, else `false`. + * @example + * + * _.isSymbol(Symbol.iterator); + * // => true + * + * _.isSymbol('abc'); + * // => false + */ + function isSymbol(value) { + return (typeof value === 'undefined' ? 'undefined' : _typeof(value)) == 'symbol' || isObjectLike(value) && objectToString.call(value) == symbolTag; + } + + /** + * Converts `value` to a number. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to process. + * @returns {number} Returns the number. + * @example + * + * _.toNumber(3.2); + * // => 3.2 + * + * _.toNumber(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toNumber(Infinity); + * // => Infinity + * + * _.toNumber('3.2'); + * // => 3.2 + */ + function toNumber(value) { + if (typeof value == 'number') { + return value; + } + if (isSymbol(value)) { + return NAN; + } + if (isObject(value)) { + var other = typeof value.valueOf == 'function' ? value.valueOf() : value; + value = isObject(other) ? other + '' : other; + } + if (typeof value != 'string') { + return value === 0 ? value : +value; + } + value = value.replace(reTrim, ''); + var isBinary = reIsBinary.test(value); + return isBinary || reIsOctal.test(value) ? freeParseInt(value.slice(2), isBinary ? 2 : 8) : reIsBadHex.test(value) ? NAN : +value; + } + + module.exports = throttle; + /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) + +/***/ }), +/* 9 */ +/***/ (function(module, exports, __webpack_require__) { + + 'use strict'; + + Object.defineProperty(exports, "__esModule", { + value: true + }); + + 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; }; }(); + + var _react = __webpack_require__(2); + + var _react2 = _interopRequireDefault(_react); + + var _reactDom = __webpack_require__(3); + + var _reactDom2 = _interopRequireDefault(_reactDom); + + 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"); } } + + function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + + function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + + var createSelectable = function createSelectable(WrappedComponent) { + var SelectableItem = function (_React$Component) { + _inherits(SelectableItem, _React$Component); + + function SelectableItem() { + _classCallCheck(this, SelectableItem); + + return _possibleConstructorReturn(this, (SelectableItem.__proto__ || Object.getPrototypeOf(SelectableItem)).apply(this, arguments)); + } + + _createClass(SelectableItem, [{ + key: 'componentDidMount', + value: function componentDidMount() { + this.context.selectable.register(this.props.selectableKey, _reactDom2.default.findDOMNode(this)); + } + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + this.context.selectable.unregister(this.props.selectableKey); + } + }, { + key: 'render', + value: function render() { + return _react2.default.createElement(WrappedComponent, this.props, this.props.children); + } + }]); + + return SelectableItem; + }(_react2.default.Component); + + SelectableItem.contextTypes = { + selectable: _react2.default.PropTypes.object + }; + + SelectableItem.propTypes = { + selectableKey: _react2.default.PropTypes.any.isRequired + }; + + return SelectableItem; + }; + + exports.default = createSelectable; + +/***/ }) +/******/ ]) +}); +; + +/***/ }), + +/***/ "../../../node_modules/webpack/buildin/global.js": +/***/ (function(module, exports) { + +var g; + +// This works in non-strict mode +g = (function() { + return this; +})(); + +try { + // This works if eval is allowed (see CSP) + g = g || Function("return this")() || (1,eval)("this"); +} catch(e) { + // This works if the window reference is available + if(typeof window === "object") + g = window; +} + +// g can still be undefined, but nothing to do about it... +// We return undefined, instead of nothing here, so it's +// easier to handle this case. if(!global) { ...} + +module.exports = g; + + +/***/ }), + +/***/ "../../../node_modules/webpack/buildin/module.js": +/***/ (function(module, exports) { + +module.exports = function(module) { + if(!module.webpackPolyfill) { + module.deprecate = function() {}; + module.paths = []; + // module.parent = undefined by default + if(!module.children) module.children = []; + Object.defineProperty(module, "loaded", { + enumerable: true, + get: function() { + return module.l; + } + }); + Object.defineProperty(module, "id", { + enumerable: true, + get: function() { + return module.i; + } + }); + module.webpackPolyfill = 1; + } + return module; +}; + + +/***/ }), + +/***/ "./client/src/boot/applyTransform.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _Injector = __webpack_require__(2); + +var _Injector2 = _interopRequireDefault(_Injector); + +var _insertAssetModal = __webpack_require__("./client/src/transforms/AssetAdmin/insertAssetModal.js"); + +var _insertAssetModal2 = _interopRequireDefault(_insertAssetModal); + +var _ownerAwareUnpublish = __webpack_require__("./client/src/transforms/FormAction/ownerAwareUnpublish.js"); + +var _ownerAwareUnpublish2 = _interopRequireDefault(_ownerAwareUnpublish); + +var _moveTreeDropdownField = __webpack_require__("./client/src/transforms/TreeDropdownField/moveTreeDropdownField.js"); + +var _moveTreeDropdownField2 = _interopRequireDefault(_moveTreeDropdownField); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var applyTransform = function applyTransform() { + _Injector2.default.transform('insert-media-modal', function (updater) { + updater.form.alterSchema('AssetAdmin.EditForm.fileInsertForm', _insertAssetModal2.default); + }); + + _Injector2.default.transform('move-form-disabled', function (updater) { + updater.component('TreeDropdownField.AssetAdmin.MoveForm', _moveTreeDropdownField2.default); + }); + + _Injector2.default.transform('owner-unpublishing', function (updater) { + updater.component('FormAction.AssetAdmin.EditForm.action_unpublish', _ownerAwareUnpublish2.default); + }); +}; + +exports.default = applyTransform; + +/***/ }), + +/***/ "./client/src/boot/index.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +var _Config = __webpack_require__(20); + +var _Config2 = _interopRequireDefault(_Config); + +var _ReactRouteRegister = __webpack_require__(34); + +var _ReactRouteRegister2 = _interopRequireDefault(_ReactRouteRegister); + +var _AssetAdminRouter = __webpack_require__("./client/src/containers/AssetAdmin/AssetAdminRouter.js"); + +var _AssetAdminRouter2 = _interopRequireDefault(_AssetAdminRouter); + +var _applyTransform = __webpack_require__("./client/src/boot/applyTransform.js"); + +var _applyTransform2 = _interopRequireDefault(_applyTransform); + +var _registerReducers = __webpack_require__("./client/src/boot/registerReducers.js"); + +var _registerReducers2 = _interopRequireDefault(_registerReducers); + +var _registerComponents = __webpack_require__("./client/src/boot/registerComponents.js"); + +var _registerComponents2 = _interopRequireDefault(_registerComponents); + +var _registerQueries = __webpack_require__("./client/src/boot/registerQueries.js"); + +var _registerQueries2 = _interopRequireDefault(_registerQueries); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +document.addEventListener('DOMContentLoaded', function () { + (0, _registerComponents2.default)(); + + (0, _applyTransform2.default)(); + + var sectionConfig = _Config2.default.getSection('SilverStripe\\AssetAdmin\\Controller\\AssetAdmin'); + + _ReactRouteRegister2.default.add({ + path: sectionConfig.url, + component: _AssetAdminRouter2.default, + indexRoute: { component: _AssetAdminRouter2.default }, + childRoutes: [{ + path: 'show/:folderId/:viewAction/:fileId', + component: _AssetAdminRouter2.default + }, { + path: 'show/:folderId/:viewAction', + component: _AssetAdminRouter2.default + }, { + path: 'show/:folderId', + component: _AssetAdminRouter2.default + }] + }); + + (0, _registerQueries2.default)(); + + (0, _registerReducers2.default)(); +}); + +/***/ }), + +/***/ "./client/src/boot/registerComponents.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _Injector = __webpack_require__(2); + +var _Injector2 = _interopRequireDefault(_Injector); + +var _UploadField = __webpack_require__("./client/src/components/UploadField/UploadField.js"); + +var _UploadField2 = _interopRequireDefault(_UploadField); + +var _UploadFieldItem = __webpack_require__("./client/src/components/UploadField/UploadFieldItem.js"); + +var _UploadFieldItem2 = _interopRequireDefault(_UploadFieldItem); + +var _AssetDropzone = __webpack_require__("./client/src/components/AssetDropzone/AssetDropzone.js"); + +var _AssetDropzone2 = _interopRequireDefault(_AssetDropzone); + +var _InsertMediaModal = __webpack_require__(10); + +var _InsertMediaModal2 = _interopRequireDefault(_InsertMediaModal); + +var _PreviewImageField = __webpack_require__("./client/src/components/PreviewImageField/PreviewImageField.js"); + +var _PreviewImageField2 = _interopRequireDefault(_PreviewImageField); + +var _ProportionConstraintField = __webpack_require__("./client/src/components/ProportionConstraintField/ProportionConstraintField.js"); + +var _ProportionConstraintField2 = _interopRequireDefault(_ProportionConstraintField); + +var _HistoryList = __webpack_require__("./client/src/containers/HistoryList/HistoryList.js"); + +var _HistoryList2 = _interopRequireDefault(_HistoryList); + +var _GalleryToolbar = __webpack_require__("./client/src/components/GalleryToolbar/GalleryToolbar.js"); + +var _GalleryToolbar2 = _interopRequireDefault(_GalleryToolbar); + +var _GalleryItem = __webpack_require__("./client/src/components/GalleryItem/GalleryItem.js"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var registerComponents = function registerComponents() { + _Injector2.default.component.registerMany({ + UploadField: _UploadField2.default, + UploadFieldItem: _UploadFieldItem2.default, + PreviewImageField: _PreviewImageField2.default, + HistoryList: _HistoryList2.default, + ProportionConstraintField: _ProportionConstraintField2.default, + AssetDropzone: _AssetDropzone2.default, + InsertMediaModal: _InsertMediaModal2.default, + GalleryToolbar: _GalleryToolbar2.default, + GalleryItemFile: _GalleryItem.File, + GalleryItemFolder: _GalleryItem.Folder + }); +}; + +exports.default = registerComponents; + +/***/ }), + +/***/ "./client/src/boot/registerQueries.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _Injector = __webpack_require__(2); + +var _Injector2 = _interopRequireDefault(_Injector); + +var _fileFragments = __webpack_require__("./client/src/lib/fileFragments.js"); + +var _readFilesQuery = __webpack_require__("./client/src/state/files/readFilesQuery.js"); + +var _readFilesQuery2 = _interopRequireDefault(_readFilesQuery); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var registerQueries = function registerQueries() { + _Injector2.default.query.registerFragment('FileInterfaceFields', _fileFragments.fileInterface); + _Injector2.default.query.registerFragment('FileFields', _fileFragments.file); + _Injector2.default.query.registerFragment('FolderFields', _fileFragments.folder); + _Injector2.default.query.register('ReadFilesQuery', _readFilesQuery2.default); +}; +exports.default = registerQueries; + +/***/ }), + +/***/ "./client/src/boot/registerReducers.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _Injector = __webpack_require__(2); + +var _Injector2 = _interopRequireDefault(_Injector); + +var _redux = __webpack_require__(4); + +var _GalleryReducer = __webpack_require__("./client/src/state/gallery/GalleryReducer.js"); + +var _GalleryReducer2 = _interopRequireDefault(_GalleryReducer); + +var _QueuedFilesReducer = __webpack_require__("./client/src/state/queuedFiles/QueuedFilesReducer.js"); + +var _QueuedFilesReducer2 = _interopRequireDefault(_QueuedFilesReducer); + +var _UploadFieldReducer = __webpack_require__("./client/src/state/uploadField/UploadFieldReducer.js"); + +var _UploadFieldReducer2 = _interopRequireDefault(_UploadFieldReducer); + +var _PreviewFieldReducer = __webpack_require__("./client/src/state/previewField/PreviewFieldReducer.js"); + +var _PreviewFieldReducer2 = _interopRequireDefault(_PreviewFieldReducer); + +var _ImageLoadReducer = __webpack_require__("./client/src/state/imageLoad/ImageLoadReducer.js"); + +var _ImageLoadReducer2 = _interopRequireDefault(_ImageLoadReducer); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var registerReducers = function registerReducers() { + _Injector2.default.reducer.register('assetAdmin', (0, _redux.combineReducers)({ + gallery: _GalleryReducer2.default, + queuedFiles: _QueuedFilesReducer2.default, + uploadField: _UploadFieldReducer2.default, + previewField: _PreviewFieldReducer2.default, + imageLoad: _ImageLoadReducer2.default + })); +}; + +exports.default = registerReducers; + +/***/ }), + +/***/ "./client/src/bundles/bundle.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +__webpack_require__("../../../node_modules/expose-loader/index.js?InsertMediaModal!./client/src/containers/InsertMediaModal/InsertMediaModal.js-exposed"); +__webpack_require__("../../../node_modules/expose-loader/index.js?InsertEmbedModal!./client/src/components/InsertEmbedModal/InsertEmbedModal.js-exposed"); + +__webpack_require__("./client/src/boot/index.js"); +__webpack_require__("./client/src/entwine/UploadField/UploadFieldEntwine.js"); + +/***/ }), + +/***/ "./client/src/components/AssetDropzone/AssetDropzone.js": +/***/ (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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactDom = __webpack_require__(5); + +var _reactDom2 = _interopRequireDefault(_reactDom); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _dropzone = __webpack_require__("../../../node_modules/dropzone/dist/dropzone.js"); + +var _dropzone2 = _interopRequireDefault(_dropzone); + +var _jquery = __webpack_require__(6); + +var _jquery2 = _interopRequireDefault(_jquery); + +var _DataFormat = __webpack_require__(12); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var idCounter = 0; + +var AssetDropzone = function (_Component) { + _inherits(AssetDropzone, _Component); + + function AssetDropzone(props) { + _classCallCheck(this, AssetDropzone); + + var _this = _possibleConstructorReturn(this, (AssetDropzone.__proto__ || Object.getPrototypeOf(AssetDropzone)).call(this, props)); + + _this.dropzone = null; + _this.dragging = false; + + _this.handleAccept = _this.handleAccept.bind(_this); + _this.handleAddedFile = _this.handleAddedFile.bind(_this); + _this.handleDragEnter = _this.handleDragEnter.bind(_this); + _this.handleDragLeave = _this.handleDragLeave.bind(_this); + _this.handleDrop = _this.handleDrop.bind(_this); + _this.handleUploadProgress = _this.handleUploadProgress.bind(_this); + _this.handleError = _this.handleError.bind(_this); + _this.handleSending = _this.handleSending.bind(_this); + _this.handleSuccess = _this.handleSuccess.bind(_this); + _this.loadImage = _this.loadImage.bind(_this); + _this.handleMaxFilesExceeded = _this.handleMaxFilesExceeded.bind(_this); + return _this; + } + + _createClass(AssetDropzone, [{ + key: 'componentDidMount', + value: function componentDidMount() { + var defaultOptions = this.getDefaultOptions(); + + this.dropzone = new _dropzone2.default(_reactDom2.default.findDOMNode(this), Object.assign({}, defaultOptions, this.props.options)); + + var name = this.props.name; + if (name) { + this.dropzone.hiddenFileInput.classList.add('dz-input-' + name); + } + + if (typeof this.props.promptOnRemove !== 'undefined') { + this.setPromptOnRemove(this.props.promptOnRemove); + } + } + }, { + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(nextProps) { + if (nextProps.canUpload) { + if (this.dropzone) { + this.dropzone.enable(); + + this.dropzone.options = Object.assign({}, this.dropzone.options, this.getDefaultOptions(), this.props.options); + } + } else { + this.dropzone.disable(); + } + } + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + this.dropzone.disable(); + } + }, { + key: 'getDefaultOptions', + value: function getDefaultOptions() { + var clickable = null; + var uploadSelector = this.props.uploadSelector; + if (!uploadSelector && this.props.uploadButton) { + uploadSelector = '.asset-dropzone__upload-button'; + } + + if (uploadSelector) { + var found = (0, _jquery2.default)(_reactDom2.default.findDOMNode(this)).find(uploadSelector); + if (found && found.length) { + clickable = found.toArray(); + } + } + + return { + accept: this.handleAccept, + + addedfile: this.handleAddedFile, + + dragenter: this.handleDragEnter, + + dragleave: this.handleDragLeave, + + drop: this.handleDrop, + + maxfilesexceeded: this.handleMaxFilesExceeded, + + uploadprogress: this.handleUploadProgress, + + dictDefaultMessage: _i18n2.default._t('AssetAdmin.DROPZONE_DEFAULT_MESSAGE', 'Drop files here to upload'), + + dictFallbackMessage: _i18n2.default._t('AssetAdmin.DROPZONE_FALLBACK_MESSAGE', 'Your browser does not support drag\'n\'drop file uploads.'), + + dictFallbackText: _i18n2.default._t('AssetAdmin.DROPZONE_FALLBACK_TEXT', 'Please use the fallback form below to upload your files like in the olden days.'), + + dictInvalidFileType: _i18n2.default._t('AssetAdmin.DROPZONE_INVALID_FILE_TYPE', 'You can\'t upload files of this type.'), + + dictResponseError: _i18n2.default._t('AssetAdmin.DROPZONE_RESPONSE_ERROR', 'Server responded with an error.'), + + dictCancelUpload: _i18n2.default._t('AssetAdmin.DROPZONE_CANCEL_UPLOAD', 'Cancel upload'), + + dictCancelUploadConfirmation: _i18n2.default._t('AssetAdmin.DROPZONE_CANCEL_UPLOAD_CONFIRMATION', 'Are you sure you want to cancel this upload?'), + + dictRemoveFile: _i18n2.default._t('AssetAdmin.DROPZONE_REMOVE_FILE', 'Remove file'), + + dictMaxFilesExceeded: _i18n2.default._t('AssetAdmin.DROPZONE_MAX_FILES_EXCEEDED', 'You can not upload any more files.'), + + error: this.handleError, + + sending: this.handleSending, + + success: this.handleSuccess, + + thumbnailHeight: 150, + + thumbnailWidth: 200, + + clickable: clickable + }; + } + }, { + key: 'getFileCategory', + value: function getFileCategory(fileType) { + return fileType.split('/')[0]; + } + }, { + key: 'getLoadPreview', + value: function getLoadPreview(file) { + var _this2 = this; + + return new Promise(function (resolve) { + var reader = new FileReader(); + + reader.onload = function (event) { + + if (_this2.getFileCategory(file.type) === 'image') { + var img = new Image(); + + resolve(_this2.loadImage(img, event.target.result)); + } else { + resolve({}); + } + }; + + reader.readAsDataURL(file); + }); + } + }, { + key: 'getFileTitle', + value: function getFileTitle(filename) { + return filename.replace(/[.][^.]+$/, '').replace(/-_/, ' '); + } + }, { + key: 'setPromptOnRemove', + value: function setPromptOnRemove(userPrompt) { + this.dropzone.options.dictRemoveFileConfirmation = userPrompt; + } + }, { + key: 'handleDragEnter', + value: function handleDragEnter(event) { + if (!this.props.canUpload) { + return; + } + + this.dragging = true; + this.forceUpdate(); + + if (typeof this.props.onDragEnter === 'function') { + this.props.onDragEnter(event); + } + } + }, { + key: 'handleDragLeave', + value: function handleDragLeave(event) { + var componentNode = _reactDom2.default.findDOMNode(this); + + if (!this.props.canUpload) { + return; + } + + if (event.target !== componentNode) { + return; + } + + this.dragging = false; + this.forceUpdate(); + + if (typeof this.props.onDragLeave === 'function') { + this.props.onDragLeave(event, componentNode); + } + } + }, { + key: 'handleUploadProgress', + value: function handleUploadProgress(file, progress, bytesSent) { + if (typeof this.props.onUploadProgress === 'function') { + this.props.onUploadProgress(file, progress, bytesSent); + } + } + }, { + key: 'handleDrop', + value: function handleDrop(event) { + this.dragging = false; + this.forceUpdate(); + + if (typeof this.props.onDrop === 'function') { + this.props.onDrop(event); + } + } + }, { + key: 'handleSending', + value: function handleSending(file, xhr, formData) { + var _this3 = this; + + if (typeof this.props.updateFormData === 'function') { + this.props.updateFormData(formData); + } + formData.append('SecurityID', this.props.securityID); + formData.append('ParentID', this.props.folderId); + + var newXhr = Object.assign({}, xhr, { + abort: function abort() { + _this3.dropzone.cancelUpload(file); + xhr.abort(); + } + }); + if (typeof this.props.onSending === 'function') { + this.props.onSending(file, newXhr, formData); + } + } + }, { + key: 'handleMaxFilesExceeded', + value: function handleMaxFilesExceeded(file) { + if (typeof this.props.onMaxFilesExceeded === 'function') { + return this.props.onMaxFilesExceeded(file); + } + + return true; + } + }, { + key: 'generateQueuedId', + value: function generateQueuedId() { + idCounter += 1; + return idCounter; + } + }, { + key: 'handleAccept', + value: function handleAccept(file, done) { + if (typeof this.props.canFileUpload === 'function' && !this.props.canFileUpload(file)) { + return done(_i18n2.default._t('AssetAdmin.DROPZONE_CANNOT_UPLOAD', 'Uploading not permitted.')); + } + + if (!this.props.canUpload) { + return done(_i18n2.default._t('AssetAdmin.DROPZONE_CANNOT_UPLOAD', 'Uploading not permitted.')); + } + + return done(); + } + }, { + key: 'handleAddedFile', + value: function handleAddedFile(file) { + var _this4 = this; + + file._queuedId = this.generateQueuedId(); + var details = { + category: this.getFileCategory(file.type), + filename: file.name, + queuedId: file._queuedId, + size: file.size, + title: this.getFileTitle(file.name), + extension: (0, _DataFormat.getFileExtension)(file.name), + type: file.type + }; + + this.props.onAddedFile(details); + + var loadPreview = this.getLoadPreview(file); + + return loadPreview.then(function (preview) { + var previewDetails = { + height: preview.height, + width: preview.width, + url: preview.thumbnailURL, + thumbnail: preview.thumbnailURL, + smallThumbnail: preview.thumbnailURL + }; + if (typeof _this4.props.onPreviewLoaded === 'function') { + _this4.props.onPreviewLoaded(details, previewDetails); + } + + return _extends({}, details, previewDetails); + }); + } + }, { + key: 'loadImage', + value: function loadImage(img, newSource) { + var _this5 = this; + + return new Promise(function (resolve) { + var canvas = document.createElement('canvas'); + var ctx = canvas.getContext('2d'); + + img.onload = function () { + var previewWidth = _this5.props.preview.width * 2; + var previewHeight = _this5.props.preview.height * 2; + var ratio = img.naturalWidth / img.naturalHeight; + + if (img.naturalWidth < previewWidth || img.naturalHeight < previewHeight) { + canvas.width = img.naturalWidth; + canvas.height = img.naturalHeight; + } else if (ratio < 1) { + canvas.width = previewWidth; + canvas.height = previewWidth / ratio; + } else { + canvas.width = previewHeight * ratio; + canvas.height = previewHeight; + } + + ctx.drawImage(img, 0, 0, canvas.width, canvas.height); + var thumbnailURL = canvas.toDataURL('image/png'); + + resolve({ + width: img.naturalWidth, + height: img.naturalHeight, + thumbnailURL: thumbnailURL + }); + }; + + img.src = newSource; + }); + } + }, { + key: 'handleError', + value: function handleError(file, message) { + this.dropzone.removeFile(file); + + this.props.onError(file, message); + } + }, { + key: 'handleSuccess', + value: function handleSuccess(file) { + this.dropzone.removeFile(file); + + this.props.onSuccess(file); + } + }, { + key: 'render', + value: function render() { + var className = ['asset-dropzone']; + + if (this.props.className) { + className.push(this.props.className); + } + + var buttonProps = { + className: 'asset-dropzone__upload-button ss-ui-button font-icon-upload', + type: 'button' + }; + + if (!this.props.canUpload) { + buttonProps.disabled = true; + } + + if (this.dragging === true) { + className.push('dragging'); + } + + return _react2.default.createElement( + 'div', + { className: className.join(' ') }, + this.props.uploadButton && _react2.default.createElement( + 'button', + buttonProps, + _i18n2.default._t('AssetAdmin.DROPZONE_UPLOAD') + ), + this.props.children + ); + } + }]); + + return AssetDropzone; +}(_react.Component); + +AssetDropzone.propTypes = { + folderId: _react2.default.PropTypes.number.isRequired, + onAccept: _react2.default.PropTypes.func, + onAddedFile: _react2.default.PropTypes.func.isRequired, + onDragEnter: _react2.default.PropTypes.func, + onDragLeave: _react2.default.PropTypes.func, + onDrop: _react2.default.PropTypes.func, + onError: _react2.default.PropTypes.func.isRequired, + onPreviewLoaded: _react2.default.PropTypes.func, + onSending: _react2.default.PropTypes.func, + onSuccess: _react2.default.PropTypes.func.isRequired, + onMaxFilesExceeded: _react2.default.PropTypes.func, + updateFormData: _react2.default.PropTypes.func, + canFileUpload: _react2.default.PropTypes.func, + options: _react2.default.PropTypes.shape({ + url: _react2.default.PropTypes.string.isRequired + }), + promptOnRemove: _react2.default.PropTypes.string, + securityID: _react2.default.PropTypes.string.isRequired, + uploadButton: _react2.default.PropTypes.bool, + uploadSelector: _react2.default.PropTypes.string, + canUpload: _react2.default.PropTypes.bool.isRequired, + preview: _react2.default.PropTypes.shape({ + width: _react2.default.PropTypes.number, + height: _react2.default.PropTypes.number + }), + className: _react2.default.PropTypes.string +}; + +AssetDropzone.defaultProps = { + uploadButton: true +}; + +exports.default = AssetDropzone; + +/***/ }), + +/***/ "./client/src/components/BackButton/BackButton.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _droppable = __webpack_require__("./client/src/components/GalleryItem/droppable.js"); + +var _droppable2 = _interopRequireDefault(_droppable); + +var _Badge = __webpack_require__(17); + +var _Badge2 = _interopRequireDefault(_Badge); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var BackButton = function (_Component) { + _inherits(BackButton, _Component); + + function BackButton() { + _classCallCheck(this, BackButton); + + return _possibleConstructorReturn(this, (BackButton.__proto__ || Object.getPrototypeOf(BackButton)).apply(this, arguments)); + } + + _createClass(BackButton, [{ + key: 'render', + value: function render() { + var _props = this.props, + isDropping = _props.isDropping, + badge = _props.badge, + onClick = _props.onClick; + + var classList = ['btn', 'btn-secondary', 'btn--no-text', 'font-icon-level-up', 'btn--icon-large', 'gallery__back']; + + if (isDropping) { + classList.push('z-depth-1'); + classList.push('gallery__back--droppable-hover'); + } + + var backBadge = badge ? _react2.default.createElement(_Badge2.default, { + className: 'gallery__back-badge', + status: badge.status, + message: badge.message + }) : null; + + var button = _react2.default.createElement( + 'button', + { + className: classList.join(' '), + title: _i18n2.default._t('AssetAdmin.BACK_DESCRIPTION', 'Navigate up a level'), + onClick: onClick + }, + backBadge + ); + + return button; + } + }]); + + return BackButton; +}(_react.Component); + +BackButton.propTypes = { + onClick: _react.PropTypes.func, + isDropping: _react.PropTypes.bool, + badge: _react.PropTypes.shape(_Badge2.default.propTypes) +}; + +exports.Component = BackButton; +exports.default = (0, _droppable2.default)('GalleryItem')(BackButton); + +/***/ }), + +/***/ "./client/src/components/BulkActions/BulkActions.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactRedux = __webpack_require__(3); + +var _Injector = __webpack_require__(2); + +var _reactstrap = __webpack_require__(22); + +var _classnames = __webpack_require__(9); + +var _classnames2 = _interopRequireDefault(_classnames); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var BulkActions = function (_Component) { + _inherits(BulkActions, _Component); + + function BulkActions(props) { + _classCallCheck(this, BulkActions); + + var _this = _possibleConstructorReturn(this, (BulkActions.__proto__ || Object.getPrototypeOf(BulkActions)).call(this, props)); + + _this.handleChangeValue = _this.handleChangeValue.bind(_this); + _this.renderChild = _this.renderChild.bind(_this); + return _this; + } + + _createClass(BulkActions, [{ + key: 'getOptionByValue', + value: function getOptionByValue(value) { + return this.props.actions.find(function (action) { + return action.value === value; + }); + } + }, { + key: 'handleChangeValue', + value: function handleChangeValue(event) { + var _this2 = this; + + var promise = null; + + var option = this.getOptionByValue(event.target.value); + if (option === null) { + return null; + } + + if (typeof option.confirm === 'function') { + promise = option.confirm(this.props.items).then(function () { + return option.callback(event, _this2.props.items); + }).catch(function (reason) { + if (reason !== 'cancelled') { + throw reason; + } + }); + } else { + promise = option.callback(event, this.props.items) || Promise.resolve(); + } + + return promise; + } + }, { + key: 'renderChild', + value: function renderChild(action, i) { + var className = (0, _classnames2.default)('bulk-actions__action', action.className || 'font-icon-info-circled', { + btn: i < 2, + 'bulk-actions__action--more': i > 2 + }); + if (i < 2) { + return _react2.default.createElement( + _reactstrap.Button, + { + className: className, + key: action.value, + onClick: this.handleChangeValue, + value: action.value + }, + action.label + ); + } + return _react2.default.createElement( + _reactstrap.DropdownItem, + { + type: 'button', + className: className, + key: action.value, + onClick: this.handleChangeValue, + value: action.value + }, + action.label + ); + } + }, { + key: 'render', + value: function render() { + var _this3 = this; + + if (!this.props.items.length) { + return null; + } + + var children = this.props.actions.filter(function (action) { + return !action.canApply || action.canApply(_this3.props.items); + }); + + children = children.map(this.renderChild); + + if (!children.length) { + return null; + } + + var _props = this.props, + ActionMenu = _props.ActionMenu, + showCount = _props.showCount; + + + var count = this.props.items.length; + + return _react2.default.createElement( + 'div', + { className: 'bulk-actions fieldholder-small' }, + showCount && _react2.default.createElement( + 'div', + { className: 'bulk-actions-counter' }, + count + ), + children.slice(0, 2), + children.length > 2 && ActionMenu ? _react2.default.createElement( + ActionMenu, + { + id: 'BulkActions', + className: 'bulk-actions__more-actions-menu' + }, + children.slice(2) + ) : children.slice(2) + ); + } + }]); + + return BulkActions; +}(_react.Component); + +BulkActions.propTypes = { + items: _react.PropTypes.array, + actions: _react.PropTypes.arrayOf(_react.PropTypes.shape({ + value: _react.PropTypes.string.isRequired, + label: _react.PropTypes.string.isRequired, + className: _react.PropTypes.string, + destructive: _react.PropTypes.bool, + callback: _react.PropTypes.func, + canApply: _react.PropTypes.func, + confirm: _react.PropTypes.func + })), + ActionMenu: _react.PropTypes.oneOfType([_react.PropTypes.node, _react.PropTypes.func]), + showCount: _react.PropTypes.bool +}; + +BulkActions.defaultProps = { + items: [], + actions: [], + ActionMenu: null, + total: null, + showCount: true, + totalReachedMessage: _i18n2.default._t('') +}; + +function mapStateToProps(state) { + return { + gallery: state.assetAdmin.gallery + }; +} + +var BulkActionsWithState = (0, _reactRedux.connect)(mapStateToProps)(BulkActions); + +exports.Component = BulkActions; +exports.default = (0, _Injector.inject)(['ActionMenu'], function (ActionMenu) { + return { ActionMenu: ActionMenu }; +}, function () { + return 'BulkActions'; +})(BulkActionsWithState); + +/***/ }), + +/***/ "./client/src/components/GalleryItem/GalleryItem.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.File = exports.Folder = exports.Component = undefined; + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _classnames2 = __webpack_require__(9); + +var _classnames3 = _interopRequireDefault(_classnames2); + +var _index = __webpack_require__("./client/src/constants/index.js"); + +var _index2 = _interopRequireDefault(_index); + +var _fileShape = __webpack_require__("./client/src/lib/fileShape.js"); + +var _fileShape2 = _interopRequireDefault(_fileShape); + +var _draggable = __webpack_require__("./client/src/components/GalleryItem/draggable.js"); + +var _draggable2 = _interopRequireDefault(_draggable); + +var _droppable = __webpack_require__("./client/src/components/GalleryItem/droppable.js"); + +var _droppable2 = _interopRequireDefault(_droppable); + +var _Badge = __webpack_require__(17); + +var _Badge2 = _interopRequireDefault(_Badge); + +var _configShape = __webpack_require__("./client/src/lib/configShape.js"); + +var _configShape2 = _interopRequireDefault(_configShape); + +var _reactRedux = __webpack_require__(3); + +var _redux = __webpack_require__(4); + +var _reactSelectable = __webpack_require__("../../../node_modules/react-selectable/dist/react-selectable.js"); + +var _ImageLoadActions = __webpack_require__("./client/src/state/imageLoad/ImageLoadActions.js"); + +var imageLoadActions = _interopRequireWildcard(_ImageLoadActions); + +var _ImageLoadStatus = __webpack_require__("./client/src/state/imageLoad/ImageLoadStatus.js"); + +var _ImageLoadStatus2 = _interopRequireDefault(_ImageLoadStatus); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +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 _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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +function shouldLoadImage(props) { + return props.item.thumbnail && props.item.category === 'image' && props.item.exists && !props.item.queuedId && props.sectionConfig.imageRetry.minRetry && props.sectionConfig.imageRetry.maxRetry; +} + +var preventFocus = function preventFocus(event) { + event.preventDefault(); +}; + +var GalleryItem = function (_Component) { + _inherits(GalleryItem, _Component); + + function GalleryItem(props) { + _classCallCheck(this, GalleryItem); + + var _this = _possibleConstructorReturn(this, (GalleryItem.__proto__ || Object.getPrototypeOf(GalleryItem)).call(this, props)); + + _this.handleSelect = _this.handleSelect.bind(_this); + _this.handleActivate = _this.handleActivate.bind(_this); + _this.handleKeyDown = _this.handleKeyDown.bind(_this); + _this.handleCancelUpload = _this.handleCancelUpload.bind(_this); + return _this; + } + + _createClass(GalleryItem, [{ + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(nextProps) { + if (shouldLoadImage(nextProps)) { + nextProps.actions.imageLoad.loadImage(nextProps.item.thumbnail, nextProps.sectionConfig.imageRetry); + } + } + }, { + key: 'getThumbnailStyles', + value: function getThumbnailStyles() { + var thumbnail = this.props.item.thumbnail; + if (!this.isImage() || !thumbnail || this.missing()) { + return {}; + } + + switch (this.props.loadState) { + case _ImageLoadStatus2.default.SUCCESS: + case _ImageLoadStatus2.default.DISABLED: + return { + backgroundImage: 'url(' + thumbnail + ')' + }; + default: + return {}; + } + } + }, { + key: 'getErrorMessage', + value: function getErrorMessage() { + var message = null; + var _props = this.props, + updateErrorMessage = _props.updateErrorMessage, + item = _props.item, + loadState = _props.loadState; + + + if (this.hasError()) { + message = item.message.value; + } else if (this.missing()) { + message = _i18n2.default._t('AssetAdmin.FILE_MISSING', 'File cannot be found'); + } else if (loadState === _ImageLoadStatus2.default.FAILED) { + message = _i18n2.default._t('AssetAdmin.FILE_LOAD_ERROR', 'Thumbnail not available'); + } + + if (message !== null) { + message = updateErrorMessage(message, this.props); + return _react2.default.createElement( + 'span', + { className: 'gallery-item__error-message' }, + message + ); + } + + return null; + } + }, { + key: 'getThumbnailClassNames', + value: function getThumbnailClassNames() { + var thumbnailClassNames = ['gallery-item__thumbnail']; + + if (this.isImageSmallerThanThumbnail()) { + thumbnailClassNames.push('gallery-item__thumbnail--small'); + } + + if (!this.props.item.thumbnail && this.isImage()) { + thumbnailClassNames.push('gallery-item__thumbnail--no-preview'); + } + + switch (this.props.loadState) { + case _ImageLoadStatus2.default.LOADING: + case _ImageLoadStatus2.default.WAITING: + thumbnailClassNames.push('gallery-item__thumbnail--loading'); + break; + + case _ImageLoadStatus2.default.FAILED: + thumbnailClassNames.push('gallery-item__thumbnail--error'); + break; + default: + break; + } + + return thumbnailClassNames.join(' '); + } + }, { + key: 'getItemClassNames', + value: function getItemClassNames() { + var _classnames; + + var category = this.props.item.category || 'false'; + var selected = this.props.selectable && (this.props.item.selected || this.props.isDragging); + + return (0, _classnames3.default)((_classnames = { + 'gallery-item': true + }, _defineProperty(_classnames, 'gallery-item--' + category, true), _defineProperty(_classnames, 'gallery-item--max-selected', this.props.maxSelected && !selected), _defineProperty(_classnames, 'gallery-item--missing', this.missing()), _defineProperty(_classnames, 'gallery-item--selectable', this.props.selectable), _defineProperty(_classnames, 'gallery-item--selected', selected), _defineProperty(_classnames, 'gallery-item--dropping', this.props.isDropping), _defineProperty(_classnames, 'gallery-item--highlighted', this.props.item.highlighted), _defineProperty(_classnames, 'gallery-item--error', this.hasError()), _defineProperty(_classnames, 'gallery-item--dragging', this.props.isDragging), _classnames)); + } + }, { + key: 'getStatusFlags', + value: function getStatusFlags() { + var flags = []; + var _props2 = this.props, + item = _props2.item, + updateStatusFlags = _props2.updateStatusFlags; + + if (item.type !== 'folder') { + if (item.draft) { + flags.push({ + node: 'span', + key: 'status-draft', + title: _i18n2.default._t('File.DRAFT', 'Draft'), + className: 'gallery-item--draft' + }); + } else if (item.modified) { + flags.push({ + node: 'span', + key: 'status-modified', + title: _i18n2.default._t('File.MODIFIED', 'Modified'), + className: 'gallery-item--modified' + }); + } + } + flags = updateStatusFlags(flags, this.props); + return flags.map(function (_ref) { + var Tag = _ref.node, + attributes = _objectWithoutProperties(_ref, ['node']); + + return _react2.default.createElement(Tag, attributes); + }); + } + }, { + key: 'getProgressBar', + value: function getProgressBar() { + var progressBar = null; + var _props3 = this.props, + updateProgressBar = _props3.updateProgressBar, + item = _props3.item; + + var progressBarProps = { + className: 'gallery-item__progress-bar', + style: { + width: item.progress + '%' + } + }; + + if (!this.hasError() && this.uploading() && !this.complete()) { + progressBar = _react2.default.createElement( + 'div', + { className: 'gallery-item__upload-progress' }, + _react2.default.createElement('div', progressBarProps) + ); + } + progressBar = updateProgressBar(progressBar, this.props); + return progressBar; + } + }, { + key: 'isImageSmallerThanThumbnail', + value: function isImageSmallerThanThumbnail() { + if (!this.isImage() || this.missing()) { + return false; + } + var width = this.props.item.width; + var height = this.props.item.height; + + return height && width && height < _index2.default.THUMBNAIL_HEIGHT && width < _index2.default.THUMBNAIL_WIDTH; + } + }, { + key: 'complete', + value: function complete() { + return this.props.item.queuedId && this.saved(); + } + }, { + key: 'saved', + value: function saved() { + return this.props.item.id > 0; + } + }, { + key: 'missing', + value: function missing() { + return !this.exists() && this.saved(); + } + }, { + key: 'uploading', + value: function uploading() { + return this.props.item.queuedId && !this.saved(); + } + }, { + key: 'exists', + value: function exists() { + return this.props.item.exists; + } + }, { + key: 'isImage', + value: function isImage() { + return this.props.item.category === 'image'; + } + }, { + key: 'canBatchSelect', + value: function canBatchSelect() { + return this.props.selectable && this.props.item.canEdit; + } + }, { + key: 'hasError', + value: function hasError() { + var hasError = false; + + if (this.props.item.message) { + hasError = this.props.item.message.type === 'error'; + } + + return hasError; + } + }, { + key: 'handleActivate', + value: function handleActivate(event) { + event.stopPropagation(); + if (typeof this.props.onActivate === 'function' && this.saved()) { + this.props.onActivate(event, this.props.item); + } + } + }, { + key: 'handleSelect', + value: function handleSelect(event) { + event.stopPropagation(); + event.preventDefault(); + if (typeof this.props.onSelect === 'function') { + this.props.onSelect(event, this.props.item); + } + } + }, { + key: 'handleKeyDown', + value: function handleKeyDown(event) { + if (_index2.default.SPACE_KEY_CODE === event.keyCode) { + event.preventDefault(); + if (this.canBatchSelect()) { + this.handleSelect(event); + } + } + + if (_index2.default.RETURN_KEY_CODE === event.keyCode) { + this.handleActivate(event); + } + } + }, { + key: 'handleCancelUpload', + value: function handleCancelUpload(event) { + event.stopPropagation(); + event.preventDefault(); + if (this.hasError()) { + this.props.onRemoveErroredUpload(this.props.item); + } else if (this.props.onCancelUpload) { + this.props.onCancelUpload(this.props.item); + } + } + }, { + key: 'render', + value: function render() { + var _this2 = this; + + var action = null; + var actionIcon = null; + var overlay = null; + var _props$item = this.props.item, + id = _props$item.id, + queuedId = _props$item.queuedId; + + var htmlID = id ? 'item-' + id : 'queued-' + queuedId; + if (this.props.selectable) { + if (this.canBatchSelect()) { + action = this.handleSelect; + } + actionIcon = 'font-icon-tick'; + } + + if (this.uploading()) { + action = this.handleCancelUpload; + actionIcon = 'font-icon-cancel'; + } else if (this.exists()) { + var label = _i18n2.default._t('AssetAdmin.DETAILS', 'Details'); + overlay = _react2.default.createElement( + 'div', + { className: 'gallery-item--overlay font-icon-edit' }, + label + ); + } + + var badge = this.props.badge; + + var inputProps = { + className: 'gallery-item__checkbox', + type: 'checkbox', + title: _i18n2.default._t('AssetAdmin.SELECT', 'Select'), + tabIndex: -1, + onMouseDown: preventFocus, + id: htmlID + }; + var inputLabelClasses = ['gallery-item__checkbox-label', actionIcon]; + if (!this.canBatchSelect()) { + inputProps.disabled = true; + inputLabelClasses.push('gallery-item__checkbox-label--disabled'); + } + var inputLabelProps = { + className: inputLabelClasses.join(' '), + onClick: action + }; + + return _react2.default.createElement( + 'div', + { + className: this.getItemClassNames(), + 'data-id': this.props.item.id, + tabIndex: 0, + role: 'button', + onKeyDown: this.handleKeyDown, + onClick: this.handleActivate + }, + !!badge && _react2.default.createElement(_Badge2.default, { + className: 'gallery-item__badge', + status: badge.status, + message: badge.message + }), + _react2.default.createElement( + 'div', + { + ref: function ref(thumbnail) { + _this2.thumbnail = thumbnail; + }, + className: this.getThumbnailClassNames(), + style: this.getThumbnailStyles() + }, + overlay, + this.getStatusFlags() + ), + this.getProgressBar(), + this.getErrorMessage(), + this.props.children, + _react2.default.createElement( + 'div', + { className: 'gallery-item__title', ref: function ref(title) { + _this2.title = title; + } }, + _react2.default.createElement( + 'label', + _extends({}, inputLabelProps, { htmlFor: htmlID }), + _react2.default.createElement('input', inputProps) + ), + this.props.item.title + ) + ); + } + }]); + + return GalleryItem; +}(_react.Component); + +GalleryItem.propTypes = { + sectionConfig: _configShape2.default, + item: _fileShape2.default, + loadState: _react.PropTypes.oneOf(Object.values(_ImageLoadStatus2.default)), + + highlighted: _react.PropTypes.bool, + + selected: _react.PropTypes.bool, + + isDropping: _react.PropTypes.bool, + isDragging: _react.PropTypes.bool, + message: _react.PropTypes.shape({ + value: _react.PropTypes.string, + type: _react.PropTypes.string + }), + selectable: _react.PropTypes.bool, + onActivate: _react.PropTypes.func, + onSelect: _react.PropTypes.func, + onCancelUpload: _react.PropTypes.func, + onRemoveErroredUpload: _react.PropTypes.func, + badge: _react.PropTypes.shape({ + status: _react.PropTypes.string, + message: _react.PropTypes.string + }), + updateStatusFlags: _react.PropTypes.func, + updateProgressBar: _react.PropTypes.func, + updateErrorMessage: _react.PropTypes.func +}; + +GalleryItem.defaultProps = { + item: {}, + sectionConfig: { + imageRetry: {} + }, + updateStatusFlags: function updateStatusFlags(flags) { + return flags; + }, + updateProgressBar: function updateProgressBar(progressBar) { + return progressBar; + }, + updateErrorMessage: function updateErrorMessage(message) { + return message; + } +}; + +function mapStateToProps(state, ownprops) { + if (shouldLoadImage(ownprops)) { + var imageLoad = state.assetAdmin.imageLoad; + var file = imageLoad.files.find(function (next) { + return ownprops.item.thumbnail === next.url; + }); + + var loadState = file && file.status || _ImageLoadStatus2.default.NONE; + return { loadState: loadState }; + } + + return { loadState: _ImageLoadStatus2.default.DISABLED }; +} + +function mapDispatchToProps(dispatch) { + return { + actions: { + imageLoad: (0, _redux.bindActionCreators)(imageLoadActions, dispatch) + } + }; +} + +var ConnectedGalleryItem = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps)(GalleryItem); +var type = 'GalleryItem'; + +var File = (0, _reactSelectable.createSelectable)((0, _draggable2.default)(type)(ConnectedGalleryItem)); +var Folder = (0, _reactSelectable.createSelectable)((0, _droppable2.default)(type)(File)); +exports.Component = GalleryItem; +exports.Folder = Folder; +exports.File = File; +exports.default = ConnectedGalleryItem; + +/***/ }), + +/***/ "./client/src/components/GalleryItem/GalleryItemDragLayer.js": +/***/ (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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactDnd = __webpack_require__(15); + +var _GalleryItem = __webpack_require__("./client/src/components/GalleryItem/GalleryItem.js"); + +var _GalleryItem2 = _interopRequireDefault(_GalleryItem); + +var _Badge = __webpack_require__(17); + +var _Badge2 = _interopRequireDefault(_Badge); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var GalleryItemDragLayer = function (_Component) { + _inherits(GalleryItemDragLayer, _Component); + + function GalleryItemDragLayer() { + _classCallCheck(this, GalleryItemDragLayer); + + return _possibleConstructorReturn(this, (GalleryItemDragLayer.__proto__ || Object.getPrototypeOf(GalleryItemDragLayer)).apply(this, arguments)); + } + + _createClass(GalleryItemDragLayer, [{ + key: 'getOffset', + value: function getOffset() { + var _props = this.props, + offset = _props.offset, + dragged = _props.dragged; + + return { + transform: offset && 'translate(' + (offset.x + dragged.x) + 'px, ' + (offset.y + dragged.y) + 'px)' + }; + } + }, { + key: 'render', + value: function render() { + if (!this.props.isDragging) { + return null; + } + var item = this.props.item; + + if (!item.selected) { + return null; + } + var selectionCount = item.selected.length; + var shadows = [selectionCount > 1 ? _react2.default.createElement('div', { key: '1', className: 'gallery-item__drag-shadow' }) : null, selectionCount > 2 ? _react2.default.createElement('div', { key: '2', className: 'gallery-item__drag-shadow gallery-item__drag-shadow--second' }) : null]; + + return _react2.default.createElement( + 'div', + { className: 'gallery-item__drag-layer' }, + _react2.default.createElement( + 'div', + { className: 'gallery-item__drag-layer-item', style: this.getOffset() }, + _react2.default.createElement( + 'div', + { className: 'gallery-item__drag-layer-preview' }, + shadows, + _react2.default.createElement(_GalleryItem2.default, _extends({}, item.props, { isDragging: true })) + ), + selectionCount > 1 ? _react2.default.createElement(_Badge2.default, { + className: 'gallery-item__drag-layer-count', + status: 'info', + message: '' + selectionCount + }) : null + ) + ); + } + }]); + + return GalleryItemDragLayer; +}(_react.Component); + +GalleryItemDragLayer.propTypes = { + item: _react.PropTypes.object, + offset: _react.PropTypes.shape({ + x: _react.PropTypes.number.isRequired, + y: _react.PropTypes.number.isRequired + }), + isDragging: _react.PropTypes.bool.isRequired +}; + +var collect = function collect(monitor) { + return { + item: monitor.getItem(), + offset: monitor.getInitialClientOffset(), + dragged: monitor.getDifferenceFromInitialOffset(), + isDragging: monitor.isDragging() + }; +}; + +exports.default = (0, _reactDnd.DragLayer)(collect)(GalleryItemDragLayer); + +/***/ }), + +/***/ "./client/src/components/GalleryItem/draggable.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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; }; }(); + +exports.default = draggable; + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactDnd = __webpack_require__(15); + +var _reactDndHtml5Backend = __webpack_require__(21); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +function draggable(type) { + var spec = { + canDrag: function canDrag(props) { + return props.canDrag; + }, + beginDrag: function beginDrag(props) { + var id = props.item.id; + + if (typeof props.onDrag === 'function') { + props.onDrag(true, id); + } + var selected = props.selectedFiles.concat([]); + if (!selected.includes(id)) { + selected.push(id); + } + + return { selected: selected, props: props }; + }, + endDrag: function endDrag(props) { + var id = props.item.id; + + if (typeof props.onDrag === 'function') { + props.onDrag(false, id); + } + } + }; + + var collect = function collect(connect, monitor) { + return { + connectDragPreview: connect.dragPreview(), + connectDragSource: connect.dragSource(), + isDragging: monitor.isDragging() + }; + }; + + var dragItem = (0, _reactDnd.DragSource)(type, spec, collect); + + return function (Item) { + var DraggableItem = function (_Component) { + _inherits(DraggableItem, _Component); + + function DraggableItem() { + _classCallCheck(this, DraggableItem); + + return _possibleConstructorReturn(this, (DraggableItem.__proto__ || Object.getPrototypeOf(DraggableItem)).apply(this, arguments)); + } + + _createClass(DraggableItem, [{ + key: 'componentDidMount', + value: function componentDidMount() { + this.props.connectDragPreview((0, _reactDndHtml5Backend.getEmptyImage)(), { + captureDraggingState: true + }); + } + }, { + key: 'render', + value: function render() { + var connectDragSource = this.props.connectDragSource; + + var item = _react2.default.createElement(Item, this.props); + + if (typeof item.type === 'string') { + return connectDragSource(item); + } + return connectDragSource(_react2.default.createElement( + 'div', + { className: 'gallery-item__draggable' }, + item + )); + } + }]); + + return DraggableItem; + }(_react.Component); + + DraggableItem.propTypes = { + connectDragSource: _react.PropTypes.func.isRequired, + connectDragPreview: _react.PropTypes.func.isRequired, + item: _react.PropTypes.shape({ + id: _react.PropTypes.number.isRequired + }).isRequired, + onDrag: _react.PropTypes.func, + selectedFiles: _react.PropTypes.arrayOf(_react.PropTypes.number) + }; + + return dragItem(DraggableItem); + }; +} + +/***/ }), + +/***/ "./client/src/components/GalleryItem/droppable.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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; }; }(); + +exports.default = droppable; + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactDnd = __webpack_require__(15); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +function droppable(types) { + var spec = { + drop: function drop(props, monitor) { + if (monitor.canDrop()) { + var item = monitor.getItem(); + props.onDropFiles(props.item.id, item.selected); + } + }, + canDrop: function canDrop(props, monitor) { + var item = monitor.getItem(); + + return !item.selected.includes(props.item.id); + } + }; + + var collect = function collect(connect, monitor) { + var over = monitor.isOver(); + return { + isDropping: over && monitor.canDrop(), + connectDropTarget: connect.dropTarget(), + isOver: over + }; + }; + + var dropItem = (0, _reactDnd.DropTarget)(types, spec, collect); + + return function (Item) { + var DroppableItem = function (_Component) { + _inherits(DroppableItem, _Component); + + function DroppableItem() { + _classCallCheck(this, DroppableItem); + + return _possibleConstructorReturn(this, (DroppableItem.__proto__ || Object.getPrototypeOf(DroppableItem)).apply(this, arguments)); + } + + _createClass(DroppableItem, [{ + key: 'render', + value: function render() { + var connectDropTarget = this.props.connectDropTarget; + + var item = _react2.default.createElement(Item, this.props); + + if (typeof item.type === 'string') { + return connectDropTarget(item); + } + return connectDropTarget(_react2.default.createElement( + 'div', + { className: 'gallery-item__droppable' }, + item + )); + } + }]); + + return DroppableItem; + }(_react.Component); + + DroppableItem.propTypes = { + connectDropTarget: _react.PropTypes.func.isRequired, + item: _react.PropTypes.shape({ + id: _react.PropTypes.number.isRequired + }).isRequired + }; + + return dropItem(DroppableItem); + }; +} + +/***/ }), + +/***/ "./client/src/components/GalleryToolbar/Buttons/AddFolderButton.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var AddFolderButton = function (_Component) { + _inherits(AddFolderButton, _Component); + + function AddFolderButton() { + _classCallCheck(this, AddFolderButton); + + var _this = _possibleConstructorReturn(this, (AddFolderButton.__proto__ || Object.getPrototypeOf(AddFolderButton)).call(this)); + + _this.handleCreateFolder = _this.handleCreateFolder.bind(_this); + return _this; + } + + _createClass(AddFolderButton, [{ + key: 'handleCreateFolder', + value: function handleCreateFolder(event) { + var onCreateFolder = this.props.onCreateFolder; + + event.preventDefault(); + if (typeof onCreateFolder === 'function') { + onCreateFolder(); + } + } + }, { + key: 'render', + value: function render() { + var canEdit = this.props.canEdit; + + return _react2.default.createElement( + 'button', + { + id: 'add-folder-button', + className: 'btn btn-secondary font-icon-folder-add btn--icon-xl', + type: 'button', + onClick: this.handleCreateFolder, + disabled: !canEdit + }, + _react2.default.createElement( + 'span', + { className: 'btn__text btn__title' }, + _i18n2.default._t('AssetAdmin.ADD_FOLDER_BUTTON') + ) + ); + } + }]); + + return AddFolderButton; +}(_react.Component); + +AddFolderButton.propTypes = { + canEdit: _react.PropTypes.bool.isRequired, + onCreateFolder: _react.PropTypes.func.isRequired +}; + +exports.default = AddFolderButton; + +/***/ }), + +/***/ "./client/src/components/GalleryToolbar/Buttons/BackButton.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _BackButton = __webpack_require__("./client/src/components/BackButton/BackButton.js"); + +var _BackButton2 = _interopRequireDefault(_BackButton); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var BackButton = function (_Component) { + _inherits(BackButton, _Component); + + function BackButton(props) { + _classCallCheck(this, BackButton); + + var _this = _possibleConstructorReturn(this, (BackButton.__proto__ || Object.getPrototypeOf(BackButton)).call(this, props)); + + _this.handleBackClick = _this.handleBackClick.bind(_this); + return _this; + } + + _createClass(BackButton, [{ + key: 'handleBackClick', + value: function handleBackClick(event) { + var _props = this.props, + onOpenFolder = _props.onOpenFolder, + folder = _props.folder; + + + event.preventDefault(); + if (typeof onOpenFolder === 'function') { + onOpenFolder(folder.parentId); + } + } + }, { + key: 'render', + value: function render() { + var _props2 = this.props, + folder = _props2.folder, + badges = _props2.badges, + onMoveFiles = _props2.onMoveFiles; + var itemId = folder.parentId; + + if (itemId === null) { + return null; + } + var badge = badges.find(function (item) { + return item.id === itemId; + }); + return _react2.default.createElement( + 'div', + { className: 'gallery__back-container' }, + _react2.default.createElement(_BackButton2.default, { + item: { id: itemId }, + onClick: this.handleBackClick, + onDropFiles: onMoveFiles, + badge: badge + }) + ); + } + }]); + + return BackButton; +}(_react.Component); + +BackButton.propTypes = { + folder: _react.PropTypes.shape({ + id: _react.PropTypes.number, + title: _react.PropTypes.string, + parentId: _react.PropTypes.number, + canView: _react.PropTypes.bool, + canEdit: _react.PropTypes.bool + }).isRequired, + badges: _react.PropTypes.arrayOf(_react.PropTypes.shape({ + id: _react.PropTypes.number, + message: _react.PropTypes.node, + status: _react.PropTypes.string + })).isRequired, + onOpenFolder: _react.PropTypes.func.isRequired, + onMoveFiles: _react.PropTypes.func.isRequired +}; + +exports.default = BackButton; + +/***/ }), + +/***/ "./client/src/components/GalleryToolbar/Buttons/UploadButton.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var UploadButton = function (_Component) { + _inherits(UploadButton, _Component); + + function UploadButton() { + _classCallCheck(this, UploadButton); + + return _possibleConstructorReturn(this, (UploadButton.__proto__ || Object.getPrototypeOf(UploadButton)).apply(this, arguments)); + } + + _createClass(UploadButton, [{ + key: 'render', + value: function render() { + var canEdit = this.props.canEdit; + + return _react2.default.createElement( + 'button', + { + id: 'upload-button', + className: 'btn btn-secondary font-icon-upload btn--icon-xl', + type: 'button', + disabled: !canEdit + }, + _react2.default.createElement( + 'span', + { className: 'btn__text btn__title' }, + _i18n2.default._t('AssetAdmin.DROPZONE_UPLOAD') + ) + ); + } + }]); + + return UploadButton; +}(_react.Component); + +UploadButton.defaultProps = { + canEdit: _react.PropTypes.func.isRequired +}; + +exports.default = UploadButton; + +/***/ }), + +/***/ "./client/src/components/GalleryToolbar/GalleryToolbar.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactRedux = __webpack_require__(3); + +var _BackButton = __webpack_require__("./client/src/components/GalleryToolbar/Buttons/BackButton.js"); + +var _BackButton2 = _interopRequireDefault(_BackButton); + +var _UploadButton = __webpack_require__("./client/src/components/GalleryToolbar/Buttons/UploadButton.js"); + +var _UploadButton2 = _interopRequireDefault(_UploadButton); + +var _AddFolderButton = __webpack_require__("./client/src/components/GalleryToolbar/Buttons/AddFolderButton.js"); + +var _AddFolderButton2 = _interopRequireDefault(_AddFolderButton); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var GalleryToolbar = function (_Component) { + _inherits(GalleryToolbar, _Component); + + function GalleryToolbar(props) { + _classCallCheck(this, GalleryToolbar); + + var _this = _possibleConstructorReturn(this, (GalleryToolbar.__proto__ || Object.getPrototypeOf(GalleryToolbar)).call(this, props)); + + _this.handleSelectSort = _this.handleSelectSort.bind(_this); + _this.handleViewChange = _this.handleViewChange.bind(_this); + return _this; + } + + _createClass(GalleryToolbar, [{ + key: 'handleSelectSort', + value: function handleSelectSort(event) { + this.props.onSort(event.currentTarget.value); + } + }, { + key: 'handleViewChange', + value: function handleViewChange(event) { + var view = event.currentTarget.value; + + this.props.onViewChange(view); + } + }, { + key: 'renderSort', + value: function renderSort() { + var _this2 = this; + + if (this.props.view !== 'tile') { + return null; + } + return _react2.default.createElement( + 'div', + { className: 'gallery__sort fieldholder-small' }, + _react2.default.createElement( + 'select', + { + className: 'dropdown no-change-track no-chzn', + tabIndex: '0', + style: { width: '160px' }, + defaultValue: this.props.sort + }, + this.props.sorters.map(function (sorter) { + return _react2.default.createElement( + 'option', + { + key: sorter.field + '-' + sorter.direction, + onClick: _this2.handleSelectSort, + 'data-field': sorter.field, + 'data-direction': sorter.direction, + value: sorter.field + ',' + sorter.direction + }, + sorter.label + ); + }) + ) + ); + } + }, { + key: 'renderViewChangeButtons', + value: function renderViewChangeButtons() { + var _this3 = this; + + var views = ['tile', 'table']; + return views.map(function (view) { + var icon = view === 'table' ? 'list' : 'thumbnails'; + var classNames = ['gallery__view-change-button', 'btn btn-secondary', 'btn--icon-sm', 'btn--no-text']; + + if (view === _this3.props.view) { + return null; + } + classNames.push('font-icon-' + icon); + return _react2.default.createElement('button', { + id: 'button-view-' + view, + key: view, + className: classNames.join(' '), + type: 'button', + title: 'Change view gallery/list', + onClick: _this3.handleViewChange, + value: view + }); + }); + } + }, { + key: 'render', + value: function render() { + var _props = this.props, + badges = _props.badges, + children = _props.children, + folder = _props.folder, + onMoveFiles = _props.onMoveFiles, + onOpenFolder = _props.onOpenFolder, + onCreateFolder = _props.onCreateFolder, + BackButton = _props.BackButton, + UploadButton = _props.UploadButton, + AddFolderButton = _props.AddFolderButton; + var canEdit = folder.canEdit; + + + return _react2.default.createElement( + 'div', + { className: 'toolbar--content toolbar--space-save' }, + _react2.default.createElement( + 'div', + { className: 'fill-width' }, + _react2.default.createElement( + 'div', + { className: 'flexbox-area-grow' }, + _react2.default.createElement( + 'div', + { className: 'btn-toolbar' }, + _react2.default.createElement(BackButton, { + folder: folder, + badges: badges, + onOpenFolder: onOpenFolder, + onMoveFiles: onMoveFiles + }), + _react2.default.createElement(UploadButton, { + canEdit: canEdit + }), + _react2.default.createElement(AddFolderButton, { + canEdit: canEdit, + onCreateFolder: onCreateFolder + }), + children + ) + ), + _react2.default.createElement( + 'div', + { className: 'gallery__state-buttons' }, + this.renderSort(), + _react2.default.createElement( + 'div', + { className: 'btn-group', role: 'group', 'aria-label': 'View mode' }, + this.renderViewChangeButtons() + ) + ) + ) + ); + } + }]); + + return GalleryToolbar; +}(_react.Component); + +GalleryToolbar.propTypes = { + onMoveFiles: _react.PropTypes.func.isRequired, + onCreateFolder: _react.PropTypes.func.isRequired, + onViewChange: _react.PropTypes.func.isRequired, + onOpenFolder: _react.PropTypes.func.isRequired, + onSort: _react.PropTypes.func.isRequired, + folder: _react.PropTypes.shape({ + id: _react.PropTypes.number, + title: _react.PropTypes.string, + parentId: _react.PropTypes.number, + canView: _react.PropTypes.bool, + canEdit: _react.PropTypes.bool + }).isRequired, + view: _react.PropTypes.oneOf(['tile', 'table']), + sort: _react.PropTypes.string, + badges: _react.PropTypes.arrayOf(_react.PropTypes.shape({ + id: _react.PropTypes.number, + message: _react.PropTypes.node, + status: _react.PropTypes.string + })), + BackButton: _react.PropTypes.func, + UploadButton: _react.PropTypes.func, + AddFolderButton: _react.PropTypes.func +}; + +GalleryToolbar.defaultProps = { + view: 'tile', + BackButton: _BackButton2.default, + UploadButton: _UploadButton2.default, + AddFolderButton: _AddFolderButton2.default +}; + +function mapStateToProps(state, ownProps) { + var sort = ownProps.sort; + var _state$assetAdmin$gal = state.assetAdmin.gallery, + badges = _state$assetAdmin$gal.badges, + sorters = _state$assetAdmin$gal.sorters; + + if (sort === '') { + sort = sorters[0].field + ',' + sorters[0].direction; + } + return { badges: badges, sorters: sorters, sort: sort }; +} + +exports.Component = GalleryToolbar; +exports.default = (0, _reactRedux.connect)(mapStateToProps)(GalleryToolbar); + +/***/ }), + +/***/ "./client/src/components/PreviewImageField/PreviewImageField.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _AssetDropzone = __webpack_require__("./client/src/components/AssetDropzone/AssetDropzone.js"); + +var _AssetDropzone2 = _interopRequireDefault(_AssetDropzone); + +var _index = __webpack_require__("./client/src/constants/index.js"); + +var _index2 = _interopRequireDefault(_index); + +var _reactRedux = __webpack_require__(3); + +var _redux = __webpack_require__(4); + +var _reduxForm = __webpack_require__(23); + +var _PreviewFieldActions = __webpack_require__("./client/src/state/previewField/PreviewFieldActions.js"); + +var previewFieldActions = _interopRequireWildcard(_PreviewFieldActions); + +var _DataFormat = __webpack_require__(12); + +var _getFormState = __webpack_require__(24); + +var _getFormState2 = _interopRequireDefault(_getFormState); + +var _classnames = __webpack_require__(9); + +var _classnames2 = _interopRequireDefault(_classnames); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var PreviewImageField = function (_Component) { + _inherits(PreviewImageField, _Component); + + function PreviewImageField(props) { + _classCallCheck(this, PreviewImageField); + + var _this = _possibleConstructorReturn(this, (PreviewImageField.__proto__ || Object.getPrototypeOf(PreviewImageField)).call(this, props)); + + _this.handleAddedFile = _this.handleAddedFile.bind(_this); + _this.handleFailedUpload = _this.handleFailedUpload.bind(_this); + _this.handleSuccessfulUpload = _this.handleSuccessfulUpload.bind(_this); + _this.handleSending = _this.handleSending.bind(_this); + _this.handleUploadProgress = _this.handleUploadProgress.bind(_this); + _this.handleCancelUpload = _this.handleCancelUpload.bind(_this); + _this.handleRemoveErroredUpload = _this.handleRemoveErroredUpload.bind(_this); + _this.canFileUpload = _this.canFileUpload.bind(_this); + _this.updateFormData = _this.updateFormData.bind(_this); + return _this; + } + + _createClass(PreviewImageField, [{ + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(nextProps) { + if (this.props.data.url && nextProps.data.url !== this.props.data.url || this.props.data.version && nextProps.data.version !== this.props.data.version) { + this.props.actions.previewField.removeFile(this.props.id); + } + } + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + this.props.actions.previewField.removeFile(this.props.id); + } + }, { + key: 'getDropzoneProps', + value: function getDropzoneProps() { + var endpoint = this.props.data.uploadFileEndpoint; + var name = this.props.name; + var options = { + url: endpoint && endpoint.url, + method: endpoint && endpoint.method, + paramName: 'Upload', + clickable: '#preview-replace-button', + maxFiles: 1 + }; + var preview = { + height: _index2.default.THUMBNAIL_HEIGHT, + width: _index2.default.THUMBNAIL_WIDTH + }; + var securityID = this.props.securityID; + + var classNames = ['asset-dropzone--button', 'preview-image-field__container', this.props.className, this.props.extraClass]; + + return { + name: name, + className: classNames.join(' '), + canUpload: endpoint && this.canEdit(), + preview: preview, + folderId: this.props.data.parentid, + options: options, + securityID: securityID, + uploadButton: false, + onAddedFile: this.handleAddedFile, + onError: this.handleFailedUpload, + onSuccess: this.handleSuccessfulUpload, + onSending: this.handleSending, + onUploadProgress: this.handleUploadProgress, + canFileUpload: this.canFileUpload, + updateFormData: this.updateFormData + }; + } + }, { + key: 'getButtonClasses', + value: function getButtonClasses(type) { + return (0, _classnames2.default)(['preview-image-field__toolbar-button--' + type, 'preview-image-field__toolbar-button']); + } + }, { + key: 'updateFormData', + value: function updateFormData(formData) { + formData.append('ID', this.props.data.id); + formData.append('Name', this.props.nameValue); + } + }, { + key: 'handleSending', + value: function handleSending(file, xhr) { + this.props.actions.previewField.updateFile(this.props.id, { xhr: xhr }); + } + }, { + key: 'handleSuccessfulUpload', + value: function handleSuccessfulUpload(fileXhr) { + var json = JSON.parse(fileXhr.xhr.response); + + if (typeof this.props.onAutofill === 'function') { + this.props.onAutofill('FileFilename', json.Filename); + this.props.onAutofill('FileHash', json.Hash); + this.props.onAutofill('FileVariant', json.Variant); + + if (json.Name) { + this.props.onAutofill(this.props.data.nameField, json.Name); + } + } + } + }, { + key: 'handleFailedUpload', + value: function handleFailedUpload(file, response) { + this.props.actions.previewField.failUpload(this.props.id, response); + } + }, { + key: 'handleAddedFile', + value: function handleAddedFile(data) { + this.props.actions.previewField.addFile(this.props.id, data); + } + }, { + key: 'handleRemoveErroredUpload', + value: function handleRemoveErroredUpload() { + if (typeof this.props.onAutofill === 'function') { + var initial = this.props.data.initialValues; + + this.props.onAutofill('FileFilename', initial.FileFilename); + this.props.onAutofill('FileHash', initial.FileHash); + this.props.onAutofill('FileVariant', initial.FileVariant); + } + + this.props.actions.previewField.removeFile(this.props.id); + } + }, { + key: 'handleCancelUpload', + value: function handleCancelUpload() { + if (this.props.upload.xhr) { + this.props.upload.xhr.abort(); + } + this.handleRemoveErroredUpload(); + } + }, { + key: 'canFileUpload', + value: function canFileUpload(file) { + var prevName = this.props.data.initialValues.FileFilename; + var prevExt = (0, _DataFormat.getFileExtension)(prevName); + var nextExt = (0, _DataFormat.getFileExtension)(file.name); + + if (!prevExt || prevExt === nextExt) { + return true; + } + + var message = _i18n2.default._t('AssetAdmin.CONFIRM_CHANGE_EXTENSION', 'Are you sure you want upload a file with a different extension?'); + + return this.props.confirm(message); + } + }, { + key: 'preventDefault', + value: function preventDefault(e) { + e.preventDefault(); + } + }, { + key: 'canEdit', + value: function canEdit() { + return !this.props.readOnly && !this.props.disabled && this.props.data.category !== 'folder'; + } + }, { + key: 'handleUploadProgress', + value: function handleUploadProgress(file, progress) { + this.props.actions.previewField.updateFile(this.props.id, { progress: progress }); + } + }, { + key: 'renderImage', + value: function renderImage() { + var data = this.props.data; + + if (!data.mock && !data.exists && !this.props.upload.url) { + return _react2.default.createElement( + 'div', + { className: 'editor__file-preview-message--file-missing' }, + _i18n2.default._t('AssetAdmin.FILE_MISSING', 'File cannot be found') + ); + } + + var category = this.props.upload.category; + var preview = category && category !== 'image' ? _index2.default.DEFAULT_PREVIEW : this.props.upload.url || data.preview || data.url; + var image = _react2.default.createElement('img', { alt: 'preview', src: preview, className: 'editor__thumbnail' }); + var progress = this.props.upload.progress; + var linkedImage = data.url && !progress ? _react2.default.createElement( + 'a', + { className: 'editor__file-preview-link', href: data.url, target: '_blank' }, + image + ) : null; + var progressBar = progress > 0 && progress < 100 ? _react2.default.createElement( + 'div', + { className: 'preview-image-field__progress' }, + _react2.default.createElement('div', { className: 'preview-image-field__progress-bar', style: { width: progress + '%' } }) + ) : null; + var message = this.props.upload.message; + var messageBox = null; + + if (message) { + messageBox = _react2.default.createElement( + 'div', + { className: 'preview-image-field__message preview-image-field__message--' + message.type }, + message.value + ); + } else if (progress === 100) { + messageBox = _react2.default.createElement( + 'div', + { className: 'preview-image-field__message preview-image-field__message--success' }, + _i18n2.default._t('AssetAdmin.REPlACE_FILE_SUCCESS', 'Upload successful, the file will be replaced when you Save.') + ); + } + + return _react2.default.createElement( + 'div', + { className: 'editor__thumbnail-container' }, + linkedImage || image, + progressBar, + messageBox + ); + } + }, { + key: 'renderToolbar', + value: function renderToolbar() { + var canEdit = this.canEdit(); + if (!this.props.data.url && !canEdit) { + return null; + } + return _react2.default.createElement( + 'div', + { className: 'preview-image-field__toolbar fill-height' }, + this.props.data.url ? _react2.default.createElement( + 'a', + { + href: this.props.data.url, + target: '_blank', + className: this.getButtonClasses('link') + }, + 'Open' + ) : null, + canEdit ? _react2.default.createElement( + 'button', + { + id: 'preview-replace-button', + onClick: this.preventDefault, + className: this.getButtonClasses('replace'), + type: 'button' + }, + 'Replace' + ) : null, + this.props.upload.progress || this.props.upload.message ? _react2.default.createElement( + 'button', + { + onClick: this.handleCancelUpload, + className: this.getButtonClasses('remove'), + type: 'button' + }, + 'Remove' + ) : null + ); + } + }, { + key: 'render', + value: function render() { + var dropzoneProps = this.getDropzoneProps(); + + if (this.canEdit()) { + return _react2.default.createElement( + _AssetDropzone2.default, + dropzoneProps, + this.renderImage(), + this.renderToolbar() + ); + } + var classNames = ['preview-image-field__container', this.props.className, this.props.extraClass]; + + return _react2.default.createElement( + 'div', + { className: classNames.join(' ') }, + this.renderImage(), + this.renderToolbar() + ); + } + }]); + + return PreviewImageField; +}(_react.Component); + +PreviewImageField.propTypes = { + id: _react.PropTypes.string.isRequired, + name: _react.PropTypes.string, + className: _react.PropTypes.string, + extraClass: _react.PropTypes.string, + readOnly: _react.PropTypes.bool, + disabled: _react.PropTypes.bool, + onAutofill: _react.PropTypes.func, + formid: _react.PropTypes.string, + nameValue: _react.PropTypes.string, + data: _react.PropTypes.shape({ + id: _react.PropTypes.number, + parentid: _react.PropTypes.number, + version: _react.PropTypes.number, + url: _react.PropTypes.string, + mock: _react.PropTypes.bool, + exists: _react.PropTypes.bool, + preview: _react.PropTypes.string, + category: _react.PropTypes.string, + nameField: _react.PropTypes.string, + uploadFileEndpoint: _react.PropTypes.shape({ + url: _react.PropTypes.string.isRequired, + method: _react.PropTypes.string.isRequired, + payloadFormat: _react.PropTypes.string + }), + initialValues: _react.PropTypes.object + }).isRequired, + upload: _react.PropTypes.shape({ + url: _react.PropTypes.string, + progress: _react.PropTypes.number, + xhr: _react.PropTypes.object, + category: _react.PropTypes.string, + message: _react.PropTypes.shape({ + type: _react.PropTypes.string.isRequired, + value: _react.PropTypes.string.isRequired + }) + }), + actions: _react.PropTypes.object, + securityID: _react.PropTypes.string, + confirm: _react.PropTypes.func +}; + +PreviewImageField.defaultProps = { + extraClass: '', + className: '', + data: {}, + upload: {}, + + confirm: function confirm(msg) { + return window.confirm(msg); + } +}; + +function mapStateToProps(state, ownProps) { + var securityID = state.config.SecurityID; + var id = ownProps.id; + var upload = state.assetAdmin.previewField[id] || {}; + var selector = (0, _reduxForm.formValueSelector)(ownProps.formid, _getFormState2.default); + + return { + securityID: securityID, + upload: upload, + nameValue: selector(state, 'Name') + }; +} + +function mapDispatchToProps(dispatch) { + return { + actions: { + previewField: (0, _redux.bindActionCreators)(previewFieldActions, dispatch) + } + }; +} + +exports.Component = PreviewImageField; +exports.default = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps)(PreviewImageField); + +/***/ }), + +/***/ "./client/src/components/ProportionConstraintField/ProportionConstraintField.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _Injector = __webpack_require__(2); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var ProportionConstraintField = function (_Component) { + _inherits(ProportionConstraintField, _Component); + + function ProportionConstraintField(props) { + _classCallCheck(this, ProportionConstraintField); + + var _this = _possibleConstructorReturn(this, (ProportionConstraintField.__proto__ || Object.getPrototypeOf(ProportionConstraintField)).call(this, props)); + + var childrenArray = _react.Children.toArray(props.children); + + if (childrenArray.length !== 2) { + throw new Error('ProportionConstraintField must be passed two children -- one field for each value'); + } + return _this; + } + + _createClass(ProportionConstraintField, [{ + key: 'handleChange', + value: function handleChange(childIndex, e, newValue) { + var _props = this.props, + children = _props.children, + active = _props.active, + onAutofill = _props.onAutofill, + ratio = _props.data.ratio; + + var value = newValue || e.target.value; + var peerIndex = childIndex === 0 ? 1 : 0; + var currentName = children[childIndex].props.name; + var peerName = children[peerIndex].props.name; + var multiplier = childIndex === 0 ? 1 / ratio : ratio; + var round = Math.round; + + + onAutofill(currentName, value); + + if (active) { + onAutofill(peerName, round(value * multiplier)); + } + } + }, { + key: 'render', + value: function render() { + var _this2 = this; + + var FieldGroup = this.props.FieldGroup; + + return _react2.default.createElement( + FieldGroup, + this.props, + this.props.children.map(function (child, key) { + return (0, _react.cloneElement)(child, { + onChange: function onChange(e, newValue) { + return _this2.handleChange(key, e, newValue); + }, + key: key + }, child.props.children); + }) + ); + } + }]); + + return ProportionConstraintField; +}(_react.Component); + +ProportionConstraintField.propTypes = { + children: _react.PropTypes.array, + onAutofill: _react.PropTypes.func, + active: _react.PropTypes.bool, + data: _react.PropTypes.shape({ + ratio: _react.PropTypes.number.isRequired + }), + FieldGroup: _react.PropTypes.oneOfType([_react.PropTypes.element, _react.PropTypes.func]).isRequired +}; + +ProportionConstraintField.defaultProps = { + active: true +}; + +exports.Component = ProportionConstraintField; +exports.default = (0, _Injector.inject)(['FieldGroup'])(ProportionConstraintField); + +/***/ }), + +/***/ "./client/src/components/Search/Search.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hasFilters = exports.Component = undefined; + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactRedux = __webpack_require__(3); + +var _reactDom = __webpack_require__(5); + +var _reactDom2 = _interopRequireDefault(_reactDom); + +var _redux = __webpack_require__(4); + +var _FormBuilderLoader = __webpack_require__(18); + +var _FormBuilderLoader2 = _interopRequireDefault(_FormBuilderLoader); + +var _reactstrap = __webpack_require__(22); + +var _SchemaActions = __webpack_require__(16); + +var schemaActions = _interopRequireWildcard(_SchemaActions); + +var _reduxForm = __webpack_require__(23); + +var _getIn = __webpack_require__("./node_modules/redux-form/lib/structure/plain/getIn.js"); + +var _getIn2 = _interopRequireDefault(_getIn); + +var _Focusedzone = __webpack_require__(30); + +var _Focusedzone2 = _interopRequireDefault(_Focusedzone); + +var _getFormState = __webpack_require__(24); + +var _getFormState2 = _interopRequireDefault(_getFormState); + +var _classnames = __webpack_require__(9); + +var _classnames2 = _interopRequireDefault(_classnames); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var identifier = 'AssetAdmin.SearchForm'; +var view = { + NONE: 'NONE', + VISIBLE: 'VISIBLE', + EXPANDED: 'EXPANDED' +}; + +function hasFilters(filters) { + return filters && Object.keys(filters).length > 0; +} + +var Search = function (_Component) { + _inherits(Search, _Component); + + function Search(props) { + _classCallCheck(this, Search); + + var _this = _possibleConstructorReturn(this, (Search.__proto__ || Object.getPrototypeOf(Search)).call(this, props)); + + _this.expand = _this.expand.bind(_this); + _this.handleKeyUp = _this.handleKeyUp.bind(_this); + _this.handleChange = _this.handleChange.bind(_this); + _this.doSearch = _this.doSearch.bind(_this); + _this.focusInput = _this.focusInput.bind(_this); + _this.focusFirstFormField = _this.focusFirstFormField.bind(_this); + _this.hide = _this.hide.bind(_this); + _this.show = _this.show.bind(_this); + _this.toggle = _this.toggle.bind(_this); + _this.open = _this.open.bind(_this); + _this.state = { + view: view.NONE, + searchText: props.filters && props.filters.name || '' + }; + return _this; + } + + _createClass(Search, [{ + key: 'componentWillMount', + value: function componentWillMount() { + this.setOverrides(this.props); + } + }, { + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(props) { + if (props && !hasFilters(props.filters) && hasFilters(this.props.filters)) { + this.clearFormData(props); + } else if (JSON.stringify(props.filters) !== JSON.stringify(this.props.filters)) { + this.setOverrides(props); + } + } + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + this.setOverrides(); + } + }, { + key: 'setOverrides', + value: function setOverrides(props) { + if (props && (!hasFilters(props.filters) || this.props.searchFormSchemaUrl !== props.searchFormSchemaUrl)) { + var schemaUrl = props && props.searchFormSchemaUrl || this.props.searchFormSchemaUrl; + if (schemaUrl) { + this.props.actions.schema.setSchemaStateOverrides(schemaUrl, null); + } + } + + if (props && hasFilters(props.filters) && props.searchFormSchemaUrl) { + var filters = props.filters || {}; + var overrides = { + fields: Object.keys(filters).map(function (name) { + var value = filters[name]; + return { name: name, value: value }; + }) + }; + + this.props.actions.schema.setSchemaStateOverrides(props.searchFormSchemaUrl, overrides); + } + } + }, { + key: 'focusInput', + value: function focusInput() { + if (this.state.view === view.NONE) { + return; + } + + var node = _reactDom2.default.findDOMNode(this); + if (!node) { + return; + } + + var input = node.querySelector('.search__content-field'); + + if (input !== document.activeElement) { + input.focus(); + if (input.select) { + input.select(); + } + } + } + }, { + key: 'focusFirstFormField', + value: function focusFirstFormField() { + if (this.state.view !== view.EXPANDED) { + return; + } + + var node = _reactDom2.default.findDOMNode(this); + if (!node) { + return; + } + + var form = node.querySelector('.search__filter-panel form'); + if (!form) { + return; + } + + var input = form.querySelector('input, textarea, select'); + if (input) { + input.focus(); + if (input.select) { + input.select(); + } + } + } + }, { + key: 'clearFormData', + value: function clearFormData(props) { + this.setState({ searchText: '' }); + + var schemaUrl = props && props.searchFormSchemaUrl || this.props.searchFormSchemaUrl; + if (schemaUrl) { + this.props.actions.schema.setSchemaStateOverrides(schemaUrl, null); + this.props.actions.reduxForm.initialize(identifier, {}, Object.keys(this.props.formData)); + this.props.actions.reduxForm.reset(identifier); + } + } + }, { + key: 'handleChange', + value: function handleChange(event) { + this.setState({ searchText: event.target.value }); + } + }, { + key: 'handleKeyUp', + value: function handleKeyUp(event) { + if (event.keyCode === 13) { + this.doSearch(); + } + } + }, { + key: 'open', + value: function open() { + this.show(); + setTimeout(this.focusInput, 50); + } + }, { + key: 'hide', + value: function hide() { + this.setState({ view: view.NONE }); + } + }, { + key: 'show', + value: function show() { + this.setState({ view: view.VISIBLE }); + } + }, { + key: 'expand', + value: function expand() { + this.setState({ view: view.EXPANDED }); + } + }, { + key: 'toggle', + value: function toggle() { + switch (this.state.view) { + case view.VISIBLE: + this.expand(); + setTimeout(this.focusFirstFormField, 50); + break; + case view.EXPANDED: + this.show(); + break; + default: + } + } + }, { + key: 'doSearch', + value: function doSearch() { + var _this2 = this; + + var data = {}; + + if (this.state.searchText) { + data.name = this.state.searchText; + } + + Object.keys(this.props.formData).forEach(function (key) { + var value = _this2.props.formData[key]; + if (value) { + data[key] = value; + } + }); + + this.show(); + this.props.onSearch(data); + } + }, { + key: 'render', + value: function render() { + var formId = this.props.id + '_ExtraFields'; + var triggerId = this.props.id + '_Trigger'; + var searchText = this.state.searchText; + + var searchClasses = ['search']; + var advancedButtonClasses = ['btn', 'btn-secondary', 'btn--icon-md', 'btn--no-text', 'font-icon-down-open', 'search__filter-trigger']; + var expanded = false; + switch (this.state.view) { + case view.EXPANDED: + expanded = true; + searchClasses.push('search--active'); + break; + case view.VISIBLE: + advancedButtonClasses.push('collapsed'); + searchClasses.push('search--active'); + break; + case view.NONE: + advancedButtonClasses.push('collapsed'); + break; + default: + } + + var searchButtonClasses = (0, _classnames2.default)('btn', 'btn-primary', 'search__submit', 'font-icon-search', 'btn--icon-large', 'btn--no-text'); + + var searchTriggerButtonClasses = (0, _classnames2.default)('btn', 'btn--no-text', 'btn-secondary', 'search__trigger', 'font-icon-search', 'btn--icon-large'); + + return _react2.default.createElement( + _Focusedzone2.default, + { onClickOut: this.hide }, + _react2.default.createElement( + 'div', + { className: searchClasses.join(' ') }, + _react2.default.createElement('button', { + className: searchTriggerButtonClasses, + type: 'button', + title: _i18n2.default._t('AssetAdmin.SEARCH', 'Search'), + 'aria-owns': this.props.id, + 'aria-controls': this.props.id, + 'aria-expanded': 'false', + onClick: this.open, + id: triggerId + }), + _react2.default.createElement( + 'div', + { id: this.props.id, className: 'search__group' }, + _react2.default.createElement('input', { + 'aria-labelledby': triggerId, + type: 'text', + name: 'name', + placeholder: _i18n2.default._t('AssetAdmin.SEARCH', 'Search'), + className: 'form-control search__content-field', + onKeyUp: this.handleKeyUp, + onChange: this.handleChange, + value: searchText, + + autoFocus: true + }), + _react2.default.createElement( + 'button', + { + 'aria-expanded': expanded, + 'aria-controls': formId, + onClick: this.toggle, + className: advancedButtonClasses.join(' '), + title: _i18n2.default._t('AssetAdmin.ADVANCED', 'Advanced') + }, + _react2.default.createElement( + 'span', + { className: 'search__filter-trigger-text' }, + _i18n2.default._t('AssetAdmin.ADVANCED', 'Advanced') + ) + ), + _react2.default.createElement('button', { + className: searchButtonClasses, + title: _i18n2.default._t('AssetAdmin.SEARCH', 'Search'), + onClick: this.doSearch + }), + _react2.default.createElement('button', { + onClick: this.hide, + title: _i18n2.default._t('AssetAdmin.CLOSE', 'Close'), + className: 'btn font-icon-cancel btn--no-text btn--icon-md search__cancel', + 'aria-controls': this.props.id, + 'aria-expanded': 'true' + }), + _react2.default.createElement( + _reactstrap.Collapse, + { id: formId, className: 'search__filter-panel', isOpen: expanded }, + _react2.default.createElement(_FormBuilderLoader2.default, { + identifier: identifier, + schemaUrl: this.props.searchFormSchemaUrl + }) + ) + ) + ) + ); + } + }]); + + return Search; +}(_react.Component); + +Search.propTypes = { + searchFormSchemaUrl: _react.PropTypes.string.isRequired, + id: _react.PropTypes.string.isRequired, + onSearch: _react.PropTypes.func.isRequired, + filters: _react.PropTypes.object, + formData: _react.PropTypes.object +}; + +function mapStateToProps(state, ownProps) { + var schema = state.form.formSchemas[ownProps.searchFormSchemaUrl]; + if (!schema || !schema.name) { + return { formData: {} }; + } + var form = (0, _getIn2.default)((0, _getFormState2.default)(state), schema.name); + var formData = form && form.values || {}; + return { formData: formData }; +} + +function mapDispatchToProps(dispatch) { + return { + actions: { + schema: (0, _redux.bindActionCreators)(schemaActions, dispatch), + reduxForm: (0, _redux.bindActionCreators)({ reset: _reduxForm.reset, initialize: _reduxForm.initialize }, dispatch) + } + }; +} + +exports.Component = Search; +exports.hasFilters = hasFilters; +exports.default = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps)(Search); + +/***/ }), + +/***/ "./client/src/components/UploadField/UploadField.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ConnectedUploadField = exports.Component = undefined; + +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 _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactRedux = __webpack_require__(3); + +var _redux = __webpack_require__(4); + +var _Injector = __webpack_require__(2); + +var _index = __webpack_require__("./client/src/constants/index.js"); + +var _index2 = _interopRequireDefault(_index); + +var _FieldHolder = __webpack_require__(28); + +var _FieldHolder2 = _interopRequireDefault(_FieldHolder); + +var _fileShape = __webpack_require__("./client/src/lib/fileShape.js"); + +var _fileShape2 = _interopRequireDefault(_fileShape); + +var _UploadFieldActions = __webpack_require__("./client/src/state/uploadField/UploadFieldActions.js"); + +var uploadFieldActions = _interopRequireWildcard(_UploadFieldActions); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +function compareValues(left, right) { + if (left.length !== right.length) { + return true; + } + + for (var i = 0; i < left.length; i++) { + if (left[i].id !== right[i].id) { + return true; + } + } + return false; +} + +var UploadField = function (_Component) { + _inherits(UploadField, _Component); + + function UploadField(props) { + _classCallCheck(this, UploadField); + + var _this = _possibleConstructorReturn(this, (UploadField.__proto__ || Object.getPrototypeOf(UploadField)).call(this, props)); + + _this.getMaxFiles = _this.getMaxFiles.bind(_this); + _this.getFolderId = _this.getFolderId.bind(_this); + _this.renderChild = _this.renderChild.bind(_this); + _this.handleAddShow = _this.handleAddShow.bind(_this); + _this.handleHide = _this.handleHide.bind(_this); + _this.handleAddInsert = _this.handleAddInsert.bind(_this); + _this.handleInsertMany = _this.handleInsertMany.bind(_this); + _this.handleAddedFile = _this.handleAddedFile.bind(_this); + _this.handleSending = _this.handleSending.bind(_this); + _this.handleUploadProgress = _this.handleUploadProgress.bind(_this); + _this.handleFailedUpload = _this.handleFailedUpload.bind(_this); + _this.handleSuccessfulUpload = _this.handleSuccessfulUpload.bind(_this); + _this.handleItemRemove = _this.handleItemRemove.bind(_this); + _this.handleReplaceShow = _this.handleReplaceShow.bind(_this); + _this.handleChange = _this.handleChange.bind(_this); + _this.handleReplace = _this.handleReplace.bind(_this); + _this.canEdit = _this.canEdit.bind(_this); + _this.canAttach = _this.canAttach.bind(_this); + _this.canUpload = _this.canUpload.bind(_this); + + _this.state = { + selecting: false, + selectingItem: null + }; + return _this; + } + + _createClass(UploadField, [{ + key: 'componentDidMount', + value: function componentDidMount() { + this.props.actions.uploadField.setFiles(this.props.id, this.props.data.files); + } + }, { + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(nextProps) { + var existingFiles = this.props.files || []; + var newFiles = nextProps.files || []; + var filesChanged = compareValues(existingFiles, newFiles); + + if (filesChanged) { + this.handleChange(null, nextProps); + } + } + }, { + key: 'getMaxFiles', + value: function getMaxFiles() { + var maxFiles = this.props.data.multi ? this.props.data.maxFiles : 1; + if (maxFiles === null || typeof maxFiles === 'undefined') { + return null; + } + var filesCount = this.props.files.filter(function (file) { + return !file.message || file.message.type !== 'error'; + }).length; + var allowed = Math.max(maxFiles - filesCount, 0); + + return allowed; + } + }, { + key: 'getFolderId', + value: function getFolderId() { + var selectingItem = this.state.selectingItem; + + + if (selectingItem && (typeof selectingItem === 'undefined' ? 'undefined' : _typeof(selectingItem)) === 'object') { + return selectingItem.parent.id; + } + + return this.props.data.parentid || 0; + } + }, { + key: 'handleAddedFile', + value: function handleAddedFile(data) { + var file = _extends({}, data, { uploaded: true }); + this.props.actions.uploadField.addFile(this.props.id, file); + } + }, { + key: 'handleSending', + value: function handleSending(file, xhr) { + this.props.actions.uploadField.updateQueuedFile(this.props.id, file._queuedId, { xhr: xhr }); + } + }, { + key: 'handleUploadProgress', + value: function handleUploadProgress(file, progress) { + this.props.actions.uploadField.updateQueuedFile(this.props.id, file._queuedId, { progress: progress }); + } + }, { + key: 'handleSuccessfulUpload', + value: function handleSuccessfulUpload(file) { + var json = JSON.parse(file.xhr.response); + + if (typeof json[0].error !== 'undefined') { + this.handleFailedUpload(file); + return; + } + + this.props.actions.uploadField.succeedUpload(this.props.id, file._queuedId, json[0]); + } + }, { + key: 'handleFailedUpload', + value: function handleFailedUpload(file, response) { + this.props.actions.uploadField.failUpload(this.props.id, file._queuedId, response); + } + }, { + key: 'handleItemRemove', + value: function handleItemRemove(event, item) { + this.props.actions.uploadField.removeFile(this.props.id, item); + } + }, { + key: 'handleReplaceShow', + value: function handleReplaceShow(event, selectingItem) { + this.setState({ + selecting: true, + selectingItem: selectingItem + }); + } + }, { + key: 'handleChange', + value: function handleChange(event) { + var props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.props; + + if (typeof props.onChange === 'function') { + var fileIds = props.files.filter(function (file) { + return file.id; + }).map(function (file) { + return file.id; + }); + var newValue = { Files: fileIds }; + props.onChange(event, { id: props.id, value: newValue }); + } + } + }, { + key: 'handleUploadButton', + value: function handleUploadButton(event) { + event.preventDefault(); + } + }, { + key: 'handleAddShow', + value: function handleAddShow(event) { + event.preventDefault(); + this.setState({ + selecting: true, + selectingItem: null + }); + } + }, { + key: 'handleHide', + value: function handleHide() { + this.setState({ + selecting: false, + selectingItem: null + }); + } + }, { + key: 'handleAddInsert', + value: function handleAddInsert(event, data, file) { + this.props.actions.uploadField.addFile(this.props.id, file); + this.handleHide(); + + return Promise.resolve({}); + } + }, { + key: 'handleInsertMany', + value: function handleInsertMany(event, files) { + var _this2 = this; + + var selectingItem = this.state.selectingItem; + + if (selectingItem) { + this.handleReplace(event, null, files[0]); + return; + } + files.forEach(function (file) { + _this2.handleAddInsert(event, null, file); + }); + } + }, { + key: 'handleReplace', + value: function handleReplace(event, data, file) { + var selectingItem = this.state.selectingItem; + var _props = this.props, + id = _props.id, + _props$actions$upload = _props.actions.uploadField, + addFile = _props$actions$upload.addFile, + removeFile = _props$actions$upload.removeFile; + + + if (!selectingItem) { + throw new Error('Tried to replace a file when none was selected.'); + } + removeFile(id, selectingItem); + addFile(id, file); + this.handleHide(); + + return Promise.resolve({}); + } + }, { + key: 'canEdit', + value: function canEdit() { + return !this.props.disabled && !this.props.readOnly && (this.props.data.canUpload || this.props.data.canAttach); + } + }, { + key: 'canUpload', + value: function canUpload() { + return this.canEdit() && this.props.data.canUpload; + } + }, { + key: 'canAttach', + value: function canAttach() { + return this.canEdit() && this.props.data.canAttach; + } + }, { + key: 'renderDropzone', + value: function renderDropzone() { + var AssetDropzone = this.props.AssetDropzone; + + if (!this.props.data.createFileEndpoint) { + return null; + } + var dimensions = { + height: _index2.default.SMALL_THUMBNAIL_HEIGHT, + width: _index2.default.SMALL_THUMBNAIL_WIDTH + }; + var maxFiles = this.getMaxFiles(); + var dropzoneOptions = { + url: this.props.data.createFileEndpoint.url, + method: this.props.data.createFileEndpoint.method, + paramName: 'Upload', + maxFiles: maxFiles, + thumbnailWidth: _index2.default.SMALL_THUMBNAIL_WIDTH, + thumbnailHeight: _index2.default.SMALL_THUMBNAIL_HEIGHT + }; + + var classNames = ['uploadfield__dropzone']; + if (maxFiles === 0) { + classNames.push('uploadfield__dropzone--hidden'); + } + + if (!this.canEdit()) { + if (this.props.files.length) { + return null; + } + return _react2.default.createElement( + 'p', + null, + _i18n2.default._t('AssetAdmin.EMPTY', 'No files') + ); + } + + var securityID = this.props.securityId; + var options = []; + if (this.canUpload()) { + options.push(_react2.default.createElement( + 'button', + { + key: 'uploadbutton', + type: 'button', + onClick: this.handleUploadButton, + className: 'uploadfield__upload-button' + }, + _i18n2.default._t('AssetAdmin.BROWSE', 'Browse') + )); + } + if (this.canAttach()) { + if (options.length) { + options.push(_react2.default.createElement( + 'span', + { key: 'uploadjoin', className: 'uploadfield__join' }, + _i18n2.default._t('AssetAdmin.OR', 'or') + )); + } + options.push(_react2.default.createElement( + 'button', + { + key: 'attachbutton', + type: 'button', + onClick: this.handleAddShow, + className: 'uploadfield__add-button' + }, + _i18n2.default._t('AssetAdmin.ADD_FILES', 'Add from files') + )); + } + + return _react2.default.createElement( + AssetDropzone, + { + name: this.props.name, + canUpload: this.canUpload(), + uploadButton: false, + uploadSelector: '.uploadfield__upload-button, .uploadfield__backdrop', + folderId: this.props.data.parentid, + onAddedFile: this.handleAddedFile, + onError: this.handleFailedUpload, + onSuccess: this.handleSuccessfulUpload, + onSending: this.handleSending, + onUploadProgress: this.handleUploadProgress, + preview: dimensions, + options: dropzoneOptions, + securityID: securityID, + className: classNames.join(' ') + }, + _react2.default.createElement('div', { className: 'uploadfield__backdrop' }), + _react2.default.createElement( + 'span', + { className: 'uploadfield__droptext' }, + options + ) + ); + } + }, { + key: 'renderModal', + value: function renderModal() { + var InsertMediaModal = this.props.InsertMediaModal; + var _state = this.state, + selecting = _state.selecting, + selectingItem = _state.selectingItem; + + var maxFiles = this.getMaxFiles(); + var folderId = this.getFolderId(); + + return _react2.default.createElement(InsertMediaModal, { + title: false, + isOpen: selecting, + onInsert: selectingItem ? this.handleReplace : this.handleAddInsert, + onClosed: this.handleHide, + onInsertMany: this.handleInsertMany, + maxFiles: selectingItem ? 1 : maxFiles, + type: 'select', + bodyClassName: 'modal__dialog', + className: 'insert-media-react__dialog-wrapper', + fileAttributes: selectingItem ? { ID: selectingItem.id } : null, + folderId: folderId + }); + } + }, { + key: 'renderChild', + value: function renderChild(item, index) { + var UploadFieldItem = this.props.UploadFieldItem; + + var draftProps = { + key: item.id ? 'file-' + item.id : 'queued-' + item.queuedId, + item: item, + name: this.props.name, + onRemove: this.handleItemRemove, + canEdit: this.canEdit(), + onView: this.handleReplaceShow + }; + var itemProps = this.props.getItemProps(draftProps, index, this.props); + + return _react2.default.createElement(UploadFieldItem, itemProps); + } + }, { + key: 'render', + value: function render() { + return _react2.default.createElement( + 'div', + { className: 'uploadfield' }, + this.renderDropzone(), + this.props.files.map(this.renderChild), + this.renderModal() + ); + } + }]); + + return UploadField; +}(_react.Component); + +UploadField.propTypes = { + id: _react.PropTypes.string.isRequired, + name: _react.PropTypes.string.isRequired, + onChange: _react.PropTypes.func, + value: _react.PropTypes.shape({ + Files: _react.PropTypes.arrayOf(_react.PropTypes.number) + }), + files: _react.PropTypes.arrayOf(_fileShape2.default), + readOnly: _react.PropTypes.bool, + disabled: _react.PropTypes.bool, + data: _react.PropTypes.shape({ + files: _react.PropTypes.arrayOf(_fileShape2.default), + createFileEndpoint: _react.PropTypes.shape({ + url: _react.PropTypes.string.isRequired, + method: _react.PropTypes.string.isRequired, + payloadFormat: _react.PropTypes.string.isRequired + }), + multi: _react.PropTypes.bool, + parentid: _react.PropTypes.number, + canUpload: _react.PropTypes.bool, + canAttach: _react.PropTypes.bool, + maxFiles: _react.PropTypes.number + }), + UploadFieldItem: _react.PropTypes.oneOfType([_react.PropTypes.node, _react.PropTypes.func]), + AssetDropzone: _react.PropTypes.oneOfType([_react.PropTypes.node, _react.PropTypes.func]), + InsertMediaModal: _react.PropTypes.oneOfType([_react.PropTypes.node, _react.PropTypes.func]), + getItemProps: _react.PropTypes.func +}; + +UploadField.defaultProps = { + value: { Files: [] }, + className: '', + getItemProps: function getItemProps(props) { + return props; + } +}; + +function mapStateToProps(state, ownprops) { + var id = ownprops.id; + var files = []; + if (state.assetAdmin && state.assetAdmin.uploadField && state.assetAdmin.uploadField.fields && state.assetAdmin.uploadField.fields[id]) { + files = state.assetAdmin.uploadField.fields[id].files || []; + } + var securityId = state.config.SecurityID; + return { files: files, securityId: securityId }; +} + +function mapDispatchToProps(dispatch) { + return { + actions: { + uploadField: (0, _redux.bindActionCreators)(uploadFieldActions, dispatch) + } + }; +} + +var ConnectedUploadField = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps)(UploadField); + +exports.Component = UploadField; +exports.ConnectedUploadField = ConnectedUploadField; +exports.default = (0, _redux.compose)((0, _Injector.inject)(['UploadFieldItem', 'AssetDropzone', 'InsertMediaModal']), _FieldHolder2.default)(ConnectedUploadField); + +/***/ }), + +/***/ "./client/src/components/UploadField/UploadFieldItem.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _constants = __webpack_require__("../../../node_modules/constants-browserify/constants.json"); + +var _constants2 = _interopRequireDefault(_constants); + +var _fileShape = __webpack_require__("./client/src/lib/fileShape.js"); + +var _fileShape2 = _interopRequireDefault(_fileShape); + +var _DataFormat = __webpack_require__(12); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var UploadFieldItem = function (_Component) { + _inherits(UploadFieldItem, _Component); + + function UploadFieldItem(props) { + _classCallCheck(this, UploadFieldItem); + + var _this = _possibleConstructorReturn(this, (UploadFieldItem.__proto__ || Object.getPrototypeOf(UploadFieldItem)).call(this, props)); + + _this.handleRemove = _this.handleRemove.bind(_this); + _this.handleItemClick = _this.handleItemClick.bind(_this); + _this.handleView = _this.handleView.bind(_this); + return _this; + } + + _createClass(UploadFieldItem, [{ + key: 'getThumbnailStyles', + value: function getThumbnailStyles() { + if (this.isImage() && (this.exists() || this.uploading())) { + var thumbnail = this.props.item.smallThumbnail || this.props.item.url; + return { + backgroundImage: 'url(' + thumbnail + ')' + }; + } + + return {}; + } + }, { + key: 'getThumbnailClassNames', + value: function getThumbnailClassNames() { + var thumbnailClassNames = ['uploadfield-item__thumbnail']; + + if (this.isImageSmallerThanThumbnail()) { + thumbnailClassNames.push('uploadfield-item__thumbnail--small'); + } + + return thumbnailClassNames.join(' '); + } + }, { + key: 'getItemClassNames', + value: function getItemClassNames() { + var category = this.props.item.category || 'none'; + var itemClassNames = ['fill-width', 'uploadfield-item', 'uploadfield-item--' + category]; + + if (this.missing()) { + itemClassNames.push('uploadfield-item--missing'); + } + + if (this.hasError()) { + itemClassNames.push('uploadfield-item--error'); + } + + return itemClassNames.join(' '); + } + }, { + key: 'hasError', + value: function hasError() { + if (this.props.item.message) { + return this.props.item.message.type === 'error'; + } + + return false; + } + }, { + key: 'isImage', + value: function isImage() { + return this.props.item.category === 'image'; + } + }, { + key: 'exists', + value: function exists() { + return this.props.item.exists; + } + }, { + key: 'uploading', + value: function uploading() { + return this.props.item.queuedId && !this.saved(); + } + }, { + key: 'complete', + value: function complete() { + return this.props.item.queuedId && this.saved(); + } + }, { + key: 'saved', + value: function saved() { + return this.props.item.id > 0; + } + }, { + key: 'missing', + value: function missing() { + return !this.exists() && this.saved(); + } + }, { + key: 'isImageSmallerThanThumbnail', + value: function isImageSmallerThanThumbnail() { + if (!this.isImage() || this.missing()) { + return false; + } + var width = this.props.item.width; + var height = this.props.item.height; + + return height && width && height < _constants2.default.SMALL_THUMBNAIL_HEIGHT && width < _constants2.default.SMALL_THUMBNAIL_WIDTH; + } + }, { + key: 'handleRemove', + value: function handleRemove(event) { + event.preventDefault(); + if (this.props.onRemove) { + this.props.onRemove(event, this.props.item); + } + } + }, { + key: 'handleView', + value: function handleView(event) { + event.preventDefault(); + if (this.props.onView) { + this.props.onView(event, this.props.item); + } + } + }, { + key: 'handleItemClick', + value: function handleItemClick(event) { + event.preventDefault(); + if (this.props.onItemClick) { + this.props.onItemClick(event, this.props.item); + } + } + }, { + key: 'renderStatus', + value: function renderStatus() { + if (this.props.item.draft) { + return _react2.default.createElement( + 'span', + { className: 'uploadfield-item__status' }, + _i18n2.default._t('File.DRAFT', 'Draft') + ); + } else if (this.props.item.modified) { + return _react2.default.createElement( + 'span', + { className: 'uploadfield-item__status' }, + _i18n2.default._t('File.MODIFIED', 'Modified') + ); + } + return null; + } + }, { + key: 'renderErrorMessage', + value: function renderErrorMessage() { + var message = null; + + if (this.hasError()) { + message = this.props.item.message.value; + } else if (this.missing()) { + message = _i18n2.default._t('AssetAdmin.FILE_MISSING', 'File cannot be found'); + } + + if (message !== null) { + return _react2.default.createElement( + 'div', + { className: 'uploadfield-item__error-message' }, + message + ); + } + + return null; + } + }, { + key: 'renderProgressBar', + value: function renderProgressBar() { + var progressBarProps = { + className: 'uploadfield-item__progress-bar', + style: { + width: this.props.item.progress + '%' + } + }; + + if (!this.hasError() && this.props.item.queuedId) { + if (this.complete()) { + return _react2.default.createElement('div', { className: 'uploadfield-item__complete-icon' }); + } + return _react2.default.createElement( + 'div', + { className: 'uploadfield-item__upload-progress' }, + _react2.default.createElement('div', progressBarProps) + ); + } + + return null; + } + }, { + key: 'renderRemoveButton', + value: function renderRemoveButton() { + if (!this.props.canEdit) { + return null; + } + var classes = ['btn', 'uploadfield-item__remove-btn', 'btn-secondary', 'btn--no-text', 'font-icon-cancel', 'btn--icon-md'].join(' '); + return _react2.default.createElement('button', { + className: classes, + onClick: this.handleRemove + }); + } + }, { + key: 'renderViewButton', + value: function renderViewButton() { + if (!this.props.canEdit || !this.props.item.id) { + return null; + } + var classes = ['btn', 'uploadfield-item__view-btn', 'btn-secondary', 'btn--no-text', 'font-icon-eye', 'btn--icon-md'].join(' '); + return _react2.default.createElement('button', { + className: classes, + onClick: this.handleView + }); + } + }, { + key: 'renderFileDetails', + value: function renderFileDetails() { + var size = ''; + if (this.props.item.size) { + size = ', ' + (0, _DataFormat.fileSize)(this.props.item.size); + } + + return _react2.default.createElement( + 'div', + { className: 'uploadfield-item__details fill-height flexbox-area-grow' }, + _react2.default.createElement( + 'div', + { className: 'fill-width' }, + _react2.default.createElement( + 'span', + { className: 'uploadfield-item__title flexbox-area-grow' }, + this.props.item.title + ) + ), + _react2.default.createElement( + 'div', + { className: 'fill-width uploadfield-item__meta' }, + _react2.default.createElement( + 'span', + { className: 'uploadfield-item__specs' }, + this.props.item.extension, + size + ), + this.renderStatus() + ) + ); + } + }, { + key: 'renderThumbnail', + value: function renderThumbnail() { + return _react2.default.createElement('div', { + className: this.getThumbnailClassNames(), + style: this.getThumbnailStyles(), + onClick: this.handleItemClick, + role: 'button', + tabIndex: this.props.onItemClick ? 0 : -1 + }); + } + }, { + key: 'render', + value: function render() { + var fieldName = this.props.name + '[Files][]'; + return _react2.default.createElement( + 'div', + { className: this.getItemClassNames() }, + _react2.default.createElement('input', { type: 'hidden', value: this.props.item.id, name: fieldName }), + this.renderThumbnail(), + this.renderFileDetails(), + this.renderProgressBar(), + this.renderErrorMessage(), + this.renderViewButton(), + this.renderRemoveButton() + ); + } + }]); + + return UploadFieldItem; +}(_react.Component); + +UploadFieldItem.propTypes = { + canEdit: _react2.default.PropTypes.bool, + name: _react2.default.PropTypes.string.isRequired, + item: _fileShape2.default, + onRemove: _react2.default.PropTypes.func, + onItemClick: _react2.default.PropTypes.func, + onView: _react2.default.PropTypes.func +}; + +exports.default = UploadFieldItem; + +/***/ }), + +/***/ "./client/src/constants/index.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +exports.default = { + ACTIONS: { + CREATE_FOLDER: 'create-folder', + EDIT_FILE: 'edit' + }, + MOVE_SUCCESS_DURATION: 3000, + CSS_TRANSITION_TIME: 300, + SMALL_THUMBNAIL_HEIGHT: 60, + SMALL_THUMBNAIL_WIDTH: 60, + THUMBNAIL_HEIGHT: 150, + THUMBNAIL_WIDTH: 200, + BULK_ACTIONS: [{ + value: 'delete', + label: _i18n2.default._t('AssetAdmin.BULK_ACTIONS_DELETE', 'Delete'), + className: 'font-icon-trash', + destructive: true, + callback: null, + canApply: function canApply(items) { + return items.every(function (item) { + return item && item.canDelete; + }); + }, + confirm: function (_confirm) { + function confirm(_x) { + return _confirm.apply(this, arguments); + } + + confirm.toString = function () { + return _confirm.toString(); + }; + + return confirm; + }(function (items) { + return new Promise(function (resolve, reject) { + var foldersInUse = items.filter(function (item) { + return item.type === 'folder' && item.filesInUseCount > 0; + }); + + if (foldersInUse.length) { + alert(_i18n2.default._t('AssetAdmin.BULK_ACTIONS_DELETE_FOLDER', 'These folders contain files which are currently in use, you must move or ' + 'delete their contents before you can delete the folder.')); + + reject('cancelled'); + return; + } + var filesInUse = items.filter(function (item) { + return item.type !== 'folder' && item.inUseCount > 0; + }); + + var msg = _i18n2.default._t('AssetAdmin.BULK_ACTIONS_DELETE_CONFIRM', 'Are you sure you want to delete these files?'); + if (items.length === 1 && filesInUse.length === 1) { + msg = _i18n2.default.sprintf(_i18n2.default._t('AssetAdmin.BULK_ACTIONS_DELETE_SINGLE_CONFIRM', 'This file is currently used in %s place(s), are you sure you want to delete it?'), items[0].inUseCount); + } else if (filesInUse.length > 0) { + msg = _i18n2.default.sprintf(_i18n2.default._t('AssetAdmin.BULK_ACTIONS_DELETE_MULTI_CONFIRM', 'There are %s files currently in use, are you sure you want to delete these files?'), filesInUse.length); + } + if (filesInUse.length > 0) { + msg += '\n\n'; + msg += _i18n2.default._t('AssetAdmin.BULK_ACTIONS_DELETE_WARNING', 'Ensure files are removed from content areas prior to deleting them,' + ' otherwise they will appear as broken links.'); + } + + if (confirm(msg)) { + resolve(); + } else { + reject('cancelled'); + } + }); + }) + }, { + value: 'edit', + label: _i18n2.default._t('AssetAdmin.BULK_ACTIONS_EDIT', 'Edit'), + className: 'font-icon-edit', + destructive: false, + + canApply: function canApply(items) { + return items.length === 1; + }, + callback: null }, { + value: 'move', + label: _i18n2.default._t('AssetAdmin.BULK_ACTIONS_MOVE', 'Move'), + className: 'font-icon-folder-move', + canApply: function canApply(items) { + return items.every(function (item) { + return item && item.canEdit; + }); + }, + destructive: false, + callback: null + }, { + value: 'publish', + label: _i18n2.default._t('AssetAdmin.BULK_ACTIONS_PUBLISH', 'Publish'), + className: 'font-icon-rocket', + destructive: false, + callback: null, + canApply: function canApply(items) { + return items.some(function (item) { + return item && !item.published; + }) && items.every(function (item) { + return item.canEdit && item.type !== 'folder'; + }); + }, + confirm: null + }, { + value: 'unpublish', + label: _i18n2.default._t('AssetAdmin.BULK_ACTIONS_UNPUBLISH', 'Unpublish'), + className: 'font-icon-cancel-circled', + destructive: false, + callback: null, + canApply: function canApply(items) { + return items.some(function (item) { + return item.published; + }) && items.every(function (item) { + return item.canEdit && item.type !== 'folder'; + }); + }, + confirm: null + }, { + value: 'insert', + label: _i18n2.default._t('AssetAdmin.BULK_ACTIONS_INSERT', 'Insert'), + className: 'font-icon-plus-circled btn-primary', + destructive: false, + callback: null, + canApply: function canApply(items) { + return items.length; + }, + confirm: null + }], + BULK_ACTIONS_PLACEHOLDER: _i18n2.default._t('AssetAdmin.BULK_ACTIONS_PLACEHOLDER'), + SPACE_KEY_CODE: 32, + RETURN_KEY_CODE: 13, + DEFAULT_PREVIEW: 'framework/client/dist/images/app_icons/generic_92.png', + MODAL_MOVE: 'MODAL_MOVE' +}; + +/***/ }), + +/***/ "./client/src/containers/AssetAdmin/AssetAdmin.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.getFormSchema = exports.Component = undefined; + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactRedux = __webpack_require__(3); + +var _redux = __webpack_require__(4); + +var _Backend = __webpack_require__(19); + +var _Backend2 = _interopRequireDefault(_Backend); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _classnames = __webpack_require__(9); + +var _classnames2 = _interopRequireDefault(_classnames); + +var _GalleryActions = __webpack_require__("./client/src/state/gallery/GalleryActions.js"); + +var galleryActions = _interopRequireWildcard(_GalleryActions); + +var _BreadcrumbsActions = __webpack_require__(27); + +var breadcrumbsActions = _interopRequireWildcard(_BreadcrumbsActions); + +var _QueuedFilesActions = __webpack_require__("./client/src/state/queuedFiles/QueuedFilesActions.js"); + +var queuedFilesActions = _interopRequireWildcard(_QueuedFilesActions); + +var _Editor = __webpack_require__("./client/src/containers/Editor/Editor.js"); + +var _Editor2 = _interopRequireDefault(_Editor); + +var _Gallery = __webpack_require__("./client/src/containers/Gallery/Gallery.js"); + +var _Gallery2 = _interopRequireDefault(_Gallery); + +var _Breadcrumb = __webpack_require__(26); + +var _Breadcrumb2 = _interopRequireDefault(_Breadcrumb); + +var _Toolbar = __webpack_require__(36); + +var _Toolbar2 = _interopRequireDefault(_Toolbar); + +var _reactApollo = __webpack_require__(8); + +var _Search = __webpack_require__("./client/src/components/Search/Search.js"); + +var _Search2 = _interopRequireDefault(_Search); + +var _deleteFilesMutation = __webpack_require__("./client/src/state/files/deleteFilesMutation.js"); + +var _deleteFilesMutation2 = _interopRequireDefault(_deleteFilesMutation); + +var _unpublishFilesMutation = __webpack_require__("./client/src/state/files/unpublishFilesMutation.js"); + +var _unpublishFilesMutation2 = _interopRequireDefault(_unpublishFilesMutation); + +var _publishFilesMutation = __webpack_require__("./client/src/state/files/publishFilesMutation.js"); + +var _publishFilesMutation2 = _interopRequireDefault(_publishFilesMutation); + +var _index = __webpack_require__("./client/src/constants/index.js"); + +var _index2 = _interopRequireDefault(_index); + +var _configShape = __webpack_require__("./client/src/lib/configShape.js"); + +var _configShape2 = _interopRequireDefault(_configShape); + +var _Injector = __webpack_require__(2); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +function getFormSchema(_ref) { + var config = _ref.config, + viewAction = _ref.viewAction, + folderId = _ref.folderId, + fileId = _ref.fileId, + type = _ref.type; + + var schemaUrl = null; + var targetId = null; + + if (viewAction === _index2.default.ACTIONS.CREATE_FOLDER) { + schemaUrl = config.form.folderCreateForm.schemaUrl; + targetId = folderId; + + return { schemaUrl: schemaUrl, targetId: targetId }; + } + + if (viewAction === _index2.default.ACTIONS.EDIT_FILE) { + switch (type) { + case 'insert-media': + schemaUrl = config.form.fileInsertForm.schemaUrl; + break; + case 'insert-link': + schemaUrl = config.form.fileEditorLinkForm.schemaUrl; + break; + case 'select': + schemaUrl = config.form.fileSelectForm.schemaUrl; + break; + case 'admin': + default: + schemaUrl = config.form.fileEditForm.schemaUrl; + break; + } + + if (fileId) { + targetId = fileId; + + return { schemaUrl: schemaUrl, targetId: targetId }; + } + } + + return {}; +} + +function compare(left, right) { + if (left && !right || right && !left) { + return true; + } + + return left && right && (left.id !== right.id || left.name !== right.name); +} + +var AssetAdmin = function (_Component) { + _inherits(AssetAdmin, _Component); + + function AssetAdmin(props) { + _classCallCheck(this, AssetAdmin); + + var _this = _possibleConstructorReturn(this, (AssetAdmin.__proto__ || Object.getPrototypeOf(AssetAdmin)).call(this, props)); + + _this.handleOpenFile = _this.handleOpenFile.bind(_this); + _this.handleCloseFile = _this.handleCloseFile.bind(_this); + _this.handleDelete = _this.handleDelete.bind(_this); + _this.doPublish = _this.doPublish.bind(_this); + _this.doUnpublish = _this.doUnpublish.bind(_this); + _this.handleUnpublish = _this.handleUnpublish.bind(_this); + _this.handleDoSearch = _this.handleDoSearch.bind(_this); + _this.handleClearSearch = _this.handleClearSearch.bind(_this); + _this.handleSubmitEditor = _this.handleSubmitEditor.bind(_this); + _this.handleOpenFolder = _this.handleOpenFolder.bind(_this); + _this.handleSort = _this.handleSort.bind(_this); + _this.handleSetPage = _this.handleSetPage.bind(_this); + _this.createEndpoint = _this.createEndpoint.bind(_this); + _this.handleBackButtonClick = _this.handleBackButtonClick.bind(_this); + _this.handleFolderIcon = _this.handleFolderIcon.bind(_this); + _this.handleBrowse = _this.handleBrowse.bind(_this); + _this.handleViewChange = _this.handleViewChange.bind(_this); + _this.handleUpload = _this.handleUpload.bind(_this); + _this.handleCreateFolder = _this.handleCreateFolder.bind(_this); + _this.handleMoveFilesSuccess = _this.handleMoveFilesSuccess.bind(_this); + _this.setBreadcrumbs = _this.setBreadcrumbs.bind(_this); + return _this; + } + + _createClass(AssetAdmin, [{ + key: 'componentDidMount', + value: function componentDidMount() { + this.setBreadcrumbs(this.props); + } + }, { + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(props) { + var viewChanged = compare(this.props.folder, props.folder); + if (viewChanged || (0, _Search.hasFilters)(props.query.filter) !== (0, _Search.hasFilters)(this.props.query.filter)) { + this.setBreadcrumbs(props); + } + + if (!props.loading && props.folder && props.folderId !== props.folder.id) { + props.onReplaceUrl(props.folder.id, props.fileId, props.query, props.viewAction); + } + } + }, { + key: 'getFolderId', + value: function getFolderId() { + if (this.props.folderId !== null) { + return this.props.folderId; + } + if (this.props.folder) { + return this.props.folder.id; + } + return 0; + } + }, { + key: 'setBreadcrumbs', + value: function setBreadcrumbs(props) { + var _this2 = this; + + var folder = props.folder; + var query = props.query; + + var breadcrumbs = [{ + text: _i18n2.default._t('AssetAdmin.FILES', 'Files'), + href: this.props.getUrl && this.props.getUrl(), + onClick: function onClick(event) { + event.preventDefault(); + _this2.handleBrowse(); + } + }]; + + if (folder && folder.id) { + if (folder.parents) { + folder.parents.forEach(function (parent) { + breadcrumbs.push({ + text: parent.title, + href: _this2.props.getUrl && _this2.props.getUrl(parent.id), + onClick: function onClick(event) { + event.preventDefault(); + _this2.handleBrowse(parent.id); + } + }); + }); + } + + breadcrumbs.push({ + text: folder.title, + href: this.props.getUrl && this.props.getUrl(folder.id), + onClick: function onClick(event) { + event.preventDefault(); + _this2.handleBrowse(folder.id); + }, + icon: { + className: 'icon font-icon-edit-list', + onClick: this.handleFolderIcon + } + }); + } + + if ((0, _Search.hasFilters)(query.filter)) { + breadcrumbs.push({ + text: _i18n2.default._t('LeftAndMain.SEARCHRESULTS', 'Search results') + }); + } + + this.props.actions.breadcrumbsActions.setBreadcrumbs(breadcrumbs); + } + }, { + key: 'getFiles', + value: function getFiles() { + var _props = this.props, + files = _props.files, + queuedFiles = _props.queuedFiles; + + + var combinedFilesList = [].concat(_toConsumableArray(queuedFiles.items.filter(function (item) { + return !item.id || !files.find(function (file) { + return file.id === item.id; + }); + })), _toConsumableArray(files)); + + var foldersList = combinedFilesList.filter(function (file) { + return file.type === 'folder'; + }); + var filesList = combinedFilesList.filter(function (file) { + return file.type !== 'folder'; + }); + + return foldersList.concat(filesList); + } + }, { + key: 'handleBrowse', + value: function handleBrowse(folderId, fileId, query) { + if (typeof this.props.onBrowse === 'function') { + this.props.onBrowse(folderId, fileId, query); + } + if (folderId !== this.getFolderId()) { + this.props.actions.gallery.deselectFiles(); + } + } + }, { + key: 'handleSetPage', + value: function handleSetPage(page) { + this.handleBrowse(this.getFolderId(), this.props.fileId, Object.assign({}, this.props.query, { page: page })); + } + }, { + key: 'handleDoSearch', + value: function handleDoSearch(data) { + this.props.actions.gallery.deselectFiles(); + this.props.actions.queuedFiles.purgeUploadQueue(); + this.props.actions.files.readFiles(); + this.handleBrowse(data.currentFolderOnly ? this.getFolderId() : 0, null, { filter: data, view: this.props.query.view }); + } + }, { + key: 'handleClearSearch', + value: function handleClearSearch(event) { + this.props.actions.gallery.deselectFiles(); + this.props.actions.queuedFiles.purgeUploadQueue(); + this.props.actions.files.readFiles(); + this.handleOpenFolder(event, this.props.folder); + } + }, { + key: 'handleSort', + value: function handleSort(sort) { + this.handleBrowse(this.getFolderId(), this.props.fileId, _extends({}, this.props.query, { + sort: sort, + + limit: undefined, + page: undefined + })); + } + }, { + key: 'handleViewChange', + value: function handleViewChange(view) { + this.handleBrowse(this.getFolderId(), this.props.fileId, Object.assign({}, this.props.query, { view: view })); + } + }, { + key: 'createEndpoint', + value: function createEndpoint(endpointConfig) { + var includeToken = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; + + return _Backend2.default.createEndpointFetcher(Object.assign({}, endpointConfig, includeToken ? { defaultData: { SecurityID: this.props.securityId } } : {})); + } + }, { + key: 'handleBackButtonClick', + value: function handleBackButtonClick(event) { + event.preventDefault(); + this.props.actions.gallery.deselectFiles(); + if (this.props.folder) { + this.handleOpenFolder(this.props.folder.parentId || 0); + } else { + this.handleOpenFolder(0); + } + } + }, { + key: 'resetFile', + value: function resetFile(file) { + if (file.queuedId) { + this.props.actions.queuedFiles.removeQueuedFile(file.queuedId); + } + + if (this.props.fileId === file.id) { + this.handleCloseFile(); + this.handleOpenFile(file.id); + } + } + }, { + key: 'handleFolderIcon', + value: function handleFolderIcon(event) { + event.preventDefault(); + this.handleOpenFile(this.getFolderId()); + } + }, { + key: 'handleOpenFile', + value: function handleOpenFile(fileId) { + this.handleBrowse(this.getFolderId(), fileId, this.props.query); + } + }, { + key: 'handleSubmitEditor', + value: function handleSubmitEditor(data, action, submitFn) { + var _this3 = this; + + var promise = null; + + if (action === 'action_insert' && this.props.type === 'select') { + var files = this.getFiles(); + var file = files.find(function (item) { + return item.id === parseInt(data.ID, 10); + }); + + this.props.onInsertMany(null, [file]); + return Promise.resolve(); + } + + if (typeof this.props.onSubmitEditor === 'function') { + var _file = this.findFile(this.props.fileId); + promise = this.props.onSubmitEditor(data, action, submitFn, _file); + } else { + promise = submitFn(); + } + + if (!promise) { + throw new Error('Promise was not returned for submitting'); + } + return promise.then(function (response) { + if (action === 'action_createfolder' && _this3.props.type === 'admin') { + _this3.handleOpenFile(response.record.id); + } + + return _this3.props.actions.files.readFiles().then(function () { + if (action === 'action_createfolder' && _this3.props.type !== 'admin') { + _this3.handleOpenFolder(_this3.getFolderId()); + } + return response; + }); + }); + } + }, { + key: 'handleCloseFile', + value: function handleCloseFile() { + this.handleBrowse(this.getFolderId(), null, this.props.query); + } + }, { + key: 'handleOpenFolder', + value: function handleOpenFolder(folderId) { + var query = Object.assign({}, this.props.query); + delete query.page; + delete query.filter; + this.handleBrowse(folderId, null, query); + } + }, { + key: 'handleDelete', + value: function handleDelete(ids) { + var _this4 = this; + + var files = ids.map(function (id) { + var result = _this4.findFile(id); + if (!result) { + throw new Error('File selected for deletion cannot be found: ' + id); + } + if (result.queuedId) { + _this4.props.actions.queuedFiles.removeQueuedFile(result.queuedId); + } + return result; + }); + + var fileIDs = files.map(function (file) { + return file.id; + }); + var parentId = this.props.folder ? this.props.folder.id : 0; + + return this.props.actions.files.deleteFiles(fileIDs).then(function (_ref2) { + var deleteFiles = _ref2.data.deleteFiles; + + _this4.handleBrowse(parentId, null, _this4.props.query); + + return deleteFiles; + }); + } + }, { + key: 'doUnpublish', + value: function doUnpublish(ids) { + var _this5 = this; + + var force = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; + + var files = ids.map(function (id) { + var result = _this5.findFile(id); + if (!result) { + throw new Error('File selected for unpublishing cannot be found: ' + id); + } else if (result.type === 'folder') { + throw new Error('Cannot unpublish folders'); + } + + return result; + }); + + var fileIDs = files.map(function (file) { + return file.id; + }); + return this.props.actions.files.unpublishFiles(fileIDs, force).then(function (_ref3) { + var unpublishFiles = _ref3.data.unpublishFiles; + + var successes = unpublishFiles.filter(function (result) { + return result.__typename === 'File'; + }); + var confirmationRequired = unpublishFiles.filter(function (result) { + return result.__typename === 'PublicationNotice' && result.Type === 'HAS_OWNERS'; + }); + var successful = successes.map(function (file) { + _this5.resetFile(file); + return file; + }); + var displayedMessages = confirmationRequired.slice(0, 4); + var rest = confirmationRequired.slice(5); + var body = displayedMessages.map(function (warning) { + return warning.Message; + }); + if (rest.length) { + body.push(_i18n2.default.inject(_i18n2.default._t('AssetAdmin.BULK_OWNED_WARNING_REMAINING', 'And {count} other file(s)'), { count: rest.length })); + } + if (displayedMessages.length) { + var alertMessage = [_i18n2.default.inject(_i18n2.default._t('AssetAdmin.BULK_OWNED_WARNING_HEADING', '{count} file(s) are being used by other published content.'), { count: confirmationRequired.length }), body.join('\n'), _i18n2.default._t('AssetAdmin.BULK_OWNED_WARNING_FOOTER', 'Unpublishing will only remove files from the published version of the content. They will remain on the draft version. Unpublish anyway?')]; + + if (confirm(alertMessage.join('\n\n'))) { + var secondPassIDs = confirmationRequired.reduce(function (acc, curr) { + return acc.concat(curr.IDs); + }, []); + return _this5.doUnpublish(secondPassIDs, true).then(function (next) { + return successful.concat(next); + }); + } + } + + return successful; + }); + } + }, { + key: 'handleUnpublish', + value: function handleUnpublish(fileIds) { + var _this6 = this; + + return this.doUnpublish(fileIds).then(function (response) { + var fileId = _this6.props.fileId; + + _this6.props.actions.files.readFiles().then(function () { + if (fileId && response.find(function (file) { + return file.id === fileId; + })) { + _this6.handleCloseFile(); + _this6.handleOpenFile(fileId); + } + }); + }); + } + }, { + key: 'doPublish', + value: function doPublish(ids) { + var _this7 = this; + + var files = ids.map(function (id) { + var result = _this7.findFile(id); + if (!result) { + throw new Error('File selected for publishing cannot be found: ' + id); + } else if (result.type === 'folder') { + throw new Error('Cannot publish folders'); + } + + return result; + }); + + var fileIDs = files.map(function (file) { + return file.id; + }); + + return this.props.actions.files.publishFiles(fileIDs).then(function (_ref4) { + var publishFiles = _ref4.data.publishFiles; + + var successes = publishFiles.filter(function (result) { + return result.__typename === 'File'; + }); + + var successful = successes.map(function (file) { + _this7.resetFile(file); + return file; + }); + + return successful; + }); + } + }, { + key: 'findFile', + value: function findFile(fileId) { + var allFiles = this.getFiles(); + + return allFiles.find(function (item) { + return item.id === parseInt(fileId, 10); + }); + } + }, { + key: 'handleUpload', + value: function handleUpload() {} + }, { + key: 'handleCreateFolder', + value: function handleCreateFolder() { + this.props.onBrowse(this.getFolderId(), null, this.props.query, _index2.default.ACTIONS.CREATE_FOLDER); + } + }, { + key: 'handleMoveFilesSuccess', + value: function handleMoveFilesSuccess(folderId, fileIds) { + var _this8 = this; + + var files = this.props.queuedFiles.items.filter(function (file) { + return fileIds.includes(file.id); + }); + + files.forEach(function (file) { + if (file.queuedId) { + _this8.props.actions.queuedFiles.removeQueuedFile(file.queuedId); + } + }); + + this.props.actions.gallery.deselectFiles(); + + this.props.actions.files.readFiles(); + } + }, { + key: 'renderGallery', + value: function renderGallery() { + var config = this.props.sectionConfig; + var createFileApiUrl = config.createFileEndpoint.url; + var createFileApiMethod = config.createFileEndpoint.method; + + var limit = this.props.query && parseInt(this.props.query.limit || config.limit, 10); + var page = this.props.query && parseInt(this.props.query.page || 1, 10); + + var sort = this.props.query && this.props.query.sort; + var view = this.props.query && this.props.query.view; + var filters = this.props.query.filter || {}; + + return _react2.default.createElement(_Gallery2.default, { + files: this.getFiles(), + fileId: this.props.fileId, + folderId: this.getFolderId(), + folder: this.props.folder, + type: this.props.type, + limit: limit, + page: page, + totalCount: this.props.filesTotalCount, + view: view, + filters: filters, + graphQLErrors: this.props.graphQLErrors, + createFileApiUrl: createFileApiUrl, + createFileApiMethod: createFileApiMethod, + onDelete: this.handleDelete, + onInsertMany: this.props.onInsertMany, + onPublish: this.doPublish, + onUnpublish: this.doUnpublish, + onOpenFile: this.handleOpenFile, + onOpenFolder: this.handleOpenFolder, + onSuccessfulUpload: this.handleUpload, + onCreateFolder: this.handleCreateFolder, + onMoveFilesSuccess: this.handleMoveFilesSuccess, + onClearSearch: this.handleClearSearch, + onSort: this.handleSort, + onSetPage: this.handleSetPage, + onViewChange: this.handleViewChange, + sort: sort, + sectionConfig: config, + loading: this.props.loading, + maxFilesSelect: this.props.maxFiles + }); + } + }, { + key: 'renderEditor', + value: function renderEditor() { + var config = this.props.sectionConfig; + + var _getFormSchema = getFormSchema({ + config: config, + viewAction: this.props.viewAction, + folderId: this.getFolderId(), + type: this.props.type, + fileId: this.props.fileId + }), + schemaUrl = _getFormSchema.schemaUrl, + targetId = _getFormSchema.targetId; + + if (!schemaUrl) { + return null; + } + + return _react2.default.createElement(_Editor2.default, { + className: this.props.dialog ? 'editor--dialog' : '', + targetId: targetId, + file: this.findFile(targetId), + onClose: this.handleCloseFile, + schemaUrl: schemaUrl, + schemaUrlQueries: this.props.requireLinkText ? [{ name: 'requireLinkText', value: true }] : [], + onSubmit: this.handleSubmitEditor, + onDelete: this.handleDelete, + onUnpublish: this.handleUnpublish, + addToCampaignSchemaUrl: config.form.addToCampaignForm.schemaUrl + }); + } + }, { + key: 'render', + value: function render() { + var showBackButton = Boolean(this.props.folderId || (0, _Search.hasFilters)(this.props.query.filter)); + var searchFormSchemaUrl = this.props.sectionConfig.form.fileSearchForm.schemaUrl; + var filters = this.props.query.filter || {}; + var classNames = (0, _classnames2.default)('fill-height asset-admin', this.props.type === 'select' && { + 'asset-admin--single-select': this.props.maxFiles === 1, + 'asset-admin--multi-select': this.props.maxFiles !== 1 + }); + + return _react2.default.createElement( + 'div', + { className: classNames }, + _react2.default.createElement( + _Toolbar2.default, + { + showBackButton: showBackButton, + onBackButtonClick: this.handleBackButtonClick + }, + _react2.default.createElement(_Breadcrumb2.default, { multiline: true }), + _react2.default.createElement( + 'div', + { className: 'asset-admin__toolbar-extra pull-xs-right fill-width vertical-align-items' }, + _react2.default.createElement(_Search2.default, { + onSearch: this.handleDoSearch, + id: 'AssetSearchForm', + searchFormSchemaUrl: searchFormSchemaUrl, + folderId: this.getFolderId(), + filters: filters + }), + this.props.toolbarChildren + ) + ), + _react2.default.createElement( + 'div', + { className: 'flexbox-area-grow fill-width fill-height gallery' }, + this.renderGallery(), + this.renderEditor() + ) + ); + } + }]); + + return AssetAdmin; +}(_react.Component); + +AssetAdmin.propTypes = { + dialog: _react.PropTypes.bool, + sectionConfig: _configShape2.default, + fileId: _react.PropTypes.number, + folderId: _react.PropTypes.number, + onBrowse: _react.PropTypes.func, + onReplaceUrl: _react.PropTypes.func, + onInsertMany: _react.PropTypes.func, + graphQLErrors: _react.PropTypes.arrayOf(_react.PropTypes.string), + getUrl: _react.PropTypes.func, + query: _react.PropTypes.shape({ + sort: _react.PropTypes.string, + limit: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.string]), + page: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.string]), + filter: _react.PropTypes.object + }), + onSubmitEditor: _react.PropTypes.func, + type: _react.PropTypes.oneOf(['insert-media', 'insert-link', 'select', 'admin']), + files: _react.PropTypes.array, + queuedFiles: _react.PropTypes.shape({ + items: _react.PropTypes.array.isRequired + }), + filesTotalCount: _react.PropTypes.number, + folder: _react.PropTypes.shape({ + id: _react.PropTypes.number, + title: _react.PropTypes.string, + parents: _react.PropTypes.array, + parentId: _react.PropTypes.number, + canView: _react.PropTypes.bool, + canEdit: _react.PropTypes.bool + }), + loading: _react.PropTypes.bool, + actions: _react.PropTypes.object, + maxFiles: _react.PropTypes.number +}; + +AssetAdmin.defaultProps = { + type: 'admin', + query: { + sort: '', + limit: null, + page: 0, + filter: {} + }, + maxFiles: null +}; + +function mapStateToProps(state) { + return { + securityId: state.config.SecurityID, + + queuedFiles: state.assetAdmin.queuedFiles + }; +} + +function mapDispatchToProps(dispatch) { + return { + actions: { + gallery: (0, _redux.bindActionCreators)(galleryActions, dispatch), + breadcrumbsActions: (0, _redux.bindActionCreators)(breadcrumbsActions, dispatch), + + queuedFiles: (0, _redux.bindActionCreators)(queuedFilesActions, dispatch) + } + }; +} + +exports.Component = AssetAdmin; +exports.getFormSchema = getFormSchema; +exports.default = (0, _redux.compose)((0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps), (0, _Injector.injectGraphql)('ReadFilesQuery'), _deleteFilesMutation2.default, _unpublishFilesMutation2.default, _publishFilesMutation2.default, function (component) { + return (0, _reactApollo.withApollo)(component); +})(AssetAdmin); + +/***/ }), + +/***/ "./client/src/containers/AssetAdmin/AssetAdminRouter.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.buildUrl = exports.Component = undefined; + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactRedux = __webpack_require__(3); + +var _reactRouter = __webpack_require__(35); + +var _AssetAdmin = __webpack_require__("./client/src/containers/AssetAdmin/AssetAdmin.js"); + +var _AssetAdmin2 = _interopRequireDefault(_AssetAdmin); + +var _DataFormat = __webpack_require__(12); + +var _qs = __webpack_require__(39); + +var _qs2 = _interopRequireDefault(_qs); + +var _index = __webpack_require__("./client/src/constants/index.js"); + +var _index2 = _interopRequireDefault(_index); + +var _configShape = __webpack_require__("./client/src/lib/configShape.js"); + +var _configShape2 = _interopRequireDefault(_configShape); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var sectionConfigKey = 'SilverStripe\\AssetAdmin\\Controller\\AssetAdmin'; + +var actions = Object.keys(_index2.default.ACTIONS).map(function (key) { + return _index2.default.ACTIONS[key]; +}); + +function buildUrl(_ref) { + var base = _ref.base, + folderId = _ref.folderId, + fileId = _ref.fileId, + query = _ref.query, + action = _ref.action; + + if (action && actions.indexOf(action) === -1) { + throw new Error('Invalid action provided: ' + action); + } + + var url = null; + if (fileId) { + url = base + '/show/' + folderId + '/' + _index2.default.ACTIONS.EDIT_FILE + '/' + fileId; + } else if (folderId) { + url = base + '/show/' + folderId; + } else { + url = base + '/'; + } + + if (action === _index2.default.ACTIONS.CREATE_FOLDER) { + url = base + '/show/' + (folderId || 0) + '/' + action; + } + + var hasQuery = query && Object.keys(query).length > 0; + if (hasQuery) { + url = url + '?' + _qs2.default.stringify(query); + } + + return url; +} + +var AssetAdminRouter = function (_Component) { + _inherits(AssetAdminRouter, _Component); + + function AssetAdminRouter(props) { + _classCallCheck(this, AssetAdminRouter); + + var _this = _possibleConstructorReturn(this, (AssetAdminRouter.__proto__ || Object.getPrototypeOf(AssetAdminRouter)).call(this, props)); + + _this.handleBrowse = _this.handleBrowse.bind(_this); + _this.handleReplaceUrl = _this.handleReplaceUrl.bind(_this); + _this.getUrl = _this.getUrl.bind(_this); + return _this; + } + + _createClass(AssetAdminRouter, [{ + key: 'getUrl', + value: function getUrl() { + var folderId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; + var fileId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; + var query = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var action = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : _index2.default.ACTIONS.EDIT_FILE; + + var newFolderId = parseInt(folderId || 0, 10); + var newFileId = parseInt(fileId || 0, 10); + + var hasFolderChanged = newFolderId !== this.getFolderId(); + var newQuery = Object.assign({}, query); + if (hasFolderChanged || newQuery.page <= 1) { + delete newQuery.page; + } + + return buildUrl({ + base: this.props.sectionConfig.url, + folderId: newFolderId, + fileId: newFileId, + query: newQuery, + action: action + }); + } + }, { + key: 'getFolderId', + value: function getFolderId() { + if (this.props.params && this.props.params.folderId) { + return parseInt(this.props.params.folderId, 10); + } + return 0; + } + }, { + key: 'getFileId', + value: function getFileId() { + if (this.props.params && this.props.params.fileId) { + return parseInt(this.props.params.fileId, 10); + } + return 0; + } + }, { + key: 'getViewAction', + value: function getViewAction() { + if (this.props.params && this.props.params.viewAction) { + return this.props.params.viewAction; + } + return _index2.default.ACTIONS.EDIT_FILE; + } + }, { + key: 'getSectionProps', + value: function getSectionProps() { + return { + sectionConfig: this.props.sectionConfig, + type: 'admin', + folderId: this.getFolderId(), + viewAction: this.getViewAction(), + fileId: this.getFileId(), + query: this.getQuery(), + getUrl: this.getUrl, + onBrowse: this.handleBrowse, + onReplaceUrl: this.handleReplaceUrl + }; + } + }, { + key: 'getQuery', + value: function getQuery() { + return (0, _DataFormat.decodeQuery)(this.props.location.search); + } + }, { + key: 'handleBrowse', + value: function handleBrowse(folderId, fileId, query, action) { + var pathname = this.getUrl(folderId, fileId, query, action); + + this.props.router.push(pathname); + } + }, { + key: 'handleReplaceUrl', + value: function handleReplaceUrl(folderId, fileId, query, action) { + var pathname = this.getUrl(folderId, fileId, query, action); + + this.props.router.replace(pathname); + } + }, { + key: 'render', + value: function render() { + if (!this.props.sectionConfig) { + return null; + } + return _react2.default.createElement(_AssetAdmin2.default, this.getSectionProps()); + } + }]); + + return AssetAdminRouter; +}(_react.Component); + +AssetAdminRouter.propTypes = { + sectionConfig: _configShape2.default, + location: _react.PropTypes.shape({ + pathname: _react.PropTypes.string, + query: _react.PropTypes.object, + search: _react.PropTypes.string + }), + params: _react.PropTypes.object, + router: _react.PropTypes.object +}; + +function mapStateToProps(state) { + var sectionConfig = state.config.sections.find(function (section) { + return section.name === sectionConfigKey; + }); + + return { + sectionConfig: sectionConfig + }; +} + +exports.Component = AssetAdminRouter; +exports.buildUrl = buildUrl; +exports.default = (0, _reactRouter.withRouter)((0, _reactRedux.connect)(mapStateToProps)(AssetAdminRouter)); + +/***/ }), + +/***/ "./client/src/containers/AssetAdmin/stateRouter.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.AssetAdminStateRouter = undefined; + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactRedux = __webpack_require__(3); + +var _AssetAdminRouter = __webpack_require__("./client/src/containers/AssetAdmin/AssetAdminRouter.js"); + +var _index = __webpack_require__("./client/src/constants/index.js"); + +var _index2 = _interopRequireDefault(_index); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var sectionConfigKey = 'SilverStripe\\AssetAdmin\\Controller\\AssetAdmin'; + +var initialState = { + folderId: null, + fileId: null, + query: {}, + action: _index2.default.ACTIONS.EDIT_FILE +}; + +var AssetAdminStateRouter = function (_Component) { + _inherits(AssetAdminStateRouter, _Component); + + function AssetAdminStateRouter(props) { + _classCallCheck(this, AssetAdminStateRouter); + + var _this = _possibleConstructorReturn(this, (AssetAdminStateRouter.__proto__ || Object.getPrototypeOf(AssetAdminStateRouter)).call(this, props)); + + _this.handleBrowse = _this.handleBrowse.bind(_this); + _this.getUrl = _this.getUrl.bind(_this); + + _this.state = Object.assign({}, initialState, { folderId: props.folderId }); + return _this; + } + + _createClass(AssetAdminStateRouter, [{ + key: 'getUrl', + value: function getUrl() { + var folderId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; + var fileId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; + var query = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var action = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : _index2.default.ACTIONS.EDIT_FILE; + + var newFolderId = parseInt(folderId || 0, 10); + var newFileId = parseInt(fileId || 0, 10); + var oldFolderId = this.getFolderId(); + + var hasFolderChanged = newFolderId !== oldFolderId && oldFolderId !== null; + var newQuery = Object.assign({}, query); + if (hasFolderChanged || newQuery.page <= 1) { + delete newQuery.page; + } + + return (0, _AssetAdminRouter.buildUrl)({ + base: this.props.sectionConfig.url, + folderId: newFolderId, + fileId: newFileId, + query: newQuery, + action: action + }); + } + }, { + key: 'getFolderId', + value: function getFolderId() { + if (this.state.folderId === null) { + return null; + } + return parseInt(this.state.folderId || 0, 10); + } + }, { + key: 'getFileId', + value: function getFileId() { + return parseInt(this.state.fileId || this.props.fileId || 0, 10); + } + }, { + key: 'getViewAction', + value: function getViewAction() { + return this.state.action || _index2.default.ACTIONS.EDIT_FILE; + } + }, { + key: 'getSectionProps', + value: function getSectionProps() { + var props = Object.assign({}, this.props, { + folderId: this.getFolderId(), + fileId: this.getFileId(), + viewAction: this.getViewAction(), + query: this.state.query, + getUrl: this.getUrl, + onBrowse: this.handleBrowse + }); + + delete props.Component; + + return props; + } + }, { + key: 'handleBrowse', + value: function handleBrowse(folderId, fileId) { + var query = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var action = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : _index2.default.ACTIONS.EDIT_FILE; + + if (action && Object.values(_index2.default.ACTIONS).indexOf(action) === -1) { + throw new Error('Invalid action provided: ' + action); + } + + this.setState({ + folderId: folderId, + fileId: fileId, + query: query, + action: action + }); + } + }, { + key: 'render', + value: function render() { + var sectionProps = this.getSectionProps(); + var AssetAdmin = this.props.Component; + + return _react2.default.createElement(AssetAdmin, sectionProps); + } + }]); + + return AssetAdminStateRouter; +}(_react.Component); + +AssetAdminStateRouter.propTypes = { + Component: _react.PropTypes.oneOfType([_react.PropTypes.element, _react.PropTypes.func]), + sectionConfig: _react.PropTypes.shape({ + url: _react.PropTypes.string.isRequired + }).isRequired, + fileId: _react.PropTypes.number +}; + +function stateRouter(AssetAdmin) { + function mapStateToProps(state) { + var sectionConfig = state.config.sections.find(function (section) { + return section.name === sectionConfigKey; + }); + + return { + Component: AssetAdmin, + sectionConfig: sectionConfig + }; + } + + return (0, _reactRedux.connect)(mapStateToProps)(AssetAdminStateRouter); +} + +exports.AssetAdminStateRouter = AssetAdminStateRouter; +exports.default = stateRouter; + +/***/ }), + +/***/ "./client/src/containers/Editor/Editor.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _reactRedux = __webpack_require__(3); + +var _redux = __webpack_require__(4); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _index = __webpack_require__("./client/src/constants/index.js"); + +var _index2 = _interopRequireDefault(_index); + +var _FormBuilderLoader = __webpack_require__(18); + +var _FormBuilderLoader2 = _interopRequireDefault(_FormBuilderLoader); + +var _FormBuilderModal = __webpack_require__(11); + +var _FormBuilderModal2 = _interopRequireDefault(_FormBuilderModal); + +var _UnsavedFormsActions = __webpack_require__(38); + +var UnsavedFormsActions = _interopRequireWildcard(_UnsavedFormsActions); + +var _fileShape = __webpack_require__("./client/src/lib/fileShape.js"); + +var _fileShape2 = _interopRequireDefault(_fileShape); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var Editor = function (_Component) { + _inherits(Editor, _Component); + + function Editor(props) { + _classCallCheck(this, Editor); + + var _this = _possibleConstructorReturn(this, (Editor.__proto__ || Object.getPrototypeOf(Editor)).call(this, props)); + + _this.handleCancelKeyDown = _this.handleCancelKeyDown.bind(_this); + _this.handleClose = _this.handleClose.bind(_this); + _this.handleSubmit = _this.handleSubmit.bind(_this); + _this.handleAction = _this.handleAction.bind(_this); + _this.handleLoadingSuccess = _this.handleLoadingSuccess.bind(_this); + _this.handleLoadingError = _this.handleLoadingError.bind(_this); + _this.handleFetchingSchema = _this.handleFetchingSchema.bind(_this); + _this.closeModal = _this.closeModal.bind(_this); + _this.openModal = _this.openModal.bind(_this); + + _this.state = { + openModal: false, + loadingForm: false, + loadingError: null + }; + return _this; + } + + _createClass(Editor, [{ + key: 'handleAction', + value: function handleAction(event, data) { + var name = event.currentTarget.name; + + if (name === 'action_addtocampaign') { + this.openModal(); + event.preventDefault(); + return; + } + + if (name === 'action_delete') { + var message = _i18n2.default._t('AssetAdmin.CONFIRMDELETE', 'Are you sure you want to delete this record?'); + if (this.props.file && this.props.file.inUseCount > 0) { + message = _i18n2.default.sprintf(_i18n2.default._t('AssetAdmin.BULK_ACTIONS_DELETE_SINGLE_CONFIRM', 'This file is currently used in %s place(s), are you sure you want to delete it?'), this.props.file.inUseCount); + message += '\n\n'; + message += _i18n2.default._t('AssetAdmin.BULK_ACTIONS_DELETE_WARNING', 'Ensure files are removed from content areas prior to deleting them,' + ' otherwise they will appear as broken links.'); + } + + if (confirm(message)) { + this.props.actions.unsavedForms.removeFormChanged('AssetAdmin.EditForm'); + this.props.onDelete([data.ID]); + } + event.preventDefault(); + } + } + }, { + key: 'handleCancelKeyDown', + value: function handleCancelKeyDown(event) { + if (event.keyCode === _index2.default.SPACE_KEY_CODE || event.keyCode === _index2.default.RETURN_KEY_CODE) { + this.handleClose(event); + } + } + }, { + key: 'handleSubmit', + value: function handleSubmit(data, action, submitFn) { + if (typeof this.props.onSubmit === 'function') { + return this.props.onSubmit(data, action, submitFn); + } + + return submitFn(); + } + }, { + key: 'handleClose', + value: function handleClose(event) { + this.props.onClose(); + this.closeModal(); + + if (event) { + event.preventDefault(); + } + } + }, { + key: 'openModal', + value: function openModal() { + this.setState({ + openModal: true + }); + } + }, { + key: 'closeModal', + value: function closeModal() { + this.setState({ + openModal: false + }); + } + }, { + key: 'handleLoadingError', + value: function handleLoadingError(exception) { + this.setState({ + loadingForm: false, + loadingError: exception.errors[0] + }); + } + }, { + key: 'handleLoadingSuccess', + value: function handleLoadingSuccess() { + this.setState({ + loadingForm: false, + loadingError: null + }); + } + }, { + key: 'handleFetchingSchema', + value: function handleFetchingSchema() { + this.setState({ + loadingForm: true + }); + } + }, { + key: 'renderCancelButton', + value: function renderCancelButton() { + return _react2.default.createElement('a', { + role: 'button', + tabIndex: 0, + className: 'btn btn--close-panel btn--no-text font-icon-cancel btn--icon-xl', + onClick: this.handleClose, + onKeyDown: this.handleCancelKeyDown, + type: 'button', + 'aria-label': _i18n2.default._t('AssetAdmin.CANCEL') + }); + } + }, { + key: 'render', + value: function render() { + var urlQueryString = this.props.schemaUrlQueries.map(function (query) { + return query.name + '=' + query.value; + }).join('&').trim(); + urlQueryString = urlQueryString ? '?' + urlQueryString : ''; + var formSchemaUrl = this.props.schemaUrl + '/' + this.props.targetId + urlQueryString; + var modalSchemaUrl = this.props.addToCampaignSchemaUrl + '/' + this.props.targetId; + var editorClasses = ['panel', 'form--no-dividers', 'editor']; + if (this.props.className) { + editorClasses.push(this.props.className); + } + + var error = null; + if (this.state.loadingError) { + var message = this.state.loadingError.value; + if (this.state.loadingError.code === 404) { + message = _i18n2.default._t('AssetAdmin.FILE_MISSING', 'File cannot be found'); + } + if (!message) { + message = _i18n2.default._t('Admin.UNKNOWN_ERROR', 'An unknown error has occurred'); + } + error = _react2.default.createElement( + 'div', + { className: 'editor__file-preview-message--file-missing' }, + message + ); + } + var campaignTitle = _i18n2.default._t('Admin.ADD_TO_CAMPAIGN', 'Add to campaign'); + + return _react2.default.createElement( + 'div', + { className: editorClasses.join(' ') }, + _react2.default.createElement( + 'div', + { className: 'editor__details fill-height' }, + _react2.default.createElement(_FormBuilderLoader2.default, { + identifier: 'AssetAdmin.EditForm', + schemaUrl: formSchemaUrl, + afterMessages: this.renderCancelButton(), + onSubmit: this.handleSubmit, + onAction: this.handleAction, + onLoadingSuccess: this.handleLoadingSuccess, + onLoadingError: this.handleLoadingError, + onFetchingSchema: this.handleFetchingSchema + }), + error, + _react2.default.createElement(_FormBuilderModal2.default, { + title: campaignTitle, + identifier: 'AssetAdmin.AddToCampaign', + isOpen: this.state.openModal, + onClosed: this.closeModal, + schemaUrl: modalSchemaUrl, + bodyClassName: 'modal__dialog', + responseClassBad: 'modal__response modal__response--error', + responseClassGood: 'modal__response modal__response--good' + }), + this.state.loadingForm && [_react2.default.createElement('div', { key: 'overlay', className: 'cms-content-loading-overlay ui-widget-overlay-light' }), _react2.default.createElement('div', { key: 'spinner', className: 'cms-content-loading-spinner' })] + ) + ); + } + }]); + + return Editor; +}(_react.Component); + +Editor.propTypes = { + file: _fileShape2.default, + className: _react.PropTypes.string, + targetId: _react.PropTypes.number.isRequired, + onClose: _react.PropTypes.func.isRequired, + onSubmit: _react.PropTypes.func.isRequired, + onDelete: _react.PropTypes.func.isRequired, + + schemaUrl: _react.PropTypes.string.isRequired, + schemaUrlQueries: _react.PropTypes.arrayOf(_react.PropTypes.shape({ + name: _react.PropTypes.string, + value: _react.PropTypes.any + })), + addToCampaignSchemaUrl: _react.PropTypes.string, + actions: _react.PropTypes.object +}; + +function mapDispatchToProps(dispatch) { + return { + actions: { + unsavedForms: (0, _redux.bindActionCreators)(UnsavedFormsActions, dispatch) + } + }; +} + +exports.Component = Editor; +exports.default = (0, _reactRedux.connect)(function () { + return {}; +}, mapDispatchToProps)(Editor); + +/***/ }), + +/***/ "./client/src/containers/Gallery/Gallery.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.galleryViewDefaultProps = exports.galleryViewPropTypes = exports.Component = undefined; + +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"); } }; }(); + +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; }; }(); + +var _jquery = __webpack_require__(6); + +var _jquery2 = _interopRequireDefault(_jquery); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactDom = __webpack_require__(5); + +var _reactDom2 = _interopRequireDefault(_reactDom); + +var _reactAddonsTestUtils = __webpack_require__(33); + +var _reactAddonsTestUtils2 = _interopRequireDefault(_reactAddonsTestUtils); + +var _reactAddonsCssTransitionGroup = __webpack_require__(32); + +var _reactAddonsCssTransitionGroup2 = _interopRequireDefault(_reactAddonsCssTransitionGroup); + +var _reactRedux = __webpack_require__(3); + +var _redux = __webpack_require__(4); + +var _AssetDropzone = __webpack_require__("./client/src/components/AssetDropzone/AssetDropzone.js"); + +var _AssetDropzone2 = _interopRequireDefault(_AssetDropzone); + +var _BulkActions = __webpack_require__("./client/src/components/BulkActions/BulkActions.js"); + +var _BulkActions2 = _interopRequireDefault(_BulkActions); + +var _ThumbnailView = __webpack_require__("./client/src/containers/ThumbnailView/ThumbnailView.js"); + +var _ThumbnailView2 = _interopRequireDefault(_ThumbnailView); + +var _TableView = __webpack_require__("./client/src/containers/TableView/TableView.js"); + +var _TableView2 = _interopRequireDefault(_TableView); + +var _index = __webpack_require__("./client/src/constants/index.js"); + +var _index2 = _interopRequireDefault(_index); + +var _FormAlert = __webpack_require__(31); + +var _FormAlert2 = _interopRequireDefault(_FormAlert); + +var _GalleryActions = __webpack_require__("./client/src/state/gallery/GalleryActions.js"); + +var galleryActions = _interopRequireWildcard(_GalleryActions); + +var _QueuedFilesActions = __webpack_require__("./client/src/state/queuedFiles/QueuedFilesActions.js"); + +var queuedFilesActions = _interopRequireWildcard(_QueuedFilesActions); + +var _moveFilesMutation = __webpack_require__("./client/src/state/files/moveFilesMutation.js"); + +var _moveFilesMutation2 = _interopRequireDefault(_moveFilesMutation); + +var _reactApollo = __webpack_require__(8); + +var _reactSelectable = __webpack_require__("../../../node_modules/react-selectable/dist/react-selectable.js"); + +var _GalleryDND = __webpack_require__("./client/src/containers/Gallery/GalleryDND.js"); + +var _GalleryDND2 = _interopRequireDefault(_GalleryDND); + +var _configShape = __webpack_require__("./client/src/lib/configShape.js"); + +var _configShape2 = _interopRequireDefault(_configShape); + +var _MoveModal = __webpack_require__("./client/src/containers/MoveModal/MoveModal.js"); + +var _MoveModal2 = _interopRequireDefault(_MoveModal); + +var _Injector = __webpack_require__(2); + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var Gallery = function (_Component) { + _inherits(Gallery, _Component); + + function Gallery(props) { + _classCallCheck(this, Gallery); + + var _this = _possibleConstructorReturn(this, (Gallery.__proto__ || Object.getPrototypeOf(Gallery)).call(this, props)); + + _this.handleOpenFolder = _this.handleOpenFolder.bind(_this); + _this.handleOpenFile = _this.handleOpenFile.bind(_this); + _this.handleSelect = _this.handleSelect.bind(_this); + _this.handleAddedFile = _this.handleAddedFile.bind(_this); + _this.handlePreviewLoaded = _this.handlePreviewLoaded.bind(_this); + _this.handleCancelUpload = _this.handleCancelUpload.bind(_this); + _this.handleRemoveErroredUpload = _this.handleRemoveErroredUpload.bind(_this); + _this.handleUploadProgress = _this.handleUploadProgress.bind(_this); + _this.handleSending = _this.handleSending.bind(_this); + _this.handleSort = _this.handleSort.bind(_this); + _this.handleSetPage = _this.handleSetPage.bind(_this); + _this.handleSuccessfulUpload = _this.handleSuccessfulUpload.bind(_this); + _this.handleFailedUpload = _this.handleFailedUpload.bind(_this); + _this.handleClearSearch = _this.handleClearSearch.bind(_this); + _this.handleEnableDropzone = _this.handleEnableDropzone.bind(_this); + _this.handleMoveFiles = _this.handleMoveFiles.bind(_this); + _this.handleBulkEdit = _this.handleBulkEdit.bind(_this); + _this.handleBulkPublish = _this.handleBulkPublish.bind(_this); + _this.handleBulkUnpublish = _this.handleBulkUnpublish.bind(_this); + _this.handleBulkDelete = _this.handleBulkDelete.bind(_this); + _this.handleBulkMove = _this.handleBulkMove.bind(_this); + _this.handleBulkInsert = _this.handleBulkInsert.bind(_this); + _this.handleGroupSelect = _this.handleGroupSelect.bind(_this); + _this.handleClearSelection = _this.handleClearSelection.bind(_this); + _this.toggleSelectConcat = _this.toggleSelectConcat.bind(_this); + _this.getSelectableFiles = _this.getSelectableFiles.bind(_this); + return _this; + } + + _createClass(Gallery, [{ + key: 'componentDidMount', + value: function componentDidMount() { + this.initSortDropdown(); + window.addEventListener('keydown', this.toggleSelectConcat); + window.addEventListener('keyup', this.toggleSelectConcat); + } + }, { + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(nextProps) { + if (nextProps.view !== 'tile') { + var $select = this.getSortElement(); + + $select.off('change'); + } + + if (this.props.folderId !== nextProps.folderId) { + nextProps.actions.queuedFiles.purgeUploadQueue(); + } + } + }, { + key: 'componentDidUpdate', + value: function componentDidUpdate() { + this.initSortDropdown(); + } + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + window.removeEventListener('keydown', this.toggleSelectConcat); + window.removeEventListener('keyup', this.toggleSelectConcat); + } + }, { + key: 'getSortElement', + value: function getSortElement() { + return (0, _jquery2.default)(_reactDom2.default.findDOMNode(this)).find('.gallery__sort .dropdown'); + } + }, { + key: 'getSearchMessage', + value: function getSearchMessage(filters) { + var messages = []; + if (filters.name) { + messages.push(_i18n2.default._t('AssetAdmin.SEARCHRESULTSMESSAGEKEYWORDS', 'with keywords \'{name}\'')); + } + + if (filters.lastEditedFrom && filters.lastEditedTo) { + messages.push(_i18n2.default._t('AssetAdmin.SEARCHRESULTSMESSAGEEDITEDBETWEEN', 'last edited between \'{lastEditedFrom}\' and \'{lastEditedTo}\'')); + } else if (filters.lastEditedFrom) { + messages.push(_i18n2.default._t('AssetAdmin.SEARCHRESULTSMESSAGEEDITEDFROM', 'last edited after \'{lastEditedFrom}\'')); + } else if (filters.lastEditedTo) { + messages.push(_i18n2.default._t('AssetAdmin.SEARCHRESULTSMESSAGEEDITEDTO', 'last edited before \'{lastEditedTo}\'')); + } + + if (filters.appCategory) { + messages.push(_i18n2.default._t('AssetAdmin.SEARCHRESULTSMESSAGECATEGORY', 'categorised as \'{appCategory}\'')); + } + + if (filters.currentFolderOnly && this.props.folder.title) { + messages.push(_i18n2.default._t('AssetAdmin.SEARCHRESULTSMESSAGELIMIT', 'limited to the folder \'{folder}\'')); + } + + var parts = [messages.slice(0, -1).join(_i18n2.default._t('AssetAdmin.JOIN', ',') + ' '), messages.slice(-1)].filter(function (part) { + return part; + }).join(' ' + _i18n2.default._t('AssetAdmin.JOINLAST', 'and') + ' '); + + if (parts === '') { + return ''; + } + + var searchResults = { + parts: _i18n2.default.inject(parts, Object.assign({ folder: this.props.folder.title }, filters, { appCategory: filters.appCategory ? filters.appCategory.toLowerCase() : undefined })) + }; + + return _i18n2.default.inject(_i18n2.default._t('AssetAdmin.SEARCHRESULTSMESSAGE', 'Search results {parts}'), searchResults); + } + }, { + key: 'getSelection', + value: function getSelection(firstId, lastId) { + var selectable = this.getSelectableFiles(); + var indexes = [firstId, lastId].map(function (id) { + return selectable.findIndex(function (file) { + return file.id === id; + }); + }).filter(function (index) { + return index !== -1; + }).sort(function (a, b) { + return a - b; + }); + + if (indexes.length !== 2) { + return indexes.map(function (index) { + return selectable[index].id; + }); + } + + var _indexes = _slicedToArray(indexes, 2), + firstIndex = _indexes[0], + lastIndex = _indexes[1]; + + return selectable.filter(function (file, index) { + return index >= firstIndex && index <= lastIndex; + }).map(function (file) { + return file.id; + }); + } + }, { + key: 'getSelectableFiles', + value: function getSelectableFiles() { + var selectable = this.props.files.filter(function (file) { + return file.id; + }); + + if (this.props.type === 'select') { + return selectable.filter(function (item) { + return item.type !== 'folder'; + }); + } + + return selectable; + } + }, { + key: 'handleBulkInsert', + value: function handleBulkInsert(event, items) { + this.props.onInsertMany(event, items); + } + }, { + key: 'handleBulkDelete', + value: function handleBulkDelete(event, items) { + var _this2 = this; + + return this.props.onDelete(items.map(function (item) { + return item.id; + })).then(function (resultItems) { + var successes = resultItems.filter(function (result) { + return result; + }).length; + if (successes !== items.length) { + _this2.props.actions.gallery.setErrorMessage(_i18n2.default.sprintf(_i18n2.default._t('AssetAdmin.BULK_ACTIONS_DELETE_FAIL', '%s folders/files were successfully deleted, but %s files were not able to be deleted.'), successes, items.length - successes)); + _this2.props.actions.gallery.setNoticeMessage(null); + } else { + _this2.props.actions.gallery.setNoticeMessage(_i18n2.default.sprintf(_i18n2.default._t('AssetAdmin.BULK_ACTIONS_DELETE_SUCCESS', '%s folders/files were successfully deleted.'), successes)); + _this2.props.actions.gallery.setErrorMessage(null); + _this2.props.actions.gallery.deselectFiles(); + } + }); + } + }, { + key: 'handleBulkPublish', + value: function handleBulkPublish(event, items) { + var _this3 = this; + + var publishItems = items.map(function (item) { + return item.id; + }); + if (!publishItems.length) { + this.props.actions.gallery.deselectFiles(); + + return Promise.resolve(true); + } + this.props.actions.gallery.setLoading(true); + + return this.props.onPublish(publishItems).then(function (resultItems) { + _this3.props.actions.gallery.setLoading(false); + _this3.props.actions.gallery.setNoticeMessage(_i18n2.default.sprintf(_i18n2.default._t('AssetAdmin.BULK_ACTIONS_PUBLISH_SUCCESS', '%s folders/files were successfully published.'), resultItems.length)); + _this3.props.actions.gallery.setErrorMessage(null); + _this3.props.actions.gallery.deselectFiles(); + }); + } + }, { + key: 'handleBulkUnpublish', + value: function handleBulkUnpublish(event, items) { + var _this4 = this; + + var unpublishItems = items.filter(function (item) { + return item.published; + }).map(function (item) { + return item.id; + }); + if (!unpublishItems.length) { + this.props.actions.gallery.deselectFiles(); + + return Promise.resolve(true); + } + this.props.actions.gallery.setLoading(true); + + return this.props.onUnpublish(unpublishItems).then(function (resultItems) { + _this4.props.actions.gallery.setLoading(false); + _this4.props.actions.gallery.setNoticeMessage(_i18n2.default.sprintf(_i18n2.default._t('AssetAdmin.BULK_ACTIONS_UNPUBLISH_SUCCESS', '%s folders/files were successfully unpublished.'), resultItems.length)); + _this4.props.actions.gallery.setErrorMessage(null); + _this4.props.actions.gallery.deselectFiles(); + }); + } + }, { + key: 'initSortDropdown', + value: function initSortDropdown() { + if (this.props.view === 'tile') { + var $select = this.getSortElement(); + + $select.chosen({ + allow_single_deselect: true, + disable_search_threshold: 20 + }); + + $select.off('change'); + + $select.on('change', function () { + return _reactAddonsTestUtils2.default.Simulate.click($select.find(':selected')[0]); + }); + } + } + }, { + key: 'handleSort', + value: function handleSort(value) { + this.props.actions.queuedFiles.purgeUploadQueue(); + this.props.onSort(value); + } + }, { + key: 'handleSetPage', + value: function handleSetPage(page) { + this.props.onSetPage(page); + } + }, { + key: 'handleCancelUpload', + value: function handleCancelUpload(fileData) { + fileData.xhr.abort(); + this.props.actions.queuedFiles.removeQueuedFile(fileData.queuedId); + } + }, { + key: 'handleRemoveErroredUpload', + value: function handleRemoveErroredUpload(fileData) { + this.props.actions.queuedFiles.removeQueuedFile(fileData.queuedId); + } + }, { + key: 'handleAddedFile', + value: function handleAddedFile(fileData) { + this.props.actions.queuedFiles.addQueuedFile(fileData); + } + }, { + key: 'handlePreviewLoaded', + value: function handlePreviewLoaded(fileData, previewData) { + this.props.actions.queuedFiles.updateQueuedFile(fileData.queuedId, previewData); + } + }, { + key: 'handleSending', + value: function handleSending(file, xhr) { + this.props.actions.queuedFiles.updateQueuedFile(file._queuedId, { xhr: xhr }); + } + }, { + key: 'handleUploadProgress', + value: function handleUploadProgress(file, progress) { + this.props.actions.queuedFiles.updateQueuedFile(file._queuedId, { progress: progress }); + } + }, { + key: 'handleSuccessfulUpload', + value: function handleSuccessfulUpload(fileXhr) { + var json = JSON.parse(fileXhr.xhr.response); + + if (typeof json[0].error !== 'undefined') { + this.handleFailedUpload(fileXhr); + return; + } + + this.props.actions.queuedFiles.succeedUpload(fileXhr._queuedId, json[0]); + + if (this.props.onSuccessfulUpload) { + this.props.onSuccessfulUpload(json); + } + + if (this.props.type !== 'admin' && !this.props.fileId && this.props.queuedFiles.items.length === 0) { + var lastFile = json.pop(); + this.props.onOpenFile(lastFile.id); + } + } + }, { + key: 'handleFailedUpload', + value: function handleFailedUpload(fileXhr, response) { + this.props.actions.queuedFiles.failUpload(fileXhr._queuedId, response); + } + }, { + key: 'itemIsSelected', + value: function itemIsSelected(id) { + return this.props.selectedFiles.indexOf(id) > -1; + } + }, { + key: 'toggleSelectConcat', + value: function toggleSelectConcat(event) { + this.props.actions.gallery.setConcatenateSelect(this.isConcat(event)); + } + }, { + key: 'isConcat', + value: function isConcat(event) { + return event.metaKey || event.ctrlKey || event.shiftKey; + } + }, { + key: 'itemIsHighlighted', + value: function itemIsHighlighted(id) { + return this.props.fileId === id; + } + }, { + key: 'hasOpenedItem', + value: function hasOpenedItem() { + return !!this.props.fileId; + } + }, { + key: 'handleClearSearch', + value: function handleClearSearch(event) { + this.props.onClearSearch(event); + } + }, { + key: 'handleGroupSelect', + value: function handleGroupSelect(items, event) { + var _this5 = this; + + var _props$actions$galler = this.props.actions.gallery, + setSelectedFiles = _props$actions$galler.setSelectedFiles, + selectFiles = _props$actions$galler.selectFiles; + + var selectableFiles = this.getSelectableFiles(); + + var selectItems = items.filter(function (id, index) { + if (items.indexOf(id) !== index) { + return false; + } + return selectableFiles.find(function (file) { + return file.id === id; + }); + }); + + var concat = this.props.concatenateSelect || this.isConcat(event); + + if (this.props.maxFilesSelect !== null) { + var totalFiles = selectItems.length; + if (concat) { + var totalSelected = this.props.selectedFiles.filter(function (id) { + return !_this5.props.selectedFiles.includes(id); + }).concat(this.props.selectedFiles); + + totalFiles = totalSelected.length; + } + + if (totalFiles >= this.props.maxFilesSelect) { + return; + } + } + + if (concat) { + setSelectedFiles(selectItems); + } else { + selectFiles(selectItems); + } + } + }, { + key: 'handleClearSelection', + value: function handleClearSelection() { + this.props.actions.gallery.deselectFiles(); + } + }, { + key: 'handleOpenFolder', + value: function handleOpenFolder(event, folder) { + event.preventDefault(); + this.props.actions.gallery.setErrorMessage(null); + this.props.actions.gallery.setNoticeMessage(null); + this.props.onOpenFolder(folder.id); + } + }, { + key: 'handleOpenFile', + value: function handleOpenFile(event, file) { + event.preventDefault(); + + if (file.created === null) { + return; + } + + if ((!this.props.selectedFiles.length || this.props.maxFilesSelect === 1) && this.props.type === 'select') { + this.handleSelect(event, file); + } + + this.props.onOpenFile(file.id, file); + } + }, { + key: 'handleSelect', + value: function handleSelect(event, item) { + var maxFiles = this.props.maxFilesSelect; + var selectable = this.getSelectableFiles(); + var selectedItemIDs = selectable.filter(function (file) { + return file.id === item.id; + }).map(function (file) { + return file.id; + }); + + if (maxFiles === 1) { + this.props.actions.gallery.setSelectedFiles(selectedItemIDs); + return; + } + + if (this.props.selectedFiles.indexOf(item.id) === -1) { + if (event.shiftKey) { + selectedItemIDs = this.getSelection(this.props.lastSelected, item.id); + } + + var totalSelected = this.props.selectedFiles.filter(function (id) { + return !selectedItemIDs.includes(id); + }).concat(selectedItemIDs); + + if (totalSelected.length > maxFiles && maxFiles !== null) { + return; + } + + this.props.actions.gallery.selectFiles(selectedItemIDs); + this.props.actions.gallery.setLastSelected(item.id); + } else { + this.props.actions.gallery.deselectFiles([item.id]); + + if (event.shiftKey) { + this.props.actions.gallery.setLastSelected(null); + } + } + } + }, { + key: 'handleEnableDropzone', + value: function handleEnableDropzone(enabled) { + this.props.actions.gallery.setEnableDropzone(enabled); + } + }, { + key: 'handleMoveFiles', + value: function handleMoveFiles(folderId, fileIds) { + var _this6 = this; + + this.props.actions.files.moveFiles(folderId, fileIds).then(function () { + var duration = _index2.default.MOVE_SUCCESS_DURATION; + var message = '+' + fileIds.length; + + _this6.props.actions.gallery.setFileBadge(folderId, message, 'success', duration); + + if (typeof _this6.props.onMoveFilesSuccess === 'function') { + _this6.props.onMoveFilesSuccess(folderId, fileIds); + } + }).catch(function () { + _this6.props.actions.gallery.setErrorMessage(_i18n2.default._t('AssetAdmin.FAILED_MOVE', 'There was an error moving the selected items.')); + }); + } + }, { + key: 'handleBulkEdit', + value: function handleBulkEdit(event, items) { + this.handleOpenFile(event, items[0]); + } + }, { + key: 'handleBulkMove', + value: function handleBulkMove() { + this.props.actions.gallery.activateModal(_index2.default.MODAL_MOVE); + } + }, { + key: 'renderSearchAlert', + value: function renderSearchAlert() { + var filters = this.props.filters; + if (!filters || Object.keys(filters).length === 0) { + return null; + } + + var message = this.getSearchMessage(filters); + + if (message === '') { + return null; + } + + var body = _react2.default.createElement( + 'div', + null, + _react2.default.createElement( + 'button', + { + onClick: this.handleClearSearch, + className: 'btn btn-info font-icon-cancel form-alert__btn--right' + }, + _i18n2.default._t('AssetAdmin.SEARCHCLEARRESULTS', 'Clear results') + ), + message + ); + + return _react2.default.createElement(_FormAlert2.default, { value: { react: body }, type: 'warning' }); + } + }, { + key: 'renderTransitionBulkActions', + value: function renderTransitionBulkActions() { + return _react2.default.createElement( + _reactAddonsCssTransitionGroup2.default, + { + transitionName: 'bulk-actions', + transitionEnterTimeout: _index2.default.CSS_TRANSITION_TIME, + transitionLeaveTimeout: _index2.default.CSS_TRANSITION_TIME + }, + this.renderBulkActions() + ); + } + }, { + key: 'renderBulkActions', + value: function renderBulkActions() { + var _this7 = this; + + var actionFilter = this.props.type === 'select' ? function (action) { + return action.value === 'insert'; + } : function (action) { + return action.value !== 'insert'; + }; + + var actions = _index2.default.BULK_ACTIONS.filter(actionFilter).map(function (action) { + if (action.callback) { + return action; + } + switch (action.value) { + case 'delete': + { + return _extends({}, action, { callback: _this7.handleBulkDelete }); + } + case 'edit': + { + return _extends({}, action, { callback: _this7.handleBulkEdit }); + } + case 'move': + { + return _extends({}, action, { callback: _this7.handleBulkMove }); + } + case 'publish': + { + return _extends({}, action, { callback: _this7.handleBulkPublish }); + } + case 'unpublish': + { + return _extends({}, action, { callback: _this7.handleBulkUnpublish }); + } + case 'insert': + { + return _extends({}, action, { callback: _this7.handleBulkInsert }); + } + default: + { + return action; + } + } + }); + + var selected = this.props.selectedFiles.map(function (id) { + return _this7.props.files.find(function (file) { + return file && id === file.id; + }); + }).filter(function (item) { + return item; + }); + + if (selected.length > 0 && ['admin', 'select'].includes(this.props.type)) { + return _react2.default.createElement(_BulkActions2.default, { + actions: actions, + items: selected, + total: this.props.maxFilesSelect, + key: selected.length > 0, + container: this.gallery, + showCount: this.props.maxFilesSelect !== 1 + }); + } + + return null; + } + }, { + key: 'renderGalleryView', + value: function renderGalleryView() { + var _this8 = this; + + var GalleryView = this.props.view === 'table' ? _TableView2.default : _ThumbnailView2.default; + var files = this.props.files.map(function (file) { + return _extends({}, file, { + selected: _this8.itemIsSelected(file.id), + highlighted: _this8.itemIsHighlighted(file.id) + }); + }); + var _props = this.props, + type = _props.type, + loading = _props.loading, + page = _props.page, + totalCount = _props.totalCount, + limit = _props.limit, + sort = _props.sort, + selectedFiles = _props.selectedFiles, + badges = _props.badges; + + + var props = { + selectableItems: ['admin', 'select'].includes(type), + selectableFolders: this.props.type !== 'select', + files: files, + loading: loading, + page: page, + totalCount: totalCount, + limit: limit, + sort: sort, + selectedFiles: selectedFiles, + badges: badges, + onSort: this.handleSort, + onSetPage: this.handleSetPage, + onOpenFile: this.handleOpenFile, + onOpenFolder: this.handleOpenFolder, + onSelect: this.handleSelect, + onCancelUpload: this.handleCancelUpload, + onDropFiles: this.handleMoveFiles, + onRemoveErroredUpload: this.handleRemoveErroredUpload, + onEnableDropzone: this.handleEnableDropzone, + sectionConfig: this.props.sectionConfig, + canDrag: this.props.type === 'admin', + maxFilesSelect: this.props.maxFilesSelect + }; + + return _react2.default.createElement(GalleryView, props); + } + }, { + key: 'renderToolbar', + value: function renderToolbar() { + var _props2 = this.props, + GalleryToolbar = _props2.GalleryToolbar, + sort = _props2.sort, + view = _props2.view, + folder = _props2.folder, + onCreateFolder = _props2.onCreateFolder, + onOpenFolder = _props2.onOpenFolder, + onViewChange = _props2.onViewChange; + + + var props = { + onMoveFiles: this.handleMoveFiles, + onSort: this.handleSort, + onCreateFolder: onCreateFolder, + onOpenFolder: onOpenFolder, + onViewChange: onViewChange, + view: view, + sort: sort, + folder: folder + }; + + return _react2.default.createElement(GalleryToolbar, props); + } + }, { + key: 'render', + value: function render() { + var _this9 = this; + + var _props3 = this.props, + folder = _props3.folder, + loading = _props3.loading, + errorMessage = _props3.errorMessage, + graphQLErrors = _props3.graphQLErrors, + noticeMessage = _props3.noticeMessage; + + var hasGraphQLErrors = graphQLErrors && graphQLErrors.length > 0; + + if (!folder) { + if (errorMessage || hasGraphQLErrors) { + return _react2.default.createElement( + 'div', + { className: 'gallery__error flexbox-area-grow' }, + _react2.default.createElement( + 'div', + { className: 'gallery__error-message' }, + _react2.default.createElement( + 'h3', + null, + _i18n2.default._t('AssetAdmin.DROPZONE_RESPONSE_ERROR', 'Server responded with an error.') + ), + errorMessage && _react2.default.createElement( + 'p', + null, + errorMessage + ), + hasGraphQLErrors && graphQLErrors.map(function (error, index) { + return _react2.default.createElement( + 'p', + { key: index }, + error + ); + }) + ) + ); + } + if (loading) { + return _react2.default.createElement( + 'div', + { className: 'flexbox-area-grow' }, + _react2.default.createElement('div', { key: 'overlay', className: 'cms-content-loading-overlay ui-widget-overlay-light' }), + _react2.default.createElement('div', { key: 'spinner', className: 'cms-content-loading-spinner' }) + ); + } + return _react2.default.createElement( + 'div', + { className: 'flexbox-area-grow' }, + _react2.default.createElement( + 'div', + { className: 'editor__file-preview-message--file-missing m-t-3' }, + _i18n2.default._t('Admin.UNKNOWN_ERROR', 'An unknown error has occurred') + ) + ); + } + + var messages = _react2.default.createElement( + 'div', + { className: 'gallery_messages' }, + errorMessage && _react2.default.createElement(_FormAlert2.default, { value: errorMessage, type: 'danger' }), + noticeMessage && _react2.default.createElement(_FormAlert2.default, { value: noticeMessage, type: 'success' }), + this.renderSearchAlert() + ); + + var dimensions = { + height: _index2.default.THUMBNAIL_HEIGHT, + width: _index2.default.THUMBNAIL_WIDTH + }; + var dropzoneOptions = _extends({ + url: this.props.createFileApiUrl, + method: this.props.createFileApiMethod, + paramName: 'Upload', + clickable: '#upload-button' + }, this.props.sectionConfig.dropzoneOptions); + + var securityID = this.props.securityId; + var canEdit = this.props.folder.canEdit && this.props.enableDropzone; + + var galleryClasses = ['panel', 'panel--padded', 'panel--scrollable', 'gallery__main', 'fill-height']; + if (this.props.type === 'insert') { + galleryClasses.push('insert-media-modal__main'); + } + + var cssClasses = galleryClasses; + if (this.hasOpenedItem()) { + cssClasses.push('gallery__main--has-opened-item'); + } + + return _react2.default.createElement( + 'div', + { + className: 'flexbox-area-grow gallery__outer', + ref: function ref(gallery) { + _this9.gallery = gallery; + } + }, + this.renderTransitionBulkActions(), + _react2.default.createElement( + _GalleryDND2.default, + { className: galleryClasses.join(' ') }, + this.renderToolbar(), + _react2.default.createElement( + _reactSelectable.SelectableGroup, + { + enabled: this.props.view === 'tile' && this.props.type === 'admin', + className: 'flexbox-area-grow fill-height gallery__main--selectable', + onSelection: this.handleGroupSelect, + onNonItemClick: this.handleClearSelection, + preventDefault: false, + fixedPosition: true + }, + _react2.default.createElement( + _AssetDropzone2.default, + { + name: 'gallery-container', + className: 'flexbox-area-grow', + canUpload: canEdit, + onAddedFile: this.handleAddedFile, + onPreviewLoaded: this.handlePreviewLoaded, + onError: this.handleFailedUpload, + onSuccess: this.handleSuccessfulUpload, + onSending: this.handleSending, + onUploadProgress: this.handleUploadProgress, + preview: dimensions, + folderId: this.props.folderId, + options: dropzoneOptions, + securityID: securityID, + uploadButton: false + }, + messages, + this.renderGalleryView() + ) + ) + ), + this.props.loading && [_react2.default.createElement('div', { key: 'overlay', className: 'cms-content-loading-overlay ui-widget-overlay-light' }), _react2.default.createElement('div', { key: 'spinner', className: 'cms-content-loading-spinner' })], + _react2.default.createElement(_MoveModal2.default, { + sectionConfig: this.props.sectionConfig, + folderId: this.props.folderId, + onSuccess: this.props.onMoveFilesSuccess, + onOpenFolder: this.props.onOpenFolder + }) + ); + } + }]); + + return Gallery; +}(_react.Component); + +var sharedDefaultProps = { + page: 1, + limit: 15 +}; + +var sharedPropTypes = { + sectionConfig: _configShape2.default, + loading: _react.PropTypes.bool, + sort: _react.PropTypes.string, + files: _react.PropTypes.arrayOf(_react.PropTypes.shape({ + id: _react.PropTypes.number, + parent: _react.PropTypes.shape({ + id: _react.PropTypes.number + }) + })).isRequired, + selectedFiles: _react.PropTypes.arrayOf(_react.PropTypes.number), + totalCount: _react.PropTypes.number, + page: _react.PropTypes.number, + limit: _react.PropTypes.number, + badges: _react.PropTypes.arrayOf(_react.PropTypes.shape({ + id: _react.PropTypes.number, + message: _react.PropTypes.node, + status: _react.PropTypes.string + })), + onOpenFile: _react.PropTypes.func.isRequired, + onOpenFolder: _react.PropTypes.func.isRequired, + onSort: _react.PropTypes.func.isRequired, + onSetPage: _react.PropTypes.func.isRequired, + maxFilesSelect: _react.PropTypes.number +}; + +var galleryViewDefaultProps = Object.assign({}, sharedDefaultProps, { + selectableItems: false +}); + +var galleryViewPropTypes = Object.assign({}, sharedPropTypes, { + selectableItems: _react.PropTypes.bool, + selectableFolders: _react.PropTypes.bool, + onSelect: _react.PropTypes.func, + onCancelUpload: _react.PropTypes.func, + onDelete: _react2.default.PropTypes.func, + onRemoveErroredUpload: _react.PropTypes.func, + onEnableDropzone: _react.PropTypes.func +}); + +Gallery.defaultProps = Object.assign({}, sharedDefaultProps, { + type: 'admin', + view: 'tile', + enableDropzone: true +}); + +Gallery.propTypes = Object.assign({}, sharedPropTypes, { + onUploadSuccess: _react2.default.PropTypes.func, + onCreateFolder: _react2.default.PropTypes.func, + onMoveFilesSuccess: _react2.default.PropTypes.func, + onDelete: _react2.default.PropTypes.func, + onPublish: _react2.default.PropTypes.func, + onUnpublish: _react2.default.PropTypes.func, + type: _react.PropTypes.oneOf(['insert-media', 'insert-link', 'select', 'admin']), + view: _react.PropTypes.oneOf(['tile', 'table']), + lastSelected: _react.PropTypes.number, + dialog: _react.PropTypes.bool, + fileId: _react.PropTypes.number, + folderId: _react.PropTypes.number.isRequired, + folder: _react.PropTypes.shape({ + id: _react.PropTypes.number, + title: _react.PropTypes.string, + parentId: _react.PropTypes.number, + canView: _react.PropTypes.bool, + canEdit: _react.PropTypes.bool + }), + + files: _react.PropTypes.array, + errorMessage: _react.PropTypes.string, + graphQLErrors: _react.PropTypes.arrayOf(_react.PropTypes.string), + actions: _react.PropTypes.object, + securityId: _react.PropTypes.string, + onViewChange: _react.PropTypes.func.isRequired, + createFileApiUrl: _react.PropTypes.string, + createFileApiMethod: _react.PropTypes.string, + search: _react.PropTypes.object, + enableDropzone: _react.PropTypes.bool, + concatenateSelect: _react.PropTypes.bool, + GalleryToolbar: _react.PropTypes.func, + sorters: _react.PropTypes.arrayOf(_react.PropTypes.shape({ + field: _react.PropTypes.string.isRequired, + direction: _react.PropTypes.oneOf(['asc', 'desc']).isRequired, + label: _react.PropTypes.string.isRequired + })).isRequired +}); + +function mapStateToProps(state, ownProps) { + var sort = ownProps.sort; + var _state$assetAdmin$gal = state.assetAdmin.gallery, + selectedFiles = _state$assetAdmin$gal.selectedFiles, + errorMessage = _state$assetAdmin$gal.errorMessage, + noticeMessage = _state$assetAdmin$gal.noticeMessage, + enableDropzone = _state$assetAdmin$gal.enableDropzone, + badges = _state$assetAdmin$gal.badges, + concatenateSelect = _state$assetAdmin$gal.concatenateSelect, + loading = _state$assetAdmin$gal.loading, + sorters = _state$assetAdmin$gal.sorters, + lastSelected = _state$assetAdmin$gal.lastSelected; + + if (!sort && sorters && sorters[0]) { + sort = sorters[0].field + ',' + sorters[0].direction; + } + + return { + lastSelected: lastSelected, + selectedFiles: selectedFiles, + errorMessage: errorMessage, + noticeMessage: noticeMessage, + enableDropzone: enableDropzone, + badges: badges, + concatenateSelect: concatenateSelect, + loading: ownProps.loading || loading, + queuedFiles: state.assetAdmin.queuedFiles, + securityId: state.config.SecurityID, + sorters: sorters, + sort: sort + }; +} + +function mapDispatchToProps(dispatch) { + return { + actions: { + gallery: (0, _redux.bindActionCreators)(galleryActions, dispatch), + queuedFiles: (0, _redux.bindActionCreators)(queuedFilesActions, dispatch) + } + }; +} + +exports.Component = Gallery; +exports.galleryViewPropTypes = galleryViewPropTypes; +exports.galleryViewDefaultProps = galleryViewDefaultProps; +exports.default = (0, _redux.compose)((0, _Injector.inject)(['GalleryToolbar'], null, function () { + return 'AssetAdmin.Gallery'; +}), (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps), _moveFilesMutation2.default, function (component) { + return (0, _reactApollo.withApollo)(component); +})(Gallery); + +/***/ }), + +/***/ "./client/src/containers/Gallery/GalleryDND.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactDnd = __webpack_require__(15); + +var _reactDndHtml5Backend = __webpack_require__(21); + +var _reactDndHtml5Backend2 = _interopRequireDefault(_reactDndHtml5Backend); + +var _classnames = __webpack_require__(9); + +var _classnames2 = _interopRequireDefault(_classnames); + +var _GalleryItemDragLayer = __webpack_require__("./client/src/components/GalleryItem/GalleryItemDragLayer.js"); + +var _GalleryItemDragLayer2 = _interopRequireDefault(_GalleryItemDragLayer); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var context = (0, _reactDnd.DragDropContext)(_reactDndHtml5Backend2.default); + +var GalleryDND = function (_Component) { + _inherits(GalleryDND, _Component); + + function GalleryDND(props) { + _classCallCheck(this, GalleryDND); + + var _this = _possibleConstructorReturn(this, (GalleryDND.__proto__ || Object.getPrototypeOf(GalleryDND)).call(this, props)); + + _this.state = { + dragging: false + }; + _this.mounted = false; + _this.handleDrop = _this.handleDrop.bind(_this); + return _this; + } + + _createClass(GalleryDND, [{ + key: 'componentDidMount', + value: function componentDidMount() { + this.mounted = true; + window.addEventListener('drop', this.handleDrop, true); + } + }, { + key: 'componentWillUpdate', + value: function componentWillUpdate() { + var _this2 = this; + + setTimeout(function () { + if (!_this2.mounted) { + return; + } + var manager = _this2.context.dragDropManager; + + var dragging = manager.monitor.isDragging(); + if (_this2.state.dragging !== dragging) { + _this2.setState({ dragging: dragging }); + } + }); + } + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + this.mounted = false; + window.removeEventListener('drop', this.handleDrop, true); + } + }, { + key: 'handleDrop', + value: function handleDrop() { + var manager = this.context.dragDropManager; + var backend = manager && manager.backend; + + if (backend && backend.isDraggingNativeItem()) { + backend.endDragNativeItem(); + } + } + }, { + key: 'render', + value: function render() { + var _props = this.props, + className = _props.className, + children = _props.children; + + + return _react2.default.createElement( + 'div', + { className: (0, _classnames2.default)(className, { 'gallery__main--dragging': this.state.dragging }) }, + children, + _react2.default.createElement(_GalleryItemDragLayer2.default, null) + ); + } + }]); + + return GalleryDND; +}(_react.Component); + +GalleryDND.contextTypes = { + dragDropManager: _react.PropTypes.object +}; + +GalleryDND.propTypes = { + className: _react.PropTypes.string, + children: _react2.default.PropTypes.oneOfType([_react2.default.PropTypes.arrayOf(_react2.default.PropTypes.node), _react2.default.PropTypes.node]) +}; + +exports.default = context(GalleryDND); + +/***/ }), + +/***/ "./client/src/containers/HistoryList/HistoryItem.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var HistoryItem = function (_Component) { + _inherits(HistoryItem, _Component); + + function HistoryItem(props) { + _classCallCheck(this, HistoryItem); + + var _this = _possibleConstructorReturn(this, (HistoryItem.__proto__ || Object.getPrototypeOf(HistoryItem)).call(this, props)); + + _this.handleClick = _this.handleClick.bind(_this); + return _this; + } + + _createClass(HistoryItem, [{ + key: 'handleClick', + value: function handleClick(e) { + e.preventDefault(); + if (typeof this.props.onClick === 'function') { + this.props.onClick(this.props.versionid); + } + } + }, { + key: 'render', + value: function render() { + var publishedLine = null; + + if (this.props.status === 'Published') { + publishedLine = _react2.default.createElement( + 'p', + null, + _react2.default.createElement( + 'span', + { className: 'history-item__status-flag' }, + this.props.status + ), + ' at ', + this.props.date_formatted + ); + } + + return _react2.default.createElement( + 'li', + { + className: 'list-group-item history-item', + onClick: this.handleClick + }, + _react2.default.createElement( + 'p', + null, + _react2.default.createElement( + 'span', + { className: 'history-item__version' }, + 'v.', + this.props.versionid + ), + _react2.default.createElement( + 'span', + { className: 'history-item__date' }, + this.props.date_ago, + ' ', + this.props.author + ), + this.props.summary + ), + publishedLine + ); + } + }]); + + return HistoryItem; +}(_react.Component); + +HistoryItem.propTypes = { + versionid: _react.PropTypes.number.isRequired, + summary: _react.PropTypes.oneOfType([_react.PropTypes.bool, _react.PropTypes.string]).isRequired, + status: _react.PropTypes.string, + author: _react.PropTypes.string, + date_formatted: _react.PropTypes.string, + date_ago: _react.PropTypes.string, + onClick: _react.PropTypes.func +}; + +exports.default = HistoryItem; + +/***/ }), + +/***/ "./client/src/containers/HistoryList/HistoryList.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactRedux = __webpack_require__(3); + +var _Backend = __webpack_require__(19); + +var _Backend2 = _interopRequireDefault(_Backend); + +var _Config = __webpack_require__(20); + +var _Config2 = _interopRequireDefault(_Config); + +var _HistoryItem = __webpack_require__("./client/src/containers/HistoryList/HistoryItem.js"); + +var _HistoryItem2 = _interopRequireDefault(_HistoryItem); + +var _FormBuilderLoader = __webpack_require__(18); + +var _FormBuilderLoader2 = _interopRequireDefault(_FormBuilderLoader); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var sectionConfigKey = 'SilverStripe\\AssetAdmin\\Controller\\AssetAdmin'; + +var createEndpoint = function createEndpoint(endpointConfig) { + var includeToken = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; + return _Backend2.default.createEndpointFetcher(Object.assign({}, endpointConfig, includeToken ? { defaultData: { SecurityID: _Config2.default.get('SecurityID') } } : {})); +}; + +var HistoryList = function (_Component) { + _inherits(HistoryList, _Component); + + function HistoryList(props) { + _classCallCheck(this, HistoryList); + + var _this = _possibleConstructorReturn(this, (HistoryList.__proto__ || Object.getPrototypeOf(HistoryList)).call(this, props)); + + _this.state = { + detailView: null, + history: [], + loadedDetails: false + }; + + _this.handleClick = _this.handleClick.bind(_this); + _this.handleBack = _this.handleBack.bind(_this); + + _this.timer = null; + + _this.api = createEndpoint(props.sectionConfig.historyEndpoint); + return _this; + } + + _createClass(HistoryList, [{ + key: 'componentDidMount', + value: function componentDidMount() { + this.refreshHistoryIfNeeded(); + } + }, { + key: 'componentWillReceiveProps', + value: function componentWillReceiveProps(nextProps) { + this.refreshHistoryIfNeeded(nextProps); + } + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + clearTimeout(this.timer); + this.timer = null; + } + }, { + key: 'refreshHistoryIfNeeded', + value: function refreshHistoryIfNeeded(nextProps) { + var _this2 = this; + + if (!nextProps && !this.state.loadedDetails || nextProps.data.fileId !== this.props.data.fileId || nextProps.data.latestVersionId !== this.props.data.latestVersionId) { + this.setState({ loadedDetails: false }); + var fileId = nextProps ? nextProps.data.fileId : this.props.data.fileId; + clearTimeout(this.timer); + + this.timer = setTimeout(function () { + _this2.api({ + fileId: fileId + }).then(function (history) { + if (_this2.timer) { + _this2.setState({ history: history, loadedDetails: true }); + } + }); + }, 250); + } + } + }, { + key: 'handleClick', + value: function handleClick(versionId) { + this.setState({ + viewDetails: versionId + }); + } + }, { + key: 'handleBack', + value: function handleBack(event) { + event.preventDefault(); + + this.setState({ + viewDetails: null + }); + } + }, { + key: 'render', + value: function render() { + var _this3 = this; + + if (!this.state.loadedDetails) { + return _react2.default.createElement( + 'div', + { className: 'history-list history-list--loading' }, + 'Loading...' + ); + } + + if (this.state.viewDetails) { + var schemaUrl = [this.props.historySchemaUrl, this.props.data.fileId, this.state.viewDetails].join('/'); + + var backButtonClasses = ['btn', 'btn-secondary', 'btn--icon-xl', 'btn--no-text', 'font-icon-left-open-big', 'history-list__back'].join(' '); + + return _react2.default.createElement( + 'div', + { className: 'history-list' }, + _react2.default.createElement('a', { href: '#', className: backButtonClasses, onClick: this.handleBack }), + _react2.default.createElement(_FormBuilderLoader2.default, { identifier: 'AssetAdmin.HistoryList', schemaUrl: schemaUrl }) + ); + } + + var historyList = this.state.history || []; + return _react2.default.createElement( + 'div', + { className: 'history-list' }, + _react2.default.createElement( + 'ul', + { className: 'list-group list-group-flush history-list__list' }, + historyList.map(function (history) { + return _react2.default.createElement(_HistoryItem2.default, _extends({ + key: history.versionid + }, history, { + onClick: _this3.handleClick + })); + }) + ) + ); + } + }]); + + return HistoryList; +}(_react.Component); + +HistoryList.propTypes = { + sectionConfig: _react2.default.PropTypes.shape({ + form: _react2.default.PropTypes.object, + historyEndpoint: _react2.default.PropTypes.shape({ + url: _react2.default.PropTypes.string, + method: _react2.default.PropTypes.string, + responseFormat: _react2.default.PropTypes.string + }) + }), + historySchemaUrl: _react2.default.PropTypes.string, + data: _react2.default.PropTypes.object +}; + +HistoryList.defaultProps = { + data: { + fieldId: 0 + } +}; + +function mapStateToProps(state) { + var sectionConfig = state.config.sections.find(function (section) { + return section.name === sectionConfigKey; + }); + return { + sectionConfig: sectionConfig, + historySchemaUrl: sectionConfig.form.fileHistoryForm.schemaUrl + }; +} + +exports.Component = HistoryList; +exports.default = (0, _reactRedux.connect)(mapStateToProps)(HistoryList); + +/***/ }), + +/***/ "./client/src/containers/MoveModal/MoveModal.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactRedux = __webpack_require__(3); + +var _redux = __webpack_require__(4); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _index = __webpack_require__("./client/src/constants/index.js"); + +var _index2 = _interopRequireDefault(_index); + +var _GalleryActions = __webpack_require__("./client/src/state/gallery/GalleryActions.js"); + +var _FormBuilderModal = __webpack_require__(11); + +var _FormBuilderModal2 = _interopRequireDefault(_FormBuilderModal); + +var _configShape = __webpack_require__("./client/src/lib/configShape.js"); + +var _configShape2 = _interopRequireDefault(_configShape); + +var _moveFilesMutation = __webpack_require__("./client/src/state/files/moveFilesMutation.js"); + +var _moveFilesMutation2 = _interopRequireDefault(_moveFilesMutation); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var MoveModal = function (_React$Component) { + _inherits(MoveModal, _React$Component); + + function MoveModal(props) { + _classCallCheck(this, MoveModal); + + var _this = _possibleConstructorReturn(this, (MoveModal.__proto__ || Object.getPrototypeOf(MoveModal)).call(this, props)); + + _this.handleSubmit = _this.handleSubmit.bind(_this); + _this.timeout = null; + return _this; + } + + _createClass(MoveModal, [{ + key: 'handleSubmit', + value: function handleSubmit(_ref) { + var _this2 = this; + + var FolderID = _ref.FolderID; + var moveFiles = this.props.actions.files.moveFiles; + var _props = this.props, + selectedFiles = _props.selectedFiles, + onSuccess = _props.onSuccess, + onClosed = _props.onClosed, + setNotice = _props.setNotice, + setError = _props.setError, + setBadge = _props.setBadge; + + return moveFiles(FolderID || 0, selectedFiles).then(function (_ref2) { + var _ref2$data$moveFiles = _ref2.data.moveFiles, + id = _ref2$data$moveFiles.id, + filename = _ref2$data$moveFiles.filename; + + if (typeof onSuccess === 'function') { + onSuccess(FolderID, selectedFiles); + } + + setBadge(id, '' + selectedFiles.length, 'success', _index2.default.MOVE_SUCCESS_DURATION); + + var goToFolder = function goToFolder(e) { + e.preventDefault(); + _this2.props.onOpenFolder(id); + setNotice(null); + }; + + setNotice({ + react: _react2.default.createElement( + 'span', + null, + _i18n2.default.sprintf(_i18n2.default._t('AssetAdmin.MOVED_ITEMS_TO', 'Moved %s item(s) to '), selectedFiles.length), + _react2.default.createElement( + 'a', + { href: '#', onClick: goToFolder }, + filename + ) + ) + }); + _this2.timeout = setTimeout(function () { + return setNotice(null); + }, _index2.default.MOVE_SUCCESS_DURATION); + onClosed(); + }).catch(function () { + setError(_i18n2.default._t('AssetAdmin.FAILED_MOVE', 'There was an error moving the selected items.')); + }); + } + }, { + key: 'render', + value: function render() { + var _props2 = this.props, + isOpen = _props2.isOpen, + onClosed = _props2.onClosed, + title = _props2.title, + folderId = _props2.folderId, + sectionConfig = _props2.sectionConfig; + var schemaUrl = sectionConfig.form.moveForm.schemaUrl; + + return _react2.default.createElement(_FormBuilderModal2.default, { + title: title, + isOpen: isOpen, + onClosed: onClosed, + onSubmit: this.handleSubmit, + identifier: 'AssetAdmin.MoveForm', + schemaUrl: schemaUrl + '/' + folderId + }); + } + }]); + + return MoveModal; +}(_react2.default.Component); + +MoveModal.propTypes = { + sectionConfig: _configShape2.default, + folderId: _react2.default.PropTypes.number.isRequired, + isOpen: _react2.default.PropTypes.bool, + onClosed: _react2.default.PropTypes.func, + setNotice: _react2.default.PropTypes.func, + setBadge: _react2.default.PropTypes.func, + setError: _react2.default.PropTypes.func, + title: _react2.default.PropTypes.string, + onSuccess: _react2.default.PropTypes.func, + onOpenFolder: _react2.default.PropTypes.func.isRequired, + selectedFiles: _react2.default.PropTypes.array.isRequired, + actions: _react2.default.PropTypes.shape({ + files: _react2.default.PropTypes.shape({ + moveFiles: _react2.default.PropTypes.func + }) + }).isRequired +}; + +MoveModal.defaultProps = { + isOpen: false +}; + +function mapStateToProps(state) { + var _state$assetAdmin$gal = state.assetAdmin.gallery, + modal = _state$assetAdmin$gal.modal, + selectedFiles = _state$assetAdmin$gal.selectedFiles; + + return { + isOpen: modal === _index2.default.MODAL_MOVE, + selectedFiles: selectedFiles, + title: _i18n2.default.sprintf(_i18n2.default._t('AssetAdmin.MOVE_ITEMS_TO', 'Move %s item(s) to...'), selectedFiles.length) + }; +} + +function mapDispatchToProps(dispatch) { + return { + onClosed: function onClosed() { + dispatch((0, _GalleryActions.deactivateModal)()); + }, + setNotice: function setNotice(msg) { + dispatch((0, _GalleryActions.setNoticeMessage)(msg)); + }, + setError: function setError(msg) { + dispatch((0, _GalleryActions.setErrorMessage)(msg)); + }, + setBadge: function setBadge() { + dispatch(_GalleryActions.setFileBadge.apply(undefined, arguments)); + } + }; +} + +exports.default = (0, _redux.compose)((0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps), _moveFilesMutation2.default)(MoveModal); + +/***/ }), + +/***/ "./client/src/containers/TableView/TableView.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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"); } }; }(); + +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; }; }(); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _griddleReact = __webpack_require__("../../../node_modules/griddle-react/modules/griddle.jsx.js"); + +var _griddleReact2 = _interopRequireDefault(_griddleReact); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _Gallery = __webpack_require__("./client/src/containers/Gallery/Gallery.js"); + +var _DataFormat = __webpack_require__(12); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var TableView = function (_Component) { + _inherits(TableView, _Component); + + function TableView(props) { + _classCallCheck(this, TableView); + + var _this = _possibleConstructorReturn(this, (TableView.__proto__ || Object.getPrototypeOf(TableView)).call(this, props)); + + _this.getColumns = _this.getColumns.bind(_this); + _this.handleSort = _this.handleSort.bind(_this); + _this.handleSetPage = _this.handleSetPage.bind(_this); + _this.handleRowClick = _this.handleRowClick.bind(_this); + _this.renderSelect = _this.renderSelect.bind(_this); + _this.renderTitle = _this.renderTitle.bind(_this); + _this.renderNoItemsNotice = _this.renderNoItemsNotice.bind(_this); + + _this.state = { + enableSort: false + }; + return _this; + } + + _createClass(TableView, [{ + key: 'componentDidMount', + value: function componentDidMount() { + this.setState({ + enableSort: true + }); + } + }, { + key: 'componentWillUnmount', + value: function componentWillUnmount() { + this.setState({ + enableSort: false + }); + } + }, { + key: 'getColumns', + value: function getColumns() { + var columns = ['thumbnail', 'title', 'size', 'lastEdited']; + + if (this.props.selectableItems) { + columns.unshift('selected'); + } + + return columns; + } + }, { + key: 'getColumnConfig', + value: function getColumnConfig() { + return [{ + columnName: 'selected', + sortable: false, + displayName: '', + cssClassName: 'gallery__table-column--select', + customComponent: this.renderSelect + }, { + columnName: 'thumbnail', + sortable: false, + displayName: '', + cssClassName: 'gallery__table-column--image', + customComponent: this.renderThumbnail + }, { + columnName: 'title', + customCompareFn: function customCompareFn() { + return 0; + }, + cssClassName: 'gallery__table-column--title', + customComponent: this.renderTitle + }, { + columnName: 'lastEdited', + displayName: 'Modified', + customComponent: this.renderDate + }, { + columnName: 'size', + sortable: false, + displayName: 'Size', + cssClassName: 'sort--disabled', + customComponent: this.renderSize + }]; + } + }, { + key: 'getRowMetadata', + value: function getRowMetadata(rowData) { + return 'gallery__table-row ' + (rowData.highlighted ? 'gallery__table-row--highlighted' : ''); + } + }, { + key: 'getTableProps', + value: function getTableProps() { + var _props$sort$split = this.props.sort.split(','), + _props$sort$split2 = _slicedToArray(_props$sort$split, 2), + sortColumn = _props$sort$split2[0], + sortDirection = _props$sort$split2[1]; + + return { + tableClassName: 'gallery__table table table-hover', + gridClassName: 'gallery__main-view--table', + rowMetadata: { + bodyCssClassName: this.getRowMetadata + }, + sortAscendingComponent: '', + sortDescendingComponent: '', + useExternal: true, + externalSetPage: this.handleSetPage, + externalChangeSort: this.handleSort, + + externalSetFilter: function externalSetFilter() { + return null; + }, + externalSetPageSize: function externalSetPageSize() { + return null; + }, + externalCurrentPage: this.props.page - 1, + externalMaxPage: Math.ceil(this.props.totalCount / this.props.limit), + externalSortColumn: sortColumn, + + externalSortAscending: !this.state.enableSort ? sortDirection !== 'asc' : sortDirection === 'asc', + initialSort: sortColumn, + columns: this.getColumns(), + columnMetadata: this.getColumnConfig(), + useGriddleStyles: false, + onRowClick: this.handleRowClick, + + results: this.props.files, + customNoDataComponent: this.renderNoItemsNotice + }; + } + }, { + key: 'handleActivate', + value: function handleActivate(event, item) { + if (item.type === 'folder') { + this.props.onOpenFolder(event, item); + } else { + this.props.onOpenFile(event, item); + } + } + }, { + key: 'handleRowClick', + value: function handleRowClick(row, event) { + var item = row.props.data; + + if (event.currentTarget.classList.contains('gallery__table-column--select')) { + event.stopPropagation(); + event.preventDefault(); + if (typeof this.props.onSelect === 'function') { + this.props.onSelect(event, item); + return; + } + } + + this.handleActivate(event, item); + } + }, { + key: 'handleSort', + value: function handleSort(column, ascending) { + var direction = ascending ? 'asc' : 'desc'; + + if (this.state.enableSort) { + this.props.onSort(column + ',' + direction); + } + } + }, { + key: 'handleSetPage', + value: function handleSetPage(page) { + this.props.onSetPage(page + 1); + } + }, { + key: 'preventFocus', + value: function preventFocus(event) { + event.preventDefault(); + } + }, { + key: 'renderNoItemsNotice', + value: function renderNoItemsNotice() { + if (this.props.files.length === 0 && !this.props.loading) { + return _react2.default.createElement( + 'p', + { className: 'gallery__no-item-notice' }, + _i18n2.default._t('AssetAdmin.NOITEMSFOUND') + ); + } + + return null; + } + }, { + key: 'renderSize', + value: function renderSize(props) { + if (props.rowData.type === 'folder') { + return null; + } + var description = (0, _DataFormat.fileSize)(props.data); + + return _react2.default.createElement( + 'span', + null, + description + ); + } + }, { + key: 'renderProgressBar', + value: function renderProgressBar(rowData) { + if (!rowData.queuedId || rowData.message && rowData.message.type === 'error') { + return null; + } + if (rowData.id > 0) { + return _react2.default.createElement('div', { className: 'gallery__progress-bar--complete' }); + } + var progressBarProps = { + className: 'gallery__progress-bar-progress', + style: { + width: rowData.progress + '%' + } + }; + + return _react2.default.createElement( + 'div', + { className: 'gallery__progress-bar' }, + _react2.default.createElement('div', progressBarProps) + ); + } + }, { + key: 'renderTitle', + value: function renderTitle(props) { + var progress = this.renderProgressBar(props.rowData); + + return _react2.default.createElement( + 'div', + { className: 'fill-width' }, + _react2.default.createElement( + 'div', + { className: 'flexbox-area-grow' }, + props.data + ), + progress + ); + } + }, { + key: 'renderSelect', + value: function renderSelect(props) { + if (this.props.selectableItems && (this.props.selectableFolders || props.rowData.type !== 'folder')) { + var checkboxProps = { + type: 'checkbox', + title: _i18n2.default._t('AssetAdmin.SELECT'), + checked: props.data, + tabIndex: -1, + onMouseDown: this.preventFocus + }; + + var maxSelected = ![null, 1].includes(this.props.maxFilesSelect) && this.props.selectedFiles.length >= this.props.maxFilesSelect; + + if (maxSelected && !props.data) { + checkboxProps.disabled = true; + } + + return _react2.default.createElement('input', checkboxProps); + } + return null; + } + }, { + key: 'renderDate', + value: function renderDate(props) { + if (props.rowData.type === 'folder') { + return null; + } + + return _react2.default.createElement( + 'span', + null, + props.data + ); + } + }, { + key: 'renderThumbnail', + value: function renderThumbnail(props) { + var url = props.data || props.rowData.url; + var uploading = props.rowData.queuedId && !props.rowData.id; + var category = props.rowData.category || 'false'; + var baseClass = 'gallery__table-image'; + var classNames = [baseClass]; + var styles = {}; + + classNames.push(baseClass + '--' + category); + + if (category === 'image' && url) { + styles.backgroundImage = 'url("' + url + '")'; + } + + if (!uploading && !url && category !== 'folder') { + classNames.push(baseClass + '--error'); + } + + return _react2.default.createElement('div', { className: classNames.join(' '), style: styles }); + } + }, { + key: 'render', + value: function render() { + return _react2.default.createElement(_griddleReact2.default, this.getTableProps()); + } + }]); + + return TableView; +}(_react.Component); + +TableView.defaultProps = _Gallery.galleryViewDefaultProps; + +TableView.propTypes = _extends({}, _Gallery.galleryViewPropTypes, { + sort: _react.PropTypes.string.isRequired +}); + +exports.Component = TableView; +exports.default = TableView; + +/***/ }), + +/***/ "./client/src/containers/ThumbnailView/ThumbnailView.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.Component = undefined; + +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; }; }(); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _Injector = __webpack_require__(2); + +var _Gallery = __webpack_require__("./client/src/containers/Gallery/Gallery.js"); + +var _griddleReact = __webpack_require__("../../../node_modules/griddle-react/modules/griddle.jsx.js"); + +var _griddleReact2 = _interopRequireDefault(_griddleReact); + +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"); } } + +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } + +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } + +var ThumbnailView = function (_Component) { + _inherits(ThumbnailView, _Component); + + function ThumbnailView(props) { + _classCallCheck(this, ThumbnailView); + + var _this = _possibleConstructorReturn(this, (ThumbnailView.__proto__ || Object.getPrototypeOf(ThumbnailView)).call(this, props)); + + _this.renderItem = _this.renderItem.bind(_this); + _this.handleSetPage = _this.handleSetPage.bind(_this); + _this.handlePrevPage = _this.handlePrevPage.bind(_this); + _this.handleNextPage = _this.handleNextPage.bind(_this); + _this.handleDrag = _this.handleDrag.bind(_this); + return _this; + } + + _createClass(ThumbnailView, [{ + key: 'handleDrag', + value: function handleDrag(dragging) { + this.props.onEnableDropzone(!dragging); + } + }, { + key: 'handleSetPage', + value: function handleSetPage(page) { + this.props.onSetPage(page + 1); + } + }, { + key: 'handleNextPage', + value: function handleNextPage() { + var currentPage = this.props.page - 1; + this.handleSetPage(currentPage + 1); + } + }, { + key: 'handlePrevPage', + value: function handlePrevPage() { + var currentPage = this.props.page - 1; + if (currentPage === 0) { + this.handleSetPage(currentPage); + return; + } + this.handleSetPage(currentPage - 1); + } + }, { + key: 'folderFilter', + value: function folderFilter(file) { + return file.type === 'folder'; + } + }, { + key: 'fileFilter', + value: function fileFilter(file) { + return file.type !== 'folder'; + } + }, { + key: 'renderPagination', + value: function renderPagination() { + if (this.props.totalCount <= this.props.limit) { + return null; + } + var props = { + setPage: this.handleSetPage, + maxPage: Math.ceil(this.props.totalCount / this.props.limit), + next: this.handleNextPage, + nextText: _i18n2.default._t('AssetAdmin.NEXT', 'Next'), + previous: this.handlePrevPage, + previousText: _i18n2.default._t('AssetAdmin.PREVIOUS', 'Previous'), + currentPage: this.props.page - 1, + useGriddleStyles: false + }; + return _react2.default.createElement( + 'div', + { className: 'griddle-footer' }, + _react2.default.createElement(_griddleReact2.default.GridPagination, props) + ); + } + }, { + key: 'renderItem', + value: function renderItem(item) { + var _props = this.props, + File = _props.File, + Folder = _props.Folder, + badges = _props.badges, + sectionConfig = _props.sectionConfig, + selectedFiles = _props.selectedFiles, + selectableItems = _props.selectableItems, + selectableFolders = _props.selectableFolders; + + var badge = badges.find(function (badgeItem) { + return badgeItem.id === item.id; + }); + var props = { + sectionConfig: sectionConfig, + key: item.id + '__' + item.queuedId, + selectableKey: item.id, + item: item, + selectedFiles: selectedFiles, + onDrag: this.handleDrag, + badge: badge, + canDrag: this.props.canDrag + }; + + if (item.queuedId && !item.id) { + var _props2 = this.props, + onCancelUpload = _props2.onCancelUpload, + onRemoveErroredUpload = _props2.onRemoveErroredUpload; + + props = _extends({}, props, { onCancelUpload: onCancelUpload, onRemoveErroredUpload: onRemoveErroredUpload }); + } else { + var _props3 = this.props, + onOpenFolder = _props3.onOpenFolder, + onOpenFile = _props3.onOpenFile; + + props = _extends({}, props, { + onActivate: item.type === 'folder' ? onOpenFolder : onOpenFile + }); + } + + if (selectableItems && (selectableFolders || item.type !== 'folder')) { + var maxSelected = ![null, 1].includes(this.props.maxFilesSelect) && this.props.selectedFiles.length >= this.props.maxFilesSelect; + var onSelect = this.props.maxFilesSelect === 1 ? props.onActivate : this.props.onSelect; + props = _extends({}, props, { selectable: true, onSelect: onSelect, maxSelected: maxSelected }); + } + + if (item.type === 'folder') { + var onDropFiles = this.props.onDropFiles; + + props = _extends({}, props, { onDropFiles: onDropFiles }); + return _react2.default.createElement(Folder, props); + } + return _react2.default.createElement(File, props); + } + }, { + key: 'render', + value: function render() { + var className = 'gallery__main-view--tile'; + return _react2.default.createElement( + 'div', + { className: className }, + _react2.default.createElement( + 'div', + { className: 'gallery__folders' }, + this.props.files.filter(this.folderFilter).map(this.renderItem) + ), + _react2.default.createElement( + 'div', + { className: 'gallery__files' }, + this.props.files.filter(this.fileFilter).map(this.renderItem) + ), + this.props.files.length === 0 && !this.props.loading && _react2.default.createElement( + 'p', + { className: 'gallery__no-item-notice' }, + _i18n2.default._t('AssetAdmin.NOITEMSFOUND') + ), + _react2.default.createElement( + 'div', + { className: 'gallery__load' }, + this.renderPagination() + ) + ); + } + }]); + + return ThumbnailView; +}(_react.Component); + +ThumbnailView.defaultProps = _Gallery.galleryViewDefaultProps; + +ThumbnailView.propTypes = _extends({}, _Gallery.galleryViewPropTypes, { + File: _react.PropTypes.oneOfType([_react.PropTypes.node, _react.PropTypes.func]).isRequired, + Folder: _react.PropTypes.oneOfType([_react.PropTypes.node, _react.PropTypes.func]).isRequired +}); + +var injector = (0, _Injector.inject)(['GalleryItemFile', 'GalleryItemFolder'], function (GalleryItemFile, GalleryItemFolder) { + return { + File: GalleryItemFile, + Folder: GalleryItemFolder + }; +}, function () { + return 'AssetAdmin.Gallery.ThumbnailView'; +}); + +exports.Component = ThumbnailView; +exports.default = injector(ThumbnailView); + +/***/ }), + +/***/ "./client/src/entwine/UploadField/UploadFieldEntwine.js": +/***/ (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 _jquery = __webpack_require__(6); + +var _jquery2 = _interopRequireDefault(_jquery); + +var _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactDom = __webpack_require__(5); + +var _reactDom2 = _interopRequireDefault(_reactDom); + +var _schemaFieldValues = __webpack_require__(41); + +var _Injector = __webpack_require__(2); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +_jquery2.default.entwine('ss', function ($) { + $('.js-injector-boot input.entwine-uploadfield').entwine({ + Component: null, + + getContainer: function getContainer() { + var container = this.siblings('.uploadfield-holder')[0]; + if (!container) { + var newContainer = $('
'); + this.before(newContainer); + + container = newContainer[0]; + } + return container; + }, + onunmatch: function onunmatch() { + this._super(); + + _reactDom2.default.unmountComponentAtNode(this.siblings('.uploadfield-holder')[0]); + }, + onmatch: function onmatch() { + var cmsContent = this.closest('.cms-content').attr('id'); + var context = cmsContent ? { context: cmsContent } : {}; + + var UploadField = (0, _Injector.loadComponent)('UploadField', context); + this.setComponent(UploadField); + + this._super(); + this.hide(); + this.refresh(); + }, + onclick: function onclick(e) { + e.preventDefault(); + }, + refresh: function refresh() { + var props = this.getAttributes(); + var form = $(this).closest('form'); + var onChange = function onChange() { + setTimeout(function () { + form.trigger('change'); + }, 0); + }; + + var UploadField = this.getComponent(); + + _reactDom2.default.render(_react2.default.createElement(UploadField, _extends({}, props, { + onChange: onChange, + noHolder: true + })), this.getContainer()); + }, + getAttributes: function getAttributes() { + var state = $(this).data('state'); + var schema = $(this).data('schema'); + return (0, _schemaFieldValues.schemaMerge)(schema, state); + } + }); +}); + +/***/ }), + +/***/ "./client/src/lib/configShape.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _react = __webpack_require__(0); + +var configShape = _react.PropTypes.shape({ + url: _react.PropTypes.string, + limit: _react.PropTypes.number, + imageRetry: _react.PropTypes.shape({ + minRetry: _react.PropTypes.number, + maxRetry: _react.PropTypes.number, + expiry: _react.PropTypes.number + }), + form: _react.PropTypes.object, + dropzoneOptions: _react.PropTypes.object +}); + +exports.default = configShape; + +/***/ }), + +/***/ "./client/src/lib/fileFragments.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +var fileInterface = "\n fragment FileInterfaceFields on FileInterface {\n canDelete\n canEdit\n canView\n category\n exists\n filename\n id\n lastEdited\n name\n parentId\n title\n type\n url\n }\n"; + +var file = "\n fragment FileFields on File {\n draft\n extension\n published\n modified\n size\n smallThumbnail\n thumbnail\n inUseCount\n }\n"; + +var folder = "\n fragment FolderFields on Folder {\n filesInUseCount\n }\n"; + +exports.fileInterface = fileInterface; +exports.file = file; +exports.folder = folder; + +/***/ }), + +/***/ "./client/src/lib/fileShape.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _react = __webpack_require__(0); + +var fileShape = _react.PropTypes.shape({ + canEdit: _react.PropTypes.bool, + canDelete: _react.PropTypes.bool, + canView: _react.PropTypes.bool, + exists: _react.PropTypes.bool, + type: _react.PropTypes.string, + smallThumbnail: _react.PropTypes.string, + thumbnail: _react.PropTypes.string, + width: _react.PropTypes.number, + height: _react.PropTypes.number, + category: _react.PropTypes.oneOfType([_react.PropTypes.bool, _react.PropTypes.string]), + id: _react.PropTypes.number, + inUseCount: _react.PropTypes.number, + url: _react.PropTypes.string, + title: _react.PropTypes.string, + progress: _react.PropTypes.number +}); + +exports.default = fileShape; + +/***/ }), + +/***/ "./client/src/lib/fileStructure.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _deepFreezeStrict = __webpack_require__(13); + +var _deepFreezeStrict2 = _interopRequireDefault(_deepFreezeStrict); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var fileStructure = (0, _deepFreezeStrict2.default)({ + name: null, + canDelete: false, + canEdit: false, + category: null, + created: null, + extension: null, + filename: null, + id: 0, + lastEdited: null, + messages: null, + owner: { + id: 0, + title: null + }, + parent: { + filename: null, + id: 0, + title: null + }, + queuedId: null, + size: null, + title: null, + type: null, + url: null, + xhr: null, + thumbnail: null, + smallThumbnail: null, + height: null, + width: null +}); + +exports.default = fileStructure; + +/***/ }), + +/***/ "./client/src/state/files/buildPublicationMutation.js": +/***/ (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 _templateObject = _taggedTemplateLiteral(['\n mutation ', '($IDs:[ID]!, $Force:Boolean, $Quiet:Boolean) {\n ', '(IDs: $IDs, Force: $Force, Quiet: $Quiet) {\n ...on File {\n __typename\n ...FileInterfaceFields\n ...FileFields\n }\n ...on PublicationNotice {\n __typename\n Type\n Message\n IDs\n }\n }\n }\n ', '\n ', '\n'], ['\n mutation ', '($IDs:[ID]!, $Force:Boolean, $Quiet:Boolean) {\n ', '(IDs: $IDs, Force: $Force, Quiet: $Quiet) {\n ...on File {\n __typename\n ...FileInterfaceFields\n ...FileFields\n }\n ...on PublicationNotice {\n __typename\n Type\n Message\n IDs\n }\n }\n }\n ', '\n ', '\n']); + +var _graphqlTag = __webpack_require__(14); + +var _graphqlTag2 = _interopRequireDefault(_graphqlTag); + +var _fileFragments = __webpack_require__("./client/src/lib/fileFragments.js"); + +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 _taggedTemplateLiteral(strings, raw) { return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); } + +var buildPublicationMutation = function buildPublicationMutation(mutationName) { + var operationName = mutationName.charAt(0).toUpperCase() + mutationName.slice(1); + var mutation = (0, _graphqlTag2.default)(_templateObject, operationName, mutationName, _fileFragments.fileInterface, _fileFragments.file); + + var isProd = "development" === 'production'; + var config = { + props: function props(_ref) { + var mutate = _ref.mutate, + actions = _ref.ownProps.actions; + + var mutationAction = function mutationAction(IDs) { + var Force = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; + var Quiet = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : isProd; + return mutate({ + variables: { + IDs: IDs, + Quiet: Quiet, + Force: Force + } + }); + }; + + return { + actions: _extends({}, actions, { + files: _extends({}, actions.files, _defineProperty({}, mutationName, mutationAction)) + }) + }; + } + }; + + return { mutation: mutation, config: config }; +}; + +exports.default = buildPublicationMutation; + +/***/ }), + +/***/ "./client/src/state/files/deleteFilesMutation.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.config = exports.mutation = undefined; + +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 _templateObject = _taggedTemplateLiteral(['mutation DeleteFiles($IDs:[ID]!) {\n deleteFiles(IDs: $IDs)\n}'], ['mutation DeleteFiles($IDs:[ID]!) {\n deleteFiles(IDs: $IDs)\n}']); + +var _reactApollo = __webpack_require__(8); + +var _graphqlTag = __webpack_require__(14); + +var _graphqlTag2 = _interopRequireDefault(_graphqlTag); + +var _readFilesQuery = __webpack_require__("./client/src/state/files/readFilesQuery.js"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _taggedTemplateLiteral(strings, raw) { return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); } + +var mutation = (0, _graphqlTag2.default)(_templateObject); + +var config = { + props: function props(_ref) { + var mutate = _ref.mutate, + ownProps = _ref.ownProps; + var actions = ownProps.actions; + + var deleteFiles = function deleteFiles(IDs) { + return mutate({ + variables: { + IDs: IDs + }, + update: function update(store) { + var variables = _readFilesQuery.config.options(ownProps).variables; + var data = store.readQuery({ query: _readFilesQuery.query, variables: variables }); + + var newData = JSON.parse(JSON.stringify(data)); + + var edges = newData.readFiles.edges[0].node.children.edges; + + edges = edges.filter(function (edge) { + return !IDs.includes(edge.node.id); + }); + newData.readFiles.edges[0].node.children.edges = edges; + store.writeQuery({ query: _readFilesQuery.query, data: newData, variables: variables }); + } + }); + }; + + return { + actions: _extends({}, actions, { + files: _extends({}, actions.files, { + deleteFiles: deleteFiles + }) + }) + }; + } +}; + +exports.mutation = mutation; +exports.config = config; +exports.default = (0, _reactApollo.graphql)(mutation, config); + +/***/ }), + +/***/ "./client/src/state/files/moveFilesMutation.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.config = exports.mutation = undefined; + +var _templateObject = _taggedTemplateLiteral(['\n mutation MoveFiles($folderId:ID!, $fileIds:[ID]!) {\n moveFiles(folderId: $folderId, fileIds: $fileIds) {\n ...FileInterfaceFields\n ...FileFields\n }\n }\n ', '\n ', '\n'], ['\n mutation MoveFiles($folderId:ID!, $fileIds:[ID]!) {\n moveFiles(folderId: $folderId, fileIds: $fileIds) {\n ...FileInterfaceFields\n ...FileFields\n }\n }\n ', '\n ', '\n']); + +var _reactApollo = __webpack_require__(8); + +var _graphqlTag = __webpack_require__(14); + +var _graphqlTag2 = _interopRequireDefault(_graphqlTag); + +var _fileFragments = __webpack_require__("./client/src/lib/fileFragments.js"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _taggedTemplateLiteral(strings, raw) { return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); } + +var mutation = (0, _graphqlTag2.default)(_templateObject, _fileFragments.fileInterface, _fileFragments.file); + +var config = { + props: function props(_ref) { + var mutate = _ref.mutate, + _ref$ownProps$actions = _ref.ownProps.actions, + actions = _ref$ownProps$actions === undefined ? {} : _ref$ownProps$actions; + return { + actions: Object.assign({}, actions, { + files: Object.assign({}, actions.files, { + moveFiles: function moveFiles(folderId, fileIds) { + return mutate({ + variables: { + folderId: folderId, + fileIds: fileIds + } + }); + } + }) + }) + }; + } +}; + +exports.mutation = mutation; +exports.config = config; +exports.default = (0, _reactApollo.graphql)(mutation, config); + +/***/ }), + +/***/ "./client/src/state/files/publishFilesMutation.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.config = exports.mutation = undefined; + +var _reactApollo = __webpack_require__(8); + +var _buildPublicationMutation = __webpack_require__("./client/src/state/files/buildPublicationMutation.js"); + +var _buildPublicationMutation2 = _interopRequireDefault(_buildPublicationMutation); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var _buildPublicationMuta = (0, _buildPublicationMutation2.default)('publishFiles'), + mutation = _buildPublicationMuta.mutation, + config = _buildPublicationMuta.config; + +exports.mutation = mutation; +exports.config = config; +exports.default = (0, _reactApollo.graphql)(mutation, config); + +/***/ }), + +/***/ "./client/src/state/files/readFilesQuery.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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"); } }; }(); + +var _reactApollo = __webpack_require__(8); + +var _graphqlTag = __webpack_require__(14); + +var _graphqlTag2 = _interopRequireDefault(_graphqlTag); + +var _fileFragments = __webpack_require__("./client/src/lib/fileFragments.js"); + +var _Search = __webpack_require__("./client/src/components/Search/Search.js"); + +var _Injector = __webpack_require__(2); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var apolloConfig = { + options: function options(_ref) { + var sectionConfig = _ref.sectionConfig, + folderId = _ref.folderId, + fileId = _ref.fileId, + params = _ref.query; + + var filter = Object.assign({}, params.filter); + var childrenFilter = Object.assign({}, filter, { + parentId: undefined, + + recursive: (0, _Search.hasFilters)(filter), + + currentFolderOnly: undefined + }); + + var anyChildId = (0, _Search.hasFilters)(filter) ? null : fileId || null; + var id = anyChildId ? null : folderId || 0; + + var rootFilter = { + id: id, + + anyChildId: anyChildId + }; + + var _ref2 = params.sort ? params.sort.split(',') : ['', ''], + _ref3 = _slicedToArray(_ref2, 2), + sortField = _ref3[0], + sortDir = _ref3[1]; + + var limit = params.limit || sectionConfig.limit; + return { + variables: { + rootFilter: rootFilter, + childrenFilter: childrenFilter, + limit: limit, + offset: ((params.page || 1) - 1) * limit, + sortBy: sortField && sortDir ? [{ field: sortField, direction: sortDir.toUpperCase() }] : undefined + } + }; + }, + props: function props(_ref4) { + var _ref4$data = _ref4.data, + error = _ref4$data.error, + refetch = _ref4$data.refetch, + readFiles = _ref4$data.readFiles, + networkLoading = _ref4$data.loading, + actions = _ref4.ownProps.actions; + + var folder = readFiles && readFiles.edges[0] ? readFiles.edges[0].node : null; + var files = folder && folder.children ? folder.children.edges.map(function (edge) { + return edge.node; + }).filter(function (file) { + return file; + }) : []; + var filesTotalCount = folder && folder.children ? folder.children.pageInfo.totalCount : 0; + + var filesLoading = folder && !folder.children; + + var errors = error && error.graphQLErrors && error.graphQLErrors.map(function (graphQLError) { + return graphQLError.message; + }); + return { + loading: networkLoading || filesLoading, + folder: folder, + files: files, + filesTotalCount: filesTotalCount, + graphQLErrors: errors, + actions: Object.assign({}, actions, { + files: Object.assign({}, actions.files, { + readFiles: refetch + }) + }) + }; + } +}; + +var READ = _Injector.graphqlTemplates.READ; + +var query = { + apolloConfig: apolloConfig, + templateName: READ, + pluralName: 'Files', + pagination: false, + params: { + limit: 'Int!', + offset: 'Int!', + rootFilter: 'FileFilterInput', + childrenFilter: 'FileFilterInput', + sortBy: '[ChildrenSortInputType]' + }, + args: { + 'root': { + filter: 'rootFilter' + }, + 'root/edges/node/...on Folder/children': { + limit: 'limit', + offset: 'offset', + filter: 'childrenFilter', + sortBy: 'sortBy' + } + }, + fragments: ['FileInterfaceFields', 'FileFields', 'FolderFields'], + fields: ['pageInfo', ['totalCount'], 'edges', ['node', ['...FileInterfaceFields', '...FileFields', '...on Folder', ['children', ['pageInfo', ['totalCount'], 'edges', ['node', ['...FileInterfaceFields', '...FileFields', '...FolderFields']]], 'parents', ['id', 'title']]]]] +}; +exports.default = query; + +/***/ }), + +/***/ "./client/src/state/files/unpublishFilesMutation.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.config = exports.mutation = undefined; + +var _reactApollo = __webpack_require__(8); + +var _buildPublicationMutation = __webpack_require__("./client/src/state/files/buildPublicationMutation.js"); + +var _buildPublicationMutation2 = _interopRequireDefault(_buildPublicationMutation); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var _buildPublicationMuta = (0, _buildPublicationMutation2.default)('unpublishFiles'), + mutation = _buildPublicationMuta.mutation, + config = _buildPublicationMuta.config; + +exports.mutation = mutation; +exports.config = config; +exports.default = (0, _reactApollo.graphql)(mutation, config); + +/***/ }), + +/***/ "./client/src/state/gallery/GalleryActionTypes.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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; } + +exports.default = ['SET_LAST_SELECTED', 'SET_SELECTED_FILES', 'DESELECT_FILES', 'SELECT_FILES', 'LOAD_FILE_REQUEST', 'LOAD_FILE_SUCCESS', 'HIGHLIGHT_FILES', 'UPDATE_BATCH_ACTIONS', 'SET_NOTICE_MESSAGE', 'SET_ERROR_MESSAGE', 'SET_ENABLE_DROPZONE', 'SET_FILE_BADGE', 'CLEAR_FILE_BADGE', 'ACTIVATE_MODAL', 'DEACTIVATE_MODAL', 'CONCATENATE_SELECT', 'SET_LOADING'].reduce(function (obj, item) { + return Object.assign(obj, _defineProperty({}, item, 'GALLERY.' + item)); +}, {}); + +/***/ }), + +/***/ "./client/src/state/gallery/GalleryActions.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setLastSelected = setLastSelected; +exports.setSelectedFiles = setSelectedFiles; +exports.loadFile = loadFile; +exports.selectFiles = selectFiles; +exports.setConcatenateSelect = setConcatenateSelect; +exports.deselectFiles = deselectFiles; +exports.setNoticeMessage = setNoticeMessage; +exports.setErrorMessage = setErrorMessage; +exports.setEnableDropzone = setEnableDropzone; +exports.clearFileBadge = clearFileBadge; +exports.setFileBadge = setFileBadge; +exports.activateModal = activateModal; +exports.deactivateModal = deactivateModal; +exports.setLoading = setLoading; + +var _GalleryActionTypes = __webpack_require__("./client/src/state/gallery/GalleryActionTypes.js"); + +var _GalleryActionTypes2 = _interopRequireDefault(_GalleryActionTypes); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function setLastSelected(id) { + return function (dispatch) { + dispatch({ + type: _GalleryActionTypes2.default.SET_LAST_SELECTED, + payload: { id: id } + }); + }; +} + +function setSelectedFiles(files) { + return function (dispatch) { + dispatch({ + type: _GalleryActionTypes2.default.SET_SELECTED_FILES, + payload: { files: files } + }); + }; +} + +function loadFile(id, file) { + return function (dispatch) { + dispatch({ + type: _GalleryActionTypes2.default.LOAD_FILE_SUCCESS, + payload: { + id: id, + file: file + } + }); + }; +} + +function selectFiles() { + var ids = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; + + return function (dispatch) { + return dispatch({ + type: _GalleryActionTypes2.default.SELECT_FILES, + payload: { ids: ids } + }); + }; +} + +function setConcatenateSelect(concat) { + return function (dispatch) { + return dispatch({ + type: _GalleryActionTypes2.default.CONCATENATE_SELECT, + payload: !!concat + }); + }; +} +function deselectFiles() { + var ids = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; + + return function (dispatch) { + return dispatch({ + type: _GalleryActionTypes2.default.DESELECT_FILES, + payload: { ids: ids } + }); + }; +} + +function setNoticeMessage(message) { + return function (dispatch) { + return dispatch({ + type: _GalleryActionTypes2.default.SET_NOTICE_MESSAGE, + payload: { message: message } + }); + }; +} + +function setErrorMessage(message) { + return function (dispatch) { + return dispatch({ + type: _GalleryActionTypes2.default.SET_ERROR_MESSAGE, + payload: { message: message } + }); + }; +} + +function setEnableDropzone(enableDropzone) { + return function (dispatch) { + return dispatch({ + type: _GalleryActionTypes2.default.SET_ENABLE_DROPZONE, + payload: { enableDropzone: enableDropzone } + }); + }; +} + +function clearFileBadge(id) { + return function (dispatch) { + dispatch({ + type: _GalleryActionTypes2.default.CLEAR_FILE_BADGE, + payload: { id: id } + }); + }; +} + +function setFileBadge(id, message, status, duration) { + return function (dispatch, getState) { + var _getState = getState(), + assetAdmin = _getState.assetAdmin; + + var badge = assetAdmin.gallery.badges.find(function (item) { + return item.id === id; + }); + + if (badge && badge.timer) { + clearTimeout(badge.timer); + } + var timer = duration > 0 ? setTimeout(function () { + return clearFileBadge(id)(dispatch); + }, duration) : null; + + dispatch({ + type: _GalleryActionTypes2.default.SET_FILE_BADGE, + payload: { id: id, message: message, status: status, timer: timer } + }); + }; +} + +function activateModal(name) { + return function (dispatch) { + dispatch({ + type: _GalleryActionTypes2.default.ACTIVATE_MODAL, + payload: name + }); + }; +} + +function deactivateModal() { + return function (dispatch) { + dispatch({ + type: _GalleryActionTypes2.default.DEACTIVATE_MODAL + }); + }; +} + +function setLoading(active) { + return function (dispatch) { + dispatch({ + type: _GalleryActionTypes2.default.SET_LOADING, + payload: !!active + }); + }; +} + +/***/ }), + +/***/ "./client/src/state/gallery/GalleryReducer.js": +/***/ (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; }; + +exports.default = galleryReducer; + +var _deepFreezeStrict = __webpack_require__(13); + +var _deepFreezeStrict2 = _interopRequireDefault(_deepFreezeStrict); + +var _GalleryActionTypes = __webpack_require__("./client/src/state/gallery/GalleryActionTypes.js"); + +var _GalleryActionTypes2 = _interopRequireDefault(_GalleryActionTypes); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var initialState = { + selectedFiles: [], + errorMessage: null, + noticeMessage: null, + enableDropzone: true, + modal: null, + badges: [], + concatenateSelect: false, + loading: false, + + sorters: [{ + field: 'title', + direction: 'asc', + label: _i18n2.default._t('AssetAdmin.FILTER_TITLE_ASC', 'title a-z') + }, { + field: 'title', + direction: 'desc', + label: _i18n2.default._t('AssetAdmin.FILTER_TITLE_DESC', 'title z-a') + }, { + field: 'lastEdited', + direction: 'desc', + label: _i18n2.default._t('AssetAdmin.FILTER_DATE_DESC', 'newest') + }, { + field: 'lastEdited', + direction: 'asc', + label: _i18n2.default._t('AssetAdmin.FILTER_DATE_ASC', 'oldest') + }], + lastSelected: null +}; + +function galleryReducer() { + var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState; + + var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, + type = _ref.type, + payload = _ref.payload; + + switch (type) { + case _GalleryActionTypes2.default.SET_LAST_SELECTED: + { + return _extends({}, state, { + lastSelected: payload.id + }); + } + case _GalleryActionTypes2.default.SET_FILE_BADGE: + { + return _extends({}, state, { + badges: state.badges.filter(function (badge) { + return badge.id !== payload.id; + }).concat([payload]) + }); + } + + case _GalleryActionTypes2.default.CLEAR_FILE_BADGE: + { + return _extends({}, state, { + badges: state.badges.filter(function (badge) { + return badge.id !== payload.id; + }) + }); + } + + case _GalleryActionTypes2.default.SET_ENABLE_DROPZONE: + { + return _extends({}, state, { + enableDropzone: payload.enableDropzone + }); + } + + case _GalleryActionTypes2.default.SET_NOTICE_MESSAGE: + { + return _extends({}, state, { + noticeMessage: payload.message + }); + } + + case _GalleryActionTypes2.default.SET_ERROR_MESSAGE: + { + return _extends({}, state, { + errorMessage: payload.message + }); + } + + case _GalleryActionTypes2.default.LOAD_FILE_SUCCESS: + { + var oldFile = state.files.find(function (file) { + return file.id === payload.id; + }); + if (oldFile) { + var updatedFile = _extends({}, oldFile, payload.file); + + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + files: state.files.map(function (file) { + return file.id === updatedFile.id ? updatedFile : file; + }) + })); + } else if (state.folder.id === payload.id) { + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + folder: _extends({}, state.folder, payload.file) + })); + } + return state; + } + + case _GalleryActionTypes2.default.SET_SELECTED_FILES: + { + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + selectedFiles: Array.isArray(payload.files) ? payload.files : [] + })); + } + + case _GalleryActionTypes2.default.SELECT_FILES: + { + var selectedFiles = null; + + if (payload.ids === null) { + selectedFiles = state.files.map(function (file) { + return file.id; + }); + } else { + selectedFiles = state.selectedFiles.concat(payload.ids.filter(function (id) { + return state.selectedFiles.indexOf(id) === -1; + })); + } + + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + selectedFiles: selectedFiles + })); + } + + case _GalleryActionTypes2.default.DESELECT_FILES: + { + var _selectedFiles = null; + if (payload.ids === null) { + _selectedFiles = []; + } else { + _selectedFiles = state.selectedFiles.filter(function (id) { + return payload.ids.indexOf(id) === -1; + }); + } + + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + selectedFiles: _selectedFiles + })); + } + + case _GalleryActionTypes2.default.ACTIVATE_MODAL: + { + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + modal: payload + })); + } + + case _GalleryActionTypes2.default.DEACTIVATE_MODAL: + { + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + modal: null + })); + } + + case _GalleryActionTypes2.default.CONCATENATE_SELECT: + { + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + concatenateSelect: payload + })); + } + + case _GalleryActionTypes2.default.SET_LOADING: + { + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + loading: payload + })); + } + + default: + return state; + } +} + +/***/ }), + +/***/ "./client/src/state/imageLoad/ImageLoadActionHandler.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.defaultImageFactory = undefined; + +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; }; }(); + +var _ImageLoadStatus = __webpack_require__("./client/src/state/imageLoad/ImageLoadStatus.js"); + +var _ImageLoadStatus2 = _interopRequireDefault(_ImageLoadStatus); + +var _ImageLoadLocker = __webpack_require__("./client/src/state/imageLoad/ImageLoadLocker.js"); + +var _ImageLoadLocker2 = _interopRequireDefault(_ImageLoadLocker); + +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 defaultOptions = { + minRetry: 0, + maxRetry: 0, + expiry: 0, + + onStatusChange: function onStatusChange() { + return null; + }, + onRetry: function onRetry() { + return null; + }, + onReset: function onReset() { + return null; + }, + onTimeout: function onTimeout() { + return null; + } +}; + +var defaultImageFactory = function defaultImageFactory(url, resolve, reject) { + var img = new Image(); + img.onload = resolve; + img.onerror = reject; + img.src = url; +}; + +var ImageLoadActionHandler = function () { + function ImageLoadActionHandler(options) { + var factory = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultImageFactory; + + _classCallCheck(this, ImageLoadActionHandler); + + this.options = _extends({}, defaultOptions, options); + this.factory = factory; + } + + _createClass(ImageLoadActionHandler, [{ + key: 'loadImage', + value: function loadImage(url) { + if (!this.options.minRetry) { + return null; + } + + if (!_ImageLoadLocker2.default.lock(url)) { + return null; + } + + return this.loadImageLoop(url, this.options.minRetry); + } + }, { + key: 'loadImageLoop', + value: function loadImageLoop(url, retryAfter) { + var _this = this; + + this.options.onStatusChange(url, _ImageLoadStatus2.default.LOADING); + + return new Promise(function (resolve, reject) { + return _this.factory(url, resolve, reject); + }).then(function () { + return _this.handleSuccess(url); + }).catch(function () { + return _this.handleError(url, retryAfter); + }); + } + }, { + key: 'handleReset', + value: function handleReset(url, resolve) { + this.options.onReset(url); + resolve(); + } + }, { + key: 'handleTimeout', + value: function handleTimeout(callback, delay) { + var id = setTimeout(callback, delay); + this.options.onTimeout(id, delay); + return id; + } + }, { + key: 'handleSuccess', + value: function handleSuccess(url) { + _ImageLoadLocker2.default.unlock(url); + this.options.onStatusChange(url, _ImageLoadStatus2.default.SUCCESS); + } + }, { + key: 'handleFailure', + value: function handleFailure(url) { + var _this2 = this; + + _ImageLoadLocker2.default.unlock(url); + this.options.onStatusChange(url, _ImageLoadStatus2.default.FAILED); + + if (this.options.expiry) { + return new Promise(function (resolve) { + _this2.handleTimeout(function () { + return _this2.handleReset(url, resolve); + }, _this2.options.expiry * 1000); + }); + } + + return null; + } + }, { + key: 'handleError', + value: function handleError(url, retryAfter) { + if (retryAfter > this.options.maxRetry) { + return this.handleFailure(url); + } + + this.options.onStatusChange(url, _ImageLoadStatus2.default.WAITING); + + return this.handleRetry(url, retryAfter); + } + }, { + key: 'handleRetry', + value: function handleRetry(url, retryAfter) { + var _this3 = this; + + var promise = new Promise(function (resolve) { + _this3.handleTimeout(function () { + return resolve(_this3.loadImageLoop(url, retryAfter * 2)); + }, retryAfter * 1000); + }); + this.options.onRetry(url, retryAfter, promise); + return promise; + } + }, { + key: 'setOnRetry', + value: function setOnRetry(callback) { + this.options.onRetry = callback; + } + }, { + key: 'setOnReset', + value: function setOnReset(callback) { + this.options.onReset = callback; + } + }, { + key: 'setOnStatusChange', + value: function setOnStatusChange(callback) { + this.options.onStatusChange = callback; + } + }, { + key: 'setOnTimeout', + value: function setOnTimeout(callback) { + this.options.onTimeout = callback; + } + }]); + + return ImageLoadActionHandler; +}(); + +exports.defaultImageFactory = defaultImageFactory; +exports.default = ImageLoadActionHandler; + +/***/ }), + +/***/ "./client/src/state/imageLoad/ImageLoadActionTypes.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = { + SET_STATUS: 'IMAGE_LOAD_SET_STATUS', + RESET: 'IMAGE_LOAD_RESET' }; + +/***/ }), + +/***/ "./client/src/state/imageLoad/ImageLoadActions.js": +/***/ (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; }; + +exports.loadImage = loadImage; + +var _ImageLoadActionTypes = __webpack_require__("./client/src/state/imageLoad/ImageLoadActionTypes.js"); + +var _ImageLoadActionTypes2 = _interopRequireDefault(_ImageLoadActionTypes); + +var _ImageLoadActionHandler = __webpack_require__("./client/src/state/imageLoad/ImageLoadActionHandler.js"); + +var _ImageLoadActionHandler2 = _interopRequireDefault(_ImageLoadActionHandler); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function loadImage(url, options) { + return function (dispatch, getState) { + if (!url) { + return null; + } + + var state = getState(); + var currentFile = state.assetAdmin.imageLoad.files.find(function (file) { + return file.url === url; + }); + if (currentFile) { + return null; + } + + var loadOptions = _extends({}, options, { + onStatusChange: function onStatusChange(statusURL, status) { + return dispatch({ + type: _ImageLoadActionTypes2.default.SET_STATUS, + payload: { status: status, url: statusURL } + }); + }, + onReset: function onReset(statusURL) { + return dispatch({ + type: _ImageLoadActionTypes2.default.RESET, + payload: { url: statusURL } + }); + } + }); + + var handler = new _ImageLoadActionHandler2.default(loadOptions); + return handler.loadImage(url); + }; +} + +/***/ }), + +/***/ "./client/src/state/imageLoad/ImageLoadLocker.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +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 _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +var ImageLoadLocker = function () { + function ImageLoadLocker() { + _classCallCheck(this, ImageLoadLocker); + + this.urls = []; + } + + _createClass(ImageLoadLocker, [{ + key: "lock", + value: function lock(url) { + var index = this.urls.indexOf(url); + if (index >= 0) { + return false; + } + this.urls = [].concat(_toConsumableArray(this.urls), [url]); + return true; + } + }, { + key: "unlock", + value: function unlock(url) { + this.urls = this.urls.filter(function (next) { + return next !== url; + }); + } + }]); + + return ImageLoadLocker; +}(); + +window.ss = window.ss || {}; +window.ss.imagelocker = window.ss.imagelocker || new ImageLoadLocker(); + +exports.Component = ImageLoadLocker; +exports.default = window.ss.imagelocker; + +/***/ }), + +/***/ "./client/src/state/imageLoad/ImageLoadReducer.js": +/***/ (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; }; + +exports.default = imageLoadReducer; + +var _ImageLoadActionTypes = __webpack_require__("./client/src/state/imageLoad/ImageLoadActionTypes.js"); + +var _ImageLoadActionTypes2 = _interopRequireDefault(_ImageLoadActionTypes); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } + +var initialState = { + files: [] }; + +function imageLoadReducer() { + var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState; + + var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, + type = _ref.type, + payload = _ref.payload; + + switch (type) { + case _ImageLoadActionTypes2.default.SET_STATUS: + { + return _extends({}, state, { + files: [].concat(_toConsumableArray(state.files.filter(function (file) { + return file.url !== payload.url; + })), [payload]) + }); + } + + case _ImageLoadActionTypes2.default.RESET: + { + return _extends({}, state, { + files: [].concat(_toConsumableArray(state.files.filter(function (file) { + return file.url !== payload.url; + }))) + }); + } + + default: + return state; + } +} + +/***/ }), + +/***/ "./client/src/state/imageLoad/ImageLoadStatus.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = { + DISABLED: 'DISABLED', + NONE: 'NONE', + SUCCESS: 'SUCCESS', + LOADING: 'LOADING', + WAITING: 'WAITING', + FAILED: 'FAILED' }; + +/***/ }), + +/***/ "./client/src/state/previewField/PreviewFieldActionTypes.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = { + PREVIEWFIELD_ADD_FILE: 'PREVIEWFIELD_ADD_FILE', + PREVIEWFIELD_REMOVE_FILE: 'PREVIEWFIELD_REMOVE_FILE', + PREVIEWFIELD_UPDATE_FILE: 'PREVIEWFIELD_UPDATE_FILE', + PREVIEWFIELD_FAIL_UPLOAD: 'PREVIEWFIELD_FAIL_UPLOAD' +}; + +/***/ }), + +/***/ "./client/src/state/previewField/PreviewFieldActions.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.removeFile = removeFile; +exports.addFile = addFile; +exports.failUpload = failUpload; +exports.updateFile = updateFile; + +var _PreviewFieldActionTypes = __webpack_require__("./client/src/state/previewField/PreviewFieldActionTypes.js"); + +var _PreviewFieldActionTypes2 = _interopRequireDefault(_PreviewFieldActionTypes); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function removeFile(id) { + return { + type: _PreviewFieldActionTypes2.default.PREVIEWFIELD_REMOVE_FILE, + payload: { id: id } + }; +} + +function addFile(id, file) { + return { + type: _PreviewFieldActionTypes2.default.PREVIEWFIELD_ADD_FILE, + payload: { id: id, file: file } + }; +} + +function failUpload(id, message) { + return { + type: _PreviewFieldActionTypes2.default.PREVIEWFIELD_FAIL_UPLOAD, + payload: { id: id, message: message } + }; +} + +function updateFile(id, data) { + return { + type: _PreviewFieldActionTypes2.default.PREVIEWFIELD_UPDATE_FILE, + payload: { id: id, data: data } + }; +} + +/***/ }), + +/***/ "./client/src/state/previewField/PreviewFieldReducer.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _deepFreezeStrict = __webpack_require__(13); + +var _deepFreezeStrict2 = _interopRequireDefault(_deepFreezeStrict); + +var _PreviewFieldActionTypes = __webpack_require__("./client/src/state/previewField/PreviewFieldActionTypes.js"); + +var _PreviewFieldActionTypes2 = _interopRequireDefault(_PreviewFieldActionTypes); + +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 initialState = {}; + +function previewFieldReducer() { + var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState; + var action = arguments[1]; + + switch (action.type) { + case _PreviewFieldActionTypes2.default.PREVIEWFIELD_ADD_FILE: + { + return (0, _deepFreezeStrict2.default)(Object.assign({}, state, _defineProperty({}, action.payload.id, action.payload.file))); + } + + case _PreviewFieldActionTypes2.default.PREVIEWFIELD_FAIL_UPLOAD: + { + return (0, _deepFreezeStrict2.default)(Object.assign({}, state, _defineProperty({}, action.payload.id, Object.assign({}, state[action.payload.id], action.payload.message)))); + } + + case _PreviewFieldActionTypes2.default.PREVIEWFIELD_REMOVE_FILE: + { + return (0, _deepFreezeStrict2.default)(Object.assign({}, state, _defineProperty({}, action.payload.id, undefined))); + } + + case _PreviewFieldActionTypes2.default.PREVIEWFIELD_UPDATE_FILE: + { + return (0, _deepFreezeStrict2.default)(Object.assign({}, state, _defineProperty({}, action.payload.id, Object.assign({}, state[action.payload.id], action.payload.data)))); + } + + default: + return state; + } +} + +exports.default = previewFieldReducer; + +/***/ }), + +/***/ "./client/src/state/queuedFiles/QueuedFilesActionTypes.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = { + ADD_QUEUED_FILE: 'ADD_QUEUED_FILE', + FAIL_UPLOAD: 'FAIL_UPLOAD', + PURGE_UPLOAD_QUEUE: 'PURGE_UPLOAD_QUEUE', + REMOVE_QUEUED_FILE: 'REMOVE_QUEUED_FILE', + SUCCEED_UPLOAD: 'SUCCEED_UPLOAD', + UPDATE_QUEUED_FILE: 'UPDATE_QUEUED_FILE' +}; + +/***/ }), + +/***/ "./client/src/state/queuedFiles/QueuedFilesActions.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.addQueuedFile = addQueuedFile; +exports.failUpload = failUpload; +exports.purgeUploadQueue = purgeUploadQueue; +exports.removeQueuedFile = removeQueuedFile; +exports.succeedUpload = succeedUpload; +exports.updateQueuedFile = updateQueuedFile; + +var _QueuedFilesActionTypes = __webpack_require__("./client/src/state/queuedFiles/QueuedFilesActionTypes.js"); + +var _QueuedFilesActionTypes2 = _interopRequireDefault(_QueuedFilesActionTypes); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function addQueuedFile(file) { + return function (dispatch) { + return dispatch({ + type: _QueuedFilesActionTypes2.default.ADD_QUEUED_FILE, + payload: { file: file } + }); + }; +} + +function failUpload(queuedId, response) { + return function (dispatch) { + var message = response.message; + if (response.errors && response.errors.length) { + message = response.errors[0]; + } + + if (typeof response === 'string') { + message = { + value: response, + type: 'error' + }; + } + return dispatch({ + type: _QueuedFilesActionTypes2.default.FAIL_UPLOAD, + payload: { + queuedId: queuedId, + message: message + } + }); + }; +} + +function purgeUploadQueue() { + return function (dispatch) { + return dispatch({ + type: _QueuedFilesActionTypes2.default.PURGE_UPLOAD_QUEUE, + payload: null + }); + }; +} + +function removeQueuedFile(queuedId) { + return function (dispatch) { + return dispatch({ + type: _QueuedFilesActionTypes2.default.REMOVE_QUEUED_FILE, + payload: { queuedId: queuedId } + }); + }; +} + +function succeedUpload(queuedId, json) { + return function (dispatch) { + return dispatch({ + type: _QueuedFilesActionTypes2.default.SUCCEED_UPLOAD, + payload: { queuedId: queuedId, json: json } + }); + }; +} + +function updateQueuedFile(queuedId, updates) { + return function (dispatch) { + return dispatch({ + type: _QueuedFilesActionTypes2.default.UPDATE_QUEUED_FILE, + payload: { queuedId: queuedId, updates: updates } + }); + }; +} + +/***/ }), + +/***/ "./client/src/state/queuedFiles/QueuedFilesReducer.js": +/***/ (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 _deepFreezeStrict = __webpack_require__(13); + +var _deepFreezeStrict2 = _interopRequireDefault(_deepFreezeStrict); + +var _QueuedFilesActionTypes = __webpack_require__("./client/src/state/queuedFiles/QueuedFilesActionTypes.js"); + +var _QueuedFilesActionTypes2 = _interopRequireDefault(_QueuedFilesActionTypes); + +var _fileStructure = __webpack_require__("./client/src/lib/fileStructure.js"); + +var _fileStructure2 = _interopRequireDefault(_fileStructure); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } + +var initialState = { + items: [] +}; + +function queuedFilesReducer() { + var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState; + var action = arguments[1]; + + switch (action.type) { + case _QueuedFilesActionTypes2.default.ADD_QUEUED_FILE: + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + items: [].concat(_toConsumableArray(state.items), [_extends({}, _fileStructure2.default, action.payload.file)]) + })); + + case _QueuedFilesActionTypes2.default.FAIL_UPLOAD: + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + items: state.items.map(function (file) { + if (file.queuedId === action.payload.queuedId) { + return _extends({}, file, { + message: action.payload.message + }); + } + + return file; + }) + })); + + case _QueuedFilesActionTypes2.default.PURGE_UPLOAD_QUEUE: + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + items: state.items.filter(function (file) { + return !file.id; + }) + })); + + case _QueuedFilesActionTypes2.default.REMOVE_QUEUED_FILE: + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + items: state.items.filter(function (file) { + return file.queuedId !== action.payload.queuedId; + }) + })); + + case _QueuedFilesActionTypes2.default.SUCCEED_UPLOAD: + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + items: state.items.map(function (file) { + if (file.queuedId === action.payload.queuedId) { + return _extends({}, file, action.payload.json, { + messages: [{ + value: _i18n2.default._t('AssetAdmin.DROPZONE_SUCCESS_UPLOAD'), + type: 'success', + extraClass: 'success' + }] + }); + } + return file; + }) + })); + + case _QueuedFilesActionTypes2.default.UPDATE_QUEUED_FILE: + return (0, _deepFreezeStrict2.default)(_extends({}, state, { + items: state.items.map(function (file) { + if (file.queuedId === action.payload.queuedId) { + return _extends({}, file, action.payload.updates); + } + + return file; + }) + })); + + default: + return state; + } +} + +exports.default = queuedFilesReducer; + +/***/ }), + +/***/ "./client/src/state/uploadField/UploadFieldActionTypes.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = { + UPLOADFIELD_ADD_FILE: 'UPLOADFIELD_ADD_FILE', + UPLOADFIELD_SET_FILES: 'UPLOADFIELD_SET_FILES', + UPLOADFIELD_REMOVE_FILE: 'UPLOADFIELD_REMOVE_FILE', + UPLOADFIELD_UPLOAD_FAILURE: 'UPLOADFIELD_UPLOAD_FAILURE', + UPLOADFIELD_UPLOAD_SUCCESS: 'UPLOADFIELD_UPLOAD_SUCCESS', + UPLOADFIELD_UPDATE_QUEUED_FILE: 'UPLOADFIELD_UPDATE_QUEUED_FILE' +}; + +/***/ }), + +/***/ "./client/src/state/uploadField/UploadFieldActions.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.addFile = addFile; +exports.setFiles = setFiles; +exports.failUpload = failUpload; +exports.removeFile = removeFile; +exports.succeedUpload = succeedUpload; +exports.updateQueuedFile = updateQueuedFile; + +var _UploadFieldActionTypes = __webpack_require__("./client/src/state/uploadField/UploadFieldActionTypes.js"); + +var _UploadFieldActionTypes2 = _interopRequireDefault(_UploadFieldActionTypes); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function addFile(fieldId, file) { + return function (dispatch) { + return dispatch({ + type: _UploadFieldActionTypes2.default.UPLOADFIELD_ADD_FILE, + payload: { fieldId: fieldId, file: file } + }); + }; +} + +function setFiles(fieldId, files) { + return function (dispatch) { + return dispatch({ + type: _UploadFieldActionTypes2.default.UPLOADFIELD_SET_FILES, + payload: { fieldId: fieldId, files: files } + }); + }; +} + +function failUpload(fieldId, queuedId, response) { + return function (dispatch) { + var message = response.message; + + if (typeof response === 'string') { + message = { + value: response, + type: 'error' + }; + } + return dispatch({ + type: _UploadFieldActionTypes2.default.UPLOADFIELD_UPLOAD_FAILURE, + payload: { fieldId: fieldId, queuedId: queuedId, message: message } + }); + }; +} + +function removeFile(fieldId, file) { + return function (dispatch) { + return dispatch({ + type: _UploadFieldActionTypes2.default.UPLOADFIELD_REMOVE_FILE, + payload: { fieldId: fieldId, file: file } + }); + }; +} + +function succeedUpload(fieldId, queuedId, json) { + return function (dispatch) { + return dispatch({ + type: _UploadFieldActionTypes2.default.UPLOADFIELD_UPLOAD_SUCCESS, + payload: { fieldId: fieldId, queuedId: queuedId, json: json } + }); + }; +} + +function updateQueuedFile(fieldId, queuedId, updates) { + return function (dispatch) { + return dispatch({ + type: _UploadFieldActionTypes2.default.UPLOADFIELD_UPDATE_QUEUED_FILE, + payload: { fieldId: fieldId, queuedId: queuedId, updates: updates } + }); + }; +} + +/***/ }), + +/***/ "./client/src/state/uploadField/UploadFieldReducer.js": +/***/ (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 _UploadFieldActionTypes = __webpack_require__("./client/src/state/uploadField/UploadFieldActionTypes.js"); + +var _UploadFieldActionTypes2 = _interopRequireDefault(_UploadFieldActionTypes); + +var _fileStructure = __webpack_require__("./client/src/lib/fileStructure.js"); + +var _fileStructure2 = _interopRequireDefault(_fileStructure); + +var _reduxFieldReducer = __webpack_require__(40); + +var _reduxFieldReducer2 = _interopRequireDefault(_reduxFieldReducer); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } + +var initialState = { + fields: {} +}; + +var initialFieldState = { files: [] }; + +function uploadFieldReducer() { + var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState; + var action = arguments[1]; + + var reduceField = (0, _reduxFieldReducer2.default)(state, action, initialFieldState); + + switch (action.type) { + case _UploadFieldActionTypes2.default.UPLOADFIELD_ADD_FILE: + return reduceField(function (field) { + if (field.files.find(function (file) { + return file.id === action.payload.file.id; + })) { + return field; + } + return _extends({}, field, { + files: [].concat(_toConsumableArray(field.files), [_extends({}, _fileStructure2.default, action.payload.file)]) + }); + }); + + case _UploadFieldActionTypes2.default.UPLOADFIELD_SET_FILES: + return reduceField(function () { + return { files: action.payload.files }; + }); + + case _UploadFieldActionTypes2.default.UPLOADFIELD_UPLOAD_FAILURE: + return reduceField(function (field) { + return { + files: field.files.map(function (file) { + if (file.queuedId === action.payload.queuedId) { + return Object.assign({}, file, { + message: action.payload.message + }); + } + return file; + }) + }; + }); + + case _UploadFieldActionTypes2.default.UPLOADFIELD_REMOVE_FILE: + return reduceField(function (field) { + return { + files: field.files.filter(function (file) { + return !(action.payload.file.queuedId && file.queuedId === action.payload.file.queuedId || action.payload.file.id && file.id === action.payload.file.id); + }) + }; + }); + + case _UploadFieldActionTypes2.default.UPLOADFIELD_UPLOAD_SUCCESS: + return reduceField(function (field) { + return { + files: field.files.map(function (file) { + if (file.queuedId === action.payload.queuedId) { + return Object.assign({}, file, action.payload.json); + } + return file; + }) + }; + }); + + case _UploadFieldActionTypes2.default.UPLOADFIELD_UPDATE_QUEUED_FILE: + return reduceField(function (field) { + return { + files: field.files.map(function (file) { + if (file.queuedId === action.payload.queuedId) { + return Object.assign({}, file, action.payload.updates); + } + return file; + }) + }; + }); + + default: + return state; + } +} + +exports.default = uploadFieldReducer; + +/***/ }), + +/***/ "./client/src/transforms/AssetAdmin/insertAssetModal.js": +/***/ (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 _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var insertAssetModal = function insertAssetModal(form) { + var schema = form.getState(); + var overrides = schema.stateOverride && schema.stateOverride.fields; + var customTitle = overrides && overrides.length > 0 ? _i18n2.default._t('AssetAdmin.UPDATE_FILE', 'Update file') : _i18n2.default._t('AssetAdmin.INSERT_FILE', 'Insert file'); + + form.mutateField('action_insert', function (field) { + return _extends({}, field, { + title: customTitle || field.title + }); + }); + + return form.getState(); +}; + +exports.default = insertAssetModal; + +/***/ }), + +/***/ "./client/src/transforms/FormAction/ownerAwareUnpublish.js": +/***/ (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 _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _i18n = __webpack_require__(1); + +var _i18n2 = _interopRequireDefault(_i18n); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var ownerAwareUnpublish = function ownerAwareUnpublish(FormAction) { + return function (props) { + var originalOnclick = props.onClick; + var newProps = _extends({}, props, { + onClick: function onClick(e, nameOrID) { + var owners = props.data.owners; + + var message = null; + if (owners && parseInt(owners, 10) > 0) { + message = [_i18n2.default.inject(_i18n2.default._t('AssetAdmin.SINGLE_OWNED_WARNING_1', 'This file is being used in {count} other published section(s).'), { count: owners }), _i18n2.default._t('AssetAdmin.SINGLE_OWNED_WARNING_2', 'Ensure files are removed from content areas prior to unpublishing them. Otherwise, they will appear as broken links.'), _i18n2.default._t('AssetAdmin.SINGLE_OWNED_WARNING_3', 'Do you want to unpublish this file anyway?')].join('\n\n'); + } else { + message = _i18n2.default._t('AssetAdmin.CONFIRMUNPUBLISH', 'Are you sure you want to unpublish this record?'); + } + + if (confirm(message)) { + originalOnclick(e, nameOrID); + } else { + e.preventDefault(); + } + } + }); + + return _react2.default.createElement(FormAction, newProps); + }; +}; + +exports.default = ownerAwareUnpublish; + +/***/ }), + +/***/ "./client/src/transforms/TreeDropdownField/moveTreeDropdownField.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.disabledTreeDropdownField = undefined; + +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 _react = __webpack_require__(0); + +var _react2 = _interopRequireDefault(_react); + +var _reactRedux = __webpack_require__(3); + +var _redux = __webpack_require__(4); + +var _TreeDropdownField = __webpack_require__(37); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var disabledTreeDropdownField = function disabledTreeDropdownField(TreeDropdownField) { + return function (props) { + var disabledIDs = props.disabledIDs; + + var find = props.findTreeByPath || _TreeDropdownField.findTreeByPath; + + + var newProps = _extends({}, props, { + findTreeByPath: function findTreeByPath(tree, visible) { + var visibleTree = find(tree, visible); + var pathDisabled = visible.some(function (id) { + return disabledIDs.includes(id); + }); + return visibleTree ? _extends({}, visibleTree, { + children: visibleTree.children.map(function (child) { + return _extends({}, child, { + disabled: pathDisabled || disabledIDs.includes(child.id) + }); + }) + }) : null; + } + }); + + return _react2.default.createElement(TreeDropdownField, newProps); + }; +}; + +var moveTreeDropdownField = (0, _redux.compose)((0, _reactRedux.connect)(function (state) { + return { + disabledIDs: state.assetAdmin.gallery.selectedFiles + }; +}), disabledTreeDropdownField); + +exports.disabledTreeDropdownField = disabledTreeDropdownField; +exports.default = moveTreeDropdownField; + +/***/ }), + +/***/ "./node_modules/lodash/_Hash.js": +/***/ (function(module, exports, __webpack_require__) { + +var hashClear = __webpack_require__("./node_modules/lodash/_hashClear.js"), + hashDelete = __webpack_require__("./node_modules/lodash/_hashDelete.js"), + hashGet = __webpack_require__("./node_modules/lodash/_hashGet.js"), + hashHas = __webpack_require__("./node_modules/lodash/_hashHas.js"), + hashSet = __webpack_require__("./node_modules/lodash/_hashSet.js"); + +/** + * Creates a hash object. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function Hash(entries) { + var index = -1, + length = entries == null ? 0 : entries.length; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } +} + +// Add methods to `Hash`. +Hash.prototype.clear = hashClear; +Hash.prototype['delete'] = hashDelete; +Hash.prototype.get = hashGet; +Hash.prototype.has = hashHas; +Hash.prototype.set = hashSet; + +module.exports = Hash; + + +/***/ }), + +/***/ "./node_modules/lodash/_ListCache.js": +/***/ (function(module, exports, __webpack_require__) { + +var listCacheClear = __webpack_require__("./node_modules/lodash/_listCacheClear.js"), + listCacheDelete = __webpack_require__("./node_modules/lodash/_listCacheDelete.js"), + listCacheGet = __webpack_require__("./node_modules/lodash/_listCacheGet.js"), + listCacheHas = __webpack_require__("./node_modules/lodash/_listCacheHas.js"), + listCacheSet = __webpack_require__("./node_modules/lodash/_listCacheSet.js"); + +/** + * Creates an list cache object. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function ListCache(entries) { + var index = -1, + length = entries == null ? 0 : entries.length; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } +} + +// Add methods to `ListCache`. +ListCache.prototype.clear = listCacheClear; +ListCache.prototype['delete'] = listCacheDelete; +ListCache.prototype.get = listCacheGet; +ListCache.prototype.has = listCacheHas; +ListCache.prototype.set = listCacheSet; + +module.exports = ListCache; + + +/***/ }), + +/***/ "./node_modules/lodash/_Map.js": +/***/ (function(module, exports, __webpack_require__) { + +var getNative = __webpack_require__("./node_modules/lodash/_getNative.js"), + root = __webpack_require__("./node_modules/lodash/_root.js"); + +/* Built-in method references that are verified to be native. */ +var Map = getNative(root, 'Map'); + +module.exports = Map; + + +/***/ }), + +/***/ "./node_modules/lodash/_MapCache.js": +/***/ (function(module, exports, __webpack_require__) { + +var mapCacheClear = __webpack_require__("./node_modules/lodash/_mapCacheClear.js"), + mapCacheDelete = __webpack_require__("./node_modules/lodash/_mapCacheDelete.js"), + mapCacheGet = __webpack_require__("./node_modules/lodash/_mapCacheGet.js"), + mapCacheHas = __webpack_require__("./node_modules/lodash/_mapCacheHas.js"), + mapCacheSet = __webpack_require__("./node_modules/lodash/_mapCacheSet.js"); + +/** + * Creates a map cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ +function MapCache(entries) { + var index = -1, + length = entries == null ? 0 : entries.length; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } +} + +// Add methods to `MapCache`. +MapCache.prototype.clear = mapCacheClear; +MapCache.prototype['delete'] = mapCacheDelete; +MapCache.prototype.get = mapCacheGet; +MapCache.prototype.has = mapCacheHas; +MapCache.prototype.set = mapCacheSet; + +module.exports = MapCache; + + +/***/ }), + +/***/ "./node_modules/lodash/_Symbol.js": +/***/ (function(module, exports, __webpack_require__) { + +var root = __webpack_require__("./node_modules/lodash/_root.js"); + +/** Built-in value references. */ +var Symbol = root.Symbol; + +module.exports = Symbol; + + +/***/ }), + +/***/ "./node_modules/lodash/_arrayMap.js": +/***/ (function(module, exports) { + +/** + * A specialized version of `_.map` for arrays without support for iteratee + * shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ +function arrayMap(array, iteratee) { + var index = -1, + length = array == null ? 0 : array.length, + result = Array(length); + + while (++index < length) { + result[index] = iteratee(array[index], index, array); + } + return result; +} + +module.exports = arrayMap; + + +/***/ }), + +/***/ "./node_modules/lodash/_assocIndexOf.js": +/***/ (function(module, exports, __webpack_require__) { + +var eq = __webpack_require__("./node_modules/lodash/eq.js"); + +/** + * Gets the index at which the `key` is found in `array` of key-value pairs. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} key The key to search for. + * @returns {number} Returns the index of the matched value, else `-1`. + */ +function assocIndexOf(array, key) { + var length = array.length; + while (length--) { + if (eq(array[length][0], key)) { + return length; + } + } + return -1; +} + +module.exports = assocIndexOf; + + +/***/ }), + +/***/ "./node_modules/lodash/_baseGetTag.js": +/***/ (function(module, exports, __webpack_require__) { + +var Symbol = __webpack_require__("./node_modules/lodash/_Symbol.js"), + getRawTag = __webpack_require__("./node_modules/lodash/_getRawTag.js"), + objectToString = __webpack_require__("./node_modules/lodash/_objectToString.js"); + +/** `Object#toString` result references. */ +var nullTag = '[object Null]', + undefinedTag = '[object Undefined]'; + +/** Built-in value references. */ +var symToStringTag = Symbol ? Symbol.toStringTag : undefined; + +/** + * The base implementation of `getTag` without fallbacks for buggy environments. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. + */ +function baseGetTag(value) { + if (value == null) { + return value === undefined ? undefinedTag : nullTag; + } + return (symToStringTag && symToStringTag in Object(value)) + ? getRawTag(value) + : objectToString(value); +} + +module.exports = baseGetTag; + + +/***/ }), + +/***/ "./node_modules/lodash/_baseIsNative.js": +/***/ (function(module, exports, __webpack_require__) { + +var isFunction = __webpack_require__("./node_modules/lodash/isFunction.js"), + isMasked = __webpack_require__("./node_modules/lodash/_isMasked.js"), + isObject = __webpack_require__("./node_modules/lodash/isObject.js"), + toSource = __webpack_require__("./node_modules/lodash/_toSource.js"); + +/** + * Used to match `RegExp` + * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns). + */ +var reRegExpChar = /[\\^$.*+?()[\]{}|]/g; + +/** Used to detect host constructors (Safari). */ +var reIsHostCtor = /^\[object .+?Constructor\]$/; + +/** Used for built-in method references. */ +var funcProto = Function.prototype, + objectProto = Object.prototype; + +/** Used to resolve the decompiled source of functions. */ +var funcToString = funcProto.toString; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** Used to detect if a method is native. */ +var reIsNative = RegExp('^' + + funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\$&') + .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$' +); + +/** + * The base implementation of `_.isNative` without bad shim checks. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a native function, + * else `false`. + */ +function baseIsNative(value) { + if (!isObject(value) || isMasked(value)) { + return false; + } + var pattern = isFunction(value) ? reIsNative : reIsHostCtor; + return pattern.test(toSource(value)); +} + +module.exports = baseIsNative; + + +/***/ }), + +/***/ "./node_modules/lodash/_baseToString.js": +/***/ (function(module, exports, __webpack_require__) { + +var Symbol = __webpack_require__("./node_modules/lodash/_Symbol.js"), + arrayMap = __webpack_require__("./node_modules/lodash/_arrayMap.js"), + isArray = __webpack_require__("./node_modules/lodash/isArray.js"), + isSymbol = __webpack_require__("./node_modules/lodash/isSymbol.js"); + +/** Used as references for various `Number` constants. */ +var INFINITY = 1 / 0; + +/** Used to convert symbols to primitives and strings. */ +var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolToString = symbolProto ? symbolProto.toString : undefined; + +/** + * The base implementation of `_.toString` which doesn't convert nullish + * values to empty strings. + * + * @private + * @param {*} value The value to process. + * @returns {string} Returns the string. + */ +function baseToString(value) { + // Exit early for strings to avoid a performance hit in some environments. + if (typeof value == 'string') { + return value; + } + if (isArray(value)) { + // Recursively convert values (susceptible to call stack limits). + return arrayMap(value, baseToString) + ''; + } + if (isSymbol(value)) { + return symbolToString ? symbolToString.call(value) : ''; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; +} + +module.exports = baseToString; + + +/***/ }), + +/***/ "./node_modules/lodash/_copyArray.js": +/***/ (function(module, exports) { + +/** + * 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 copyArray(source, array) { + var index = -1, + length = source.length; + + array || (array = Array(length)); + while (++index < length) { + array[index] = source[index]; + } + return array; +} + +module.exports = copyArray; + + +/***/ }), + +/***/ "./node_modules/lodash/_coreJsData.js": +/***/ (function(module, exports, __webpack_require__) { + +var root = __webpack_require__("./node_modules/lodash/_root.js"); + +/** Used to detect overreaching core-js shims. */ +var coreJsData = root['__core-js_shared__']; + +module.exports = coreJsData; + + +/***/ }), + +/***/ "./node_modules/lodash/_freeGlobal.js": +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(global) {/** Detect free variable `global` from Node.js. */ +var freeGlobal = typeof global == 'object' && global && global.Object === Object && global; + +module.exports = freeGlobal; + +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__("../../../node_modules/webpack/buildin/global.js"))) + +/***/ }), + +/***/ "./node_modules/lodash/_getMapData.js": +/***/ (function(module, exports, __webpack_require__) { + +var isKeyable = __webpack_require__("./node_modules/lodash/_isKeyable.js"); + +/** + * Gets the data for `map`. + * + * @private + * @param {Object} map The map to query. + * @param {string} key The reference key. + * @returns {*} Returns the map data. + */ +function getMapData(map, key) { + var data = map.__data__; + return isKeyable(key) + ? data[typeof key == 'string' ? 'string' : 'hash'] + : data.map; +} + +module.exports = getMapData; + + +/***/ }), + +/***/ "./node_modules/lodash/_getNative.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseIsNative = __webpack_require__("./node_modules/lodash/_baseIsNative.js"), + getValue = __webpack_require__("./node_modules/lodash/_getValue.js"); + +/** + * 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 = getValue(object, key); + return baseIsNative(value) ? value : undefined; +} + +module.exports = getNative; + + +/***/ }), + +/***/ "./node_modules/lodash/_getRawTag.js": +/***/ (function(module, exports, __webpack_require__) { + +var Symbol = __webpack_require__("./node_modules/lodash/_Symbol.js"); + +/** Used for built-in 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/7.0/#sec-object.prototype.tostring) + * of values. + */ +var nativeObjectToString = objectProto.toString; + +/** Built-in value references. */ +var symToStringTag = Symbol ? Symbol.toStringTag : undefined; + +/** + * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the raw `toStringTag`. + */ +function getRawTag(value) { + var isOwn = hasOwnProperty.call(value, symToStringTag), + tag = value[symToStringTag]; + + try { + value[symToStringTag] = undefined; + var unmasked = true; + } catch (e) {} + + var result = nativeObjectToString.call(value); + if (unmasked) { + if (isOwn) { + value[symToStringTag] = tag; + } else { + delete value[symToStringTag]; + } + } + return result; +} + +module.exports = getRawTag; + + +/***/ }), + +/***/ "./node_modules/lodash/_getValue.js": +/***/ (function(module, exports) { + +/** + * Gets the value at `key` of `object`. + * + * @private + * @param {Object} [object] The object to query. + * @param {string} key The key of the property to get. + * @returns {*} Returns the property value. + */ +function getValue(object, key) { + return object == null ? undefined : object[key]; +} + +module.exports = getValue; + + +/***/ }), + +/***/ "./node_modules/lodash/_hashClear.js": +/***/ (function(module, exports, __webpack_require__) { + +var nativeCreate = __webpack_require__("./node_modules/lodash/_nativeCreate.js"); + +/** + * Removes all key-value entries from the hash. + * + * @private + * @name clear + * @memberOf Hash + */ +function hashClear() { + this.__data__ = nativeCreate ? nativeCreate(null) : {}; + this.size = 0; +} + +module.exports = hashClear; + + +/***/ }), + +/***/ "./node_modules/lodash/_hashDelete.js": +/***/ (function(module, exports) { + +/** + * Removes `key` and its value from the hash. + * + * @private + * @name delete + * @memberOf Hash + * @param {Object} hash The hash to modify. + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function hashDelete(key) { + var result = this.has(key) && delete this.__data__[key]; + this.size -= result ? 1 : 0; + return result; +} + +module.exports = hashDelete; + + +/***/ }), + +/***/ "./node_modules/lodash/_hashGet.js": +/***/ (function(module, exports, __webpack_require__) { + +var nativeCreate = __webpack_require__("./node_modules/lodash/_nativeCreate.js"); + +/** Used to stand-in for `undefined` hash values. */ +var HASH_UNDEFINED = '__lodash_hash_undefined__'; + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Gets the hash value for `key`. + * + * @private + * @name get + * @memberOf Hash + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function hashGet(key) { + var data = this.__data__; + if (nativeCreate) { + var result = data[key]; + return result === HASH_UNDEFINED ? undefined : result; + } + return hasOwnProperty.call(data, key) ? data[key] : undefined; +} + +module.exports = hashGet; + + +/***/ }), + +/***/ "./node_modules/lodash/_hashHas.js": +/***/ (function(module, exports, __webpack_require__) { + +var nativeCreate = __webpack_require__("./node_modules/lodash/_nativeCreate.js"); + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** Used to check objects for own properties. */ +var hasOwnProperty = objectProto.hasOwnProperty; + +/** + * Checks if a hash value for `key` exists. + * + * @private + * @name has + * @memberOf Hash + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function hashHas(key) { + var data = this.__data__; + return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key); +} + +module.exports = hashHas; + + +/***/ }), + +/***/ "./node_modules/lodash/_hashSet.js": +/***/ (function(module, exports, __webpack_require__) { + +var nativeCreate = __webpack_require__("./node_modules/lodash/_nativeCreate.js"); + +/** Used to stand-in for `undefined` hash values. */ +var HASH_UNDEFINED = '__lodash_hash_undefined__'; + +/** + * Sets the hash `key` to `value`. + * + * @private + * @name set + * @memberOf Hash + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the hash instance. + */ +function hashSet(key, value) { + var data = this.__data__; + this.size += this.has(key) ? 0 : 1; + data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value; + return this; +} + +module.exports = hashSet; + + +/***/ }), + +/***/ "./node_modules/lodash/_isKeyable.js": +/***/ (function(module, exports) { + +/** + * Checks if `value` is suitable for use as unique object key. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is suitable, else `false`. + */ +function isKeyable(value) { + var type = typeof value; + return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean') + ? (value !== '__proto__') + : (value === null); +} + +module.exports = isKeyable; + + +/***/ }), + +/***/ "./node_modules/lodash/_isMasked.js": +/***/ (function(module, exports, __webpack_require__) { + +var coreJsData = __webpack_require__("./node_modules/lodash/_coreJsData.js"); + +/** Used to detect methods masquerading as native. */ +var maskSrcKey = (function() { + var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || ''); + return uid ? ('Symbol(src)_1.' + uid) : ''; +}()); + +/** + * Checks if `func` has its source masked. + * + * @private + * @param {Function} func The function to check. + * @returns {boolean} Returns `true` if `func` is masked, else `false`. + */ +function isMasked(func) { + return !!maskSrcKey && (maskSrcKey in func); +} + +module.exports = isMasked; + + +/***/ }), + +/***/ "./node_modules/lodash/_listCacheClear.js": +/***/ (function(module, exports) { + +/** + * Removes all key-value entries from the list cache. + * + * @private + * @name clear + * @memberOf ListCache + */ +function listCacheClear() { + this.__data__ = []; + this.size = 0; +} + +module.exports = listCacheClear; + + +/***/ }), + +/***/ "./node_modules/lodash/_listCacheDelete.js": +/***/ (function(module, exports, __webpack_require__) { + +var assocIndexOf = __webpack_require__("./node_modules/lodash/_assocIndexOf.js"); + +/** Used for built-in method references. */ +var arrayProto = Array.prototype; + +/** Built-in value references. */ +var splice = arrayProto.splice; + +/** + * Removes `key` and its value from the list cache. + * + * @private + * @name delete + * @memberOf ListCache + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function listCacheDelete(key) { + var data = this.__data__, + index = assocIndexOf(data, key); + + if (index < 0) { + return false; + } + var lastIndex = data.length - 1; + if (index == lastIndex) { + data.pop(); + } else { + splice.call(data, index, 1); + } + --this.size; + return true; +} + +module.exports = listCacheDelete; + + +/***/ }), + +/***/ "./node_modules/lodash/_listCacheGet.js": +/***/ (function(module, exports, __webpack_require__) { + +var assocIndexOf = __webpack_require__("./node_modules/lodash/_assocIndexOf.js"); + +/** + * Gets the list cache value for `key`. + * + * @private + * @name get + * @memberOf ListCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function listCacheGet(key) { + var data = this.__data__, + index = assocIndexOf(data, key); + + return index < 0 ? undefined : data[index][1]; +} + +module.exports = listCacheGet; + + +/***/ }), + +/***/ "./node_modules/lodash/_listCacheHas.js": +/***/ (function(module, exports, __webpack_require__) { + +var assocIndexOf = __webpack_require__("./node_modules/lodash/_assocIndexOf.js"); + +/** + * Checks if a list cache value for `key` exists. + * + * @private + * @name has + * @memberOf ListCache + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function listCacheHas(key) { + return assocIndexOf(this.__data__, key) > -1; +} + +module.exports = listCacheHas; + + +/***/ }), + +/***/ "./node_modules/lodash/_listCacheSet.js": +/***/ (function(module, exports, __webpack_require__) { + +var assocIndexOf = __webpack_require__("./node_modules/lodash/_assocIndexOf.js"); + +/** + * Sets the list cache `key` to `value`. + * + * @private + * @name set + * @memberOf ListCache + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the list cache instance. + */ +function listCacheSet(key, value) { + var data = this.__data__, + index = assocIndexOf(data, key); + + if (index < 0) { + ++this.size; + data.push([key, value]); + } else { + data[index][1] = value; + } + return this; +} + +module.exports = listCacheSet; + + +/***/ }), + +/***/ "./node_modules/lodash/_mapCacheClear.js": +/***/ (function(module, exports, __webpack_require__) { + +var Hash = __webpack_require__("./node_modules/lodash/_Hash.js"), + ListCache = __webpack_require__("./node_modules/lodash/_ListCache.js"), + Map = __webpack_require__("./node_modules/lodash/_Map.js"); + +/** + * Removes all key-value entries from the map. + * + * @private + * @name clear + * @memberOf MapCache + */ +function mapCacheClear() { + this.size = 0; + this.__data__ = { + 'hash': new Hash, + 'map': new (Map || ListCache), + 'string': new Hash + }; +} + +module.exports = mapCacheClear; + + +/***/ }), + +/***/ "./node_modules/lodash/_mapCacheDelete.js": +/***/ (function(module, exports, __webpack_require__) { + +var getMapData = __webpack_require__("./node_modules/lodash/_getMapData.js"); + +/** + * Removes `key` and its value from the map. + * + * @private + * @name delete + * @memberOf MapCache + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ +function mapCacheDelete(key) { + var result = getMapData(this, key)['delete'](key); + this.size -= result ? 1 : 0; + return result; +} + +module.exports = mapCacheDelete; + + +/***/ }), + +/***/ "./node_modules/lodash/_mapCacheGet.js": +/***/ (function(module, exports, __webpack_require__) { + +var getMapData = __webpack_require__("./node_modules/lodash/_getMapData.js"); + +/** + * Gets the map value for `key`. + * + * @private + * @name get + * @memberOf MapCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ +function mapCacheGet(key) { + return getMapData(this, key).get(key); +} + +module.exports = mapCacheGet; + + +/***/ }), + +/***/ "./node_modules/lodash/_mapCacheHas.js": +/***/ (function(module, exports, __webpack_require__) { + +var getMapData = __webpack_require__("./node_modules/lodash/_getMapData.js"); + +/** + * Checks if a map value for `key` exists. + * + * @private + * @name has + * @memberOf MapCache + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ +function mapCacheHas(key) { + return getMapData(this, key).has(key); +} + +module.exports = mapCacheHas; + + +/***/ }), + +/***/ "./node_modules/lodash/_mapCacheSet.js": +/***/ (function(module, exports, __webpack_require__) { + +var getMapData = __webpack_require__("./node_modules/lodash/_getMapData.js"); + +/** + * Sets the map `key` to `value`. + * + * @private + * @name set + * @memberOf MapCache + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the map cache instance. + */ +function mapCacheSet(key, value) { + var data = getMapData(this, key), + size = data.size; + + data.set(key, value); + this.size += data.size == size ? 0 : 1; + return this; +} + +module.exports = mapCacheSet; + + +/***/ }), + +/***/ "./node_modules/lodash/_memoizeCapped.js": +/***/ (function(module, exports, __webpack_require__) { + +var memoize = __webpack_require__("./node_modules/lodash/memoize.js"); + +/** Used as the maximum memoize cache size. */ +var MAX_MEMOIZE_SIZE = 500; + +/** + * A specialized version of `_.memoize` which clears the memoized function's + * cache when it exceeds `MAX_MEMOIZE_SIZE`. + * + * @private + * @param {Function} func The function to have its output memoized. + * @returns {Function} Returns the new memoized function. + */ +function memoizeCapped(func) { + var result = memoize(func, function(key) { + if (cache.size === MAX_MEMOIZE_SIZE) { + cache.clear(); + } + return key; + }); + + var cache = result.cache; + return result; +} + +module.exports = memoizeCapped; + + +/***/ }), + +/***/ "./node_modules/lodash/_nativeCreate.js": +/***/ (function(module, exports, __webpack_require__) { + +var getNative = __webpack_require__("./node_modules/lodash/_getNative.js"); + +/* Built-in method references that are verified to be native. */ +var nativeCreate = getNative(Object, 'create'); + +module.exports = nativeCreate; + + +/***/ }), + +/***/ "./node_modules/lodash/_objectToString.js": +/***/ (function(module, exports) { + +/** Used for built-in method references. */ +var objectProto = Object.prototype; + +/** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ +var nativeObjectToString = objectProto.toString; + +/** + * Converts `value` to a string using `Object.prototype.toString`. + * + * @private + * @param {*} value The value to convert. + * @returns {string} Returns the converted string. + */ +function objectToString(value) { + return nativeObjectToString.call(value); +} + +module.exports = objectToString; + + +/***/ }), + +/***/ "./node_modules/lodash/_root.js": +/***/ (function(module, exports, __webpack_require__) { + +var freeGlobal = __webpack_require__("./node_modules/lodash/_freeGlobal.js"); + +/** Detect free variable `self`. */ +var freeSelf = typeof self == 'object' && self && self.Object === Object && self; + +/** Used as a reference to the global object. */ +var root = freeGlobal || freeSelf || Function('return this')(); + +module.exports = root; + + +/***/ }), + +/***/ "./node_modules/lodash/_stringToPath.js": +/***/ (function(module, exports, __webpack_require__) { + +var memoizeCapped = __webpack_require__("./node_modules/lodash/_memoizeCapped.js"); + +/** Used to match property names within property paths. */ +var rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g; + +/** Used to match backslashes in property paths. */ +var reEscapeChar = /\\(\\)?/g; + +/** + * Converts `string` to a property path array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the property path array. + */ +var stringToPath = memoizeCapped(function(string) { + var result = []; + if (string.charCodeAt(0) === 46 /* . */) { + result.push(''); + } + string.replace(rePropName, function(match, number, quote, subString) { + result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match)); + }); + return result; +}); + +module.exports = stringToPath; + + +/***/ }), + +/***/ "./node_modules/lodash/_toKey.js": +/***/ (function(module, exports, __webpack_require__) { + +var isSymbol = __webpack_require__("./node_modules/lodash/isSymbol.js"); + +/** Used as references for various `Number` constants. */ +var INFINITY = 1 / 0; + +/** + * Converts `value` to a string key if it's not a string or symbol. + * + * @private + * @param {*} value The value to inspect. + * @returns {string|symbol} Returns the key. + */ +function toKey(value) { + if (typeof value == 'string' || isSymbol(value)) { + return value; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; +} + +module.exports = toKey; + + +/***/ }), + +/***/ "./node_modules/lodash/_toSource.js": +/***/ (function(module, exports) { + +/** Used for built-in method references. */ +var funcProto = Function.prototype; + +/** Used to resolve the decompiled source of functions. */ +var funcToString = funcProto.toString; + +/** + * Converts `func` to its source code. + * + * @private + * @param {Function} func The function to convert. + * @returns {string} Returns the source code. + */ +function toSource(func) { + if (func != null) { + try { + return funcToString.call(func); + } catch (e) {} + try { + return (func + ''); + } catch (e) {} + } + return ''; +} + +module.exports = toSource; + + +/***/ }), + +/***/ "./node_modules/lodash/eq.js": +/***/ (function(module, exports) { + +/** + * Performs a + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * comparison between two values to determine if they are equivalent. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * var object = { 'a': 1 }; + * var other = { 'a': 1 }; + * + * _.eq(object, object); + * // => true + * + * _.eq(object, other); + * // => false + * + * _.eq('a', 'a'); + * // => true + * + * _.eq('a', Object('a')); + * // => false + * + * _.eq(NaN, NaN); + * // => true + */ +function eq(value, other) { + return value === other || (value !== value && other !== other); +} + +module.exports = eq; + + +/***/ }), + +/***/ "./node_modules/lodash/isArray.js": +/***/ (function(module, exports) { + +/** + * Checks if `value` is classified as an `Array` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array, else `false`. + * @example + * + * _.isArray([1, 2, 3]); + * // => true + * + * _.isArray(document.body.children); + * // => false + * + * _.isArray('abc'); + * // => false + * + * _.isArray(_.noop); + * // => false + */ +var isArray = Array.isArray; + +module.exports = isArray; + + +/***/ }), + +/***/ "./node_modules/lodash/isFunction.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGetTag = __webpack_require__("./node_modules/lodash/_baseGetTag.js"), + isObject = __webpack_require__("./node_modules/lodash/isObject.js"); + +/** `Object#toString` result references. */ +var asyncTag = '[object AsyncFunction]', + funcTag = '[object Function]', + genTag = '[object GeneratorFunction]', + proxyTag = '[object Proxy]'; + +/** + * Checks if `value` is classified as a `Function` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a function, else `false`. + * @example + * + * _.isFunction(_); + * // => true + * + * _.isFunction(/abc/); + * // => false + */ +function isFunction(value) { + if (!isObject(value)) { + return false; + } + // The use of `Object#toString` avoids issues with the `typeof` operator + // in Safari 9 which returns 'object' for typed arrays and other constructors. + var tag = baseGetTag(value); + return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag; +} + +module.exports = isFunction; + + +/***/ }), + +/***/ "./node_modules/lodash/isObject.js": +/***/ (function(module, exports) { + +/** + * Checks if `value` is the + * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types) + * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) + * + * @static + * @memberOf _ + * @since 0.1.0 + * @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) { + var type = typeof value; + return value != null && (type == 'object' || type == 'function'); +} + +module.exports = isObject; + + +/***/ }), + +/***/ "./node_modules/lodash/isObjectLike.js": +/***/ (function(module, exports) { + +/** + * 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 _ + * @since 4.0.0 + * @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 != null && typeof value == 'object'; +} + +module.exports = isObjectLike; + + +/***/ }), + +/***/ "./node_modules/lodash/isSymbol.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseGetTag = __webpack_require__("./node_modules/lodash/_baseGetTag.js"), + isObjectLike = __webpack_require__("./node_modules/lodash/isObjectLike.js"); + +/** `Object#toString` result references. */ +var symbolTag = '[object Symbol]'; + +/** + * Checks if `value` is classified as a `Symbol` primitive or object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a symbol, else `false`. + * @example + * + * _.isSymbol(Symbol.iterator); + * // => true + * + * _.isSymbol('abc'); + * // => false + */ +function isSymbol(value) { + return typeof value == 'symbol' || + (isObjectLike(value) && baseGetTag(value) == symbolTag); +} + +module.exports = isSymbol; + + +/***/ }), + +/***/ "./node_modules/lodash/memoize.js": +/***/ (function(module, exports, __webpack_require__) { + +var MapCache = __webpack_require__("./node_modules/lodash/_MapCache.js"); + +/** Error message constants. */ +var FUNC_ERROR_TEXT = 'Expected a function'; + +/** + * Creates a function that memoizes the result of `func`. If `resolver` is + * provided, it determines the cache key for storing the result based on the + * arguments provided to the memoized function. By default, the first argument + * provided to the memoized function is used as the map cache key. The `func` + * is invoked with the `this` binding of the memoized function. + * + * **Note:** The cache is exposed as the `cache` property on the memoized + * function. Its creation may be customized by replacing the `_.memoize.Cache` + * constructor with one whose instances implement the + * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object) + * method interface of `clear`, `delete`, `get`, `has`, and `set`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to have its output memoized. + * @param {Function} [resolver] The function to resolve the cache key. + * @returns {Function} Returns the new memoized function. + * @example + * + * var object = { 'a': 1, 'b': 2 }; + * var other = { 'c': 3, 'd': 4 }; + * + * var values = _.memoize(_.values); + * values(object); + * // => [1, 2] + * + * values(other); + * // => [3, 4] + * + * object.a = 2; + * values(object); + * // => [1, 2] + * + * // Modify the result cache. + * values.cache.set(object, ['a', 'b']); + * values(object); + * // => ['a', 'b'] + * + * // Replace `_.memoize.Cache`. + * _.memoize.Cache = WeakMap; + */ +function memoize(func, resolver) { + if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) { + throw new TypeError(FUNC_ERROR_TEXT); + } + var memoized = function() { + var args = arguments, + key = resolver ? resolver.apply(this, args) : args[0], + cache = memoized.cache; + + if (cache.has(key)) { + return cache.get(key); + } + var result = func.apply(this, args); + memoized.cache = cache.set(key, result) || cache; + return result; + }; + memoized.cache = new (memoize.Cache || MapCache); + return memoized; +} + +// Expose `MapCache`. +memoize.Cache = MapCache; + +module.exports = memoize; + + +/***/ }), + +/***/ "./node_modules/lodash/toPath.js": +/***/ (function(module, exports, __webpack_require__) { + +var arrayMap = __webpack_require__("./node_modules/lodash/_arrayMap.js"), + copyArray = __webpack_require__("./node_modules/lodash/_copyArray.js"), + isArray = __webpack_require__("./node_modules/lodash/isArray.js"), + isSymbol = __webpack_require__("./node_modules/lodash/isSymbol.js"), + stringToPath = __webpack_require__("./node_modules/lodash/_stringToPath.js"), + toKey = __webpack_require__("./node_modules/lodash/_toKey.js"), + toString = __webpack_require__("./node_modules/lodash/toString.js"); + +/** + * Converts `value` to a property path array. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Util + * @param {*} value The value to convert. + * @returns {Array} Returns the new property path array. + * @example + * + * _.toPath('a.b.c'); + * // => ['a', 'b', 'c'] + * + * _.toPath('a[0].b.c'); + * // => ['a', '0', 'b', 'c'] + */ +function toPath(value) { + if (isArray(value)) { + return arrayMap(value, toKey); + } + return isSymbol(value) ? [value] : copyArray(stringToPath(toString(value))); +} + +module.exports = toPath; + + +/***/ }), + +/***/ "./node_modules/lodash/toString.js": +/***/ (function(module, exports, __webpack_require__) { + +var baseToString = __webpack_require__("./node_modules/lodash/_baseToString.js"); + +/** + * Converts `value` to a string. An empty string is returned for `null` + * and `undefined` values. The sign of `-0` is preserved. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {string} Returns the converted string. + * @example + * + * _.toString(null); + * // => '' + * + * _.toString(-0); + * // => '-0' + * + * _.toString([1, 2, 3]); + * // => '1,2,3' + */ +function toString(value) { + return value == null ? '' : baseToString(value); +} + +module.exports = toString; + + +/***/ }), + +/***/ "./node_modules/redux-form/lib/structure/plain/getIn.js": +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _toPath2 = __webpack_require__("./node_modules/lodash/toPath.js"); + +var _toPath3 = _interopRequireDefault(_toPath2); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var getIn = function getIn(state, field) { + if (!state) { + return state; + } + + var path = (0, _toPath3.default)(field); + var length = path.length; + if (!length) { + return undefined; + } + + var result = state; + for (var i = 0; i < length && !!result; ++i) { + result = result[path[i]]; + } + + return result; +}; + +exports.default = getIn; + +/***/ }), + +/***/ 0: +/***/ (function(module, exports) { + +module.exports = React; + +/***/ }), + +/***/ 1: +/***/ (function(module, exports) { + +module.exports = i18n; + +/***/ }), + +/***/ 10: +/***/ (function(module, exports) { + +module.exports = InsertMediaModal; + +/***/ }), + +/***/ 11: +/***/ (function(module, exports) { + +module.exports = FormBuilderModal; + +/***/ }), + +/***/ 12: +/***/ (function(module, exports) { + +module.exports = DataFormat; + +/***/ }), + +/***/ 13: +/***/ (function(module, exports) { + +module.exports = DeepFreezeStrict; + +/***/ }), + +/***/ 14: +/***/ (function(module, exports) { + +module.exports = GraphQLTag; + +/***/ }), + +/***/ 15: +/***/ (function(module, exports) { + +module.exports = ReactDND; + +/***/ }), + +/***/ 16: +/***/ (function(module, exports) { + +module.exports = SchemaActions; + +/***/ }), + +/***/ 17: +/***/ (function(module, exports) { + +module.exports = Badge; + +/***/ }), + +/***/ 18: +/***/ (function(module, exports) { + +module.exports = FormBuilderLoader; + +/***/ }), + +/***/ 19: +/***/ (function(module, exports) { + +module.exports = Backend; + +/***/ }), + +/***/ 2: +/***/ (function(module, exports) { + +module.exports = Injector; + +/***/ }), + +/***/ 20: +/***/ (function(module, exports) { + +module.exports = Config; + +/***/ }), + +/***/ 21: +/***/ (function(module, exports) { + +module.exports = ReactDNDHtml5Backend; + +/***/ }), + +/***/ 22: +/***/ (function(module, exports) { + +module.exports = Reactstrap; + +/***/ }), + +/***/ 23: +/***/ (function(module, exports) { + +module.exports = ReduxForm; + +/***/ }), + +/***/ 24: +/***/ (function(module, exports) { + +module.exports = getFormState; + +/***/ }), + +/***/ 26: +/***/ (function(module, exports) { + +module.exports = Breadcrumb; + +/***/ }), + +/***/ 27: +/***/ (function(module, exports) { + +module.exports = BreadcrumbsActions; + +/***/ }), + +/***/ 28: +/***/ (function(module, exports) { + +module.exports = FieldHolder; + +/***/ }), + +/***/ 29: +/***/ (function(module, exports) { + +module.exports = FileSchemaModalHandler; + +/***/ }), + +/***/ 3: +/***/ (function(module, exports) { + +module.exports = ReactRedux; + +/***/ }), + +/***/ 30: +/***/ (function(module, exports) { + +module.exports = Focusedzone; + +/***/ }), + +/***/ 31: +/***/ (function(module, exports) { + +module.exports = FormAlert; + +/***/ }), + +/***/ 32: +/***/ (function(module, exports) { + +module.exports = ReactAddonsCssTransitionGroup; + +/***/ }), + +/***/ 33: +/***/ (function(module, exports) { + +module.exports = ReactAddonsTestUtils; + +/***/ }), + +/***/ 34: +/***/ (function(module, exports) { + +module.exports = ReactRouteRegister; + +/***/ }), + +/***/ 35: +/***/ (function(module, exports) { + +module.exports = ReactRouter; + +/***/ }), + +/***/ 36: +/***/ (function(module, exports) { + +module.exports = Toolbar; + +/***/ }), + +/***/ 37: +/***/ (function(module, exports) { + +module.exports = TreeDropdownField; + +/***/ }), + +/***/ 38: +/***/ (function(module, exports) { + +module.exports = UnsavedFormsActions; + +/***/ }), + +/***/ 39: +/***/ (function(module, exports) { + +module.exports = qs; + +/***/ }), + +/***/ 4: +/***/ (function(module, exports) { + +module.exports = Redux; + +/***/ }), + +/***/ 40: +/***/ (function(module, exports) { + +module.exports = reduxFieldReducer; + +/***/ }), + +/***/ 41: +/***/ (function(module, exports) { + +module.exports = schemaFieldValues; + +/***/ }), + +/***/ 5: +/***/ (function(module, exports) { + +module.exports = ReactDom; + +/***/ }), + +/***/ 6: +/***/ (function(module, exports) { + +module.exports = jQuery; + +/***/ }), + +/***/ 8: +/***/ (function(module, exports) { + +module.exports = ReactApollo; + +/***/ }), + +/***/ 9: +/***/ (function(module, exports) { + +module.exports = classnames; + +/***/ }) + +/******/ }); +//# sourceMappingURL=bundle.js.map \ No newline at end of file diff --git a/client/dist/styles/bundle.css b/client/dist/styles/bundle.css index ba639cb67..a39dadd22 100644 --- a/client/dist/styles/bundle.css +++ b/client/dist/styles/bundle.css @@ -1 +1,2 @@ -.gallery-item{opacity:1;position:relative;background-color:#fff;border:1px solid;border-color:#dbe0e9 #ced5e1 #c1cad9;width:178px;border-radius:.192rem;-webkit-transition:-webkit-box-shadow .3s;transition:-webkit-box-shadow .3s;-o-transition:box-shadow .3s;transition:box-shadow .3s;transition:box-shadow .3s,-webkit-box-shadow .3s;height:174px;-webkit-transition:opacity .25s linear;-o-transition:opacity .25s linear;transition:opacity .25s linear}.gallery-item:hover{-webkit-box-shadow:0 1px 4px rgba(0,0,0,.2);box-shadow:0 1px 4px rgba(0,0,0,.2);cursor:pointer}.gallery-item:not(.gallery-item--error):not(.gallery-item--folder):hover .gallery-item--overlay{opacity:1;display:block}.gallery-item--dropping{border-color:#29abe2;background-color:#e8f5ff}.gallery-item__draggable,.gallery-item__droppable{margin:0 1.2308rem 1.2308rem 0}.gallery-item__draggable>.gallery-item__droppable,.gallery-item__droppable>.gallery-item__draggable{margin:0}.gallery-item--folder{height:54px}.gallery-item--folder .gallery-item__thumbnail{background:url() 12px 14px no-repeat;-webkit-background-size:27px 24px;background-size:27px 24px;height:52px;width:45px;float:left}.gallery-item--folder .gallery-item__title{padding-top:17px;padding-bottom:17px;padding-left:0;width:131px;height:52px}.gallery-item--folder .gallery-item__checkbox-label{margin-top:5px}.gallery-item__thumbnail{height:132px;width:176px;margin:0 auto;background-repeat:no-repeat;background-position:50%;border-top-left-radius:.192rem;border-top-right-radius:.192rem;-webkit-background-size:cover;background-size:cover}.gallery-item__thumbnail--error{background-color:#dd3636}.gallery-item__thumbnail--no-preview{background-color:#566b8d}.gallery-item__thumbnail--loading{background:#fff url() 50% no-repeat}@media only screen and (-o-min-device-pixel-ratio:2/1),only screen and (-webkit-min-device-pixel-ratio:2),only screen and (min-device-pixel-ratio:2),only screen and (min-resolution:2dppx),only screen and (min-resolution:192dpi){.gallery-item__thumbnail--loading{background:#fff url() 50% no-repeat;-webkit-background-size:43px 43px;background-size:43px 43px}}.gallery-item__thumbnail--small{-webkit-background-size:auto auto;background-size:auto;background-color:#fff}.gallery-item__title{padding:11px 12px;height:40px;width:176px;margin:0;overflow:hidden;-webkit-box-sizing:border-box;box-sizing:border-box;text-overflow:ellipsis;white-space:nowrap;position:relative}.gallery-item--selectable .gallery-item__title{padding-right:32px}.asset-admin--single-select .gallery-item--selectable:not(.gallery-item--selected) .gallery-item__title{padding-right:12px}.gallery-item__checkbox{margin:13px 4px;-webkit-transform:scale(.1);-o-transform:scale(.1);transform:scale(.1);z-index:-1;position:absolute}.gallery-item__checkbox-label{width:30px;height:40px;position:absolute;right:0;top:0;margin-bottom:0}.asset-admin--single-select .gallery-item--selectable .gallery-item__checkbox-label{display:none}.gallery-item--selectable .gallery-item__checkbox-label:before{cursor:pointer;top:0;bottom:0;right:0;height:19px;width:19px;margin:auto 10px;position:absolute;border:1px solid #ced5e1;border-radius:.192rem;font-size:1.15em;padding:1px;color:transparent;background-color:#fff}.asset-admin--single-select .gallery-item--selected .gallery-item__checkbox-label{display:block}.asset-admin--single-select .gallery-item--selected .gallery-item__checkbox-label:before{margin:8px;border-radius:100%;font-size:1.5em}.gallery-item--selectable .gallery-item__checkbox-label:not(.gallery-item__checkbox-label--disabled):hover:before{border:1px solid #29abe2}.gallery-item--error .gallery-item__checkbox-label:before,.gallery-item__upload-progress+.gallery-item__title .gallery-item__checkbox-label:before{font-size:19px;border:0;border-radius:0;padding:0}.gallery-item--error .gallery-item__checkbox-label:hover:before,.gallery-item__upload-progress+.gallery-item__title .gallery-item__checkbox-label:hover:before{border:0}.gallery-item--error .gallery-item__checkbox-label,.gallery-item--error .gallery-item__thumbnail,.gallery-item--error .gallery-item__title,.gallery-item--error:hover{cursor:not-allowed}.gallery-item--error .gallery-item__checkbox-label:before{color:#d40404}.gallery-item__error-message{position:absolute;top:calc(50% - 20px);left:50%;-webkit-transform:translateX(-50%) translateY(-50%);-o-transform:translateX(-50%) translateY(-50%);transform:translateX(-50%) translateY(-50%);max-height:calc(100% - 40px);overflow:hidden;width:90%;color:#fff;background-color:#dd3636;text-align:center}.gallery-item--error .gallery-item__thumbnail,.gallery-item--missing .gallery-item__thumbnail{position:relative}.gallery-item--error .gallery-item__thumbnail:after,.gallery-item--missing .gallery-item__thumbnail:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#dd3636;border-radius:2px 2px 0 0}.gallery-item--error:hover .gallery-item__error-message,.gallery-item--error:hover .gallery-item__thumbnail:after,.gallery-item--missing:hover .gallery-item__error-message,.gallery-item--missing:hover .gallery-item__thumbnail:after{background:#d81d1d}.gallery-item--overlay{background:rgba(48,59,77,.5);position:absolute;top:0;right:0;left:0;opacity:0;display:none;-webkit-transition-property:opacity,background;-o-transition-property:opacity,background;transition-property:opacity,background;-webkit-transition-duration:.5s;-o-transition-duration:.5s;transition-duration:.5s;border-top-left-radius:.192rem;border-top-right-radius:.192rem;color:#fff;height:132px;width:100%;font-size:14px;padding-top:56px;text-align:center}.gallery-item--overlay:before{margin-right:5px}.gallery-item--selected{border-color:#29abe2}.gallery-item--selected .gallery-item__checkbox-label:before{border-color:#29abe2;background-color:#29abe2;color:#fff}.gallery__main--dragging .gallery-item--selected{opacity:.2}.gallery-item--highlighted,.gallery-item__drag-shadow{border-color:#29abe2;background-color:#e8f5ff}.gallery-item--focussed .gallery-item--overlay{opacity:1;display:block}.gallery-item--archive .gallery-item__thumbnail{background:#fff url() 50% no-repeat}.gallery-item--audio .gallery-item__thumbnail{background:#fff url() 50% no-repeat}.gallery-item--video .gallery-item__thumbnail{background:#fff url() 50% no-repeat}.gallery-item--document .gallery-item__thumbnail{background:#fff url() 50% no-repeat}.gallery-item--false .gallery-item__thumbnail{background:#fff url() 50% no-repeat}.gallery-item__upload-progress{height:18px;width:75%;position:absolute;top:calc(50% - 20px);left:50%;-webkit-transform:translateX(-50%) translateY(-50%);-o-transform:translateX(-50%) translateY(-50%);transform:translateX(-50%) translateY(-50%);border-radius:10px;overflow:hidden;background-color:#aebace}.gallery-item__upload-progress+.gallery-item__title .gallery-item__checkbox-label:before{color:#43536d}.gallery-item__progress-bar{height:100%;background:#29abe2;width:0}.gallery-item--draft,.gallery-item--modified{position:absolute;top:.76925rem;left:.76925rem;display:block;width:8px;height:8px;border:1px solid #cf3f00;-webkit-box-shadow:0 0 1px .5px #fff;box-shadow:0 0 1px .5px #fff;border-radius:100%;z-index:1}.gallery-item--draft:hover:after,.gallery-item--modified:hover:after{top:-4px;font-size:.75rem;font-weight:200;position:absolute;color:#fff;margin-left:.9231rem}.gallery-item--draft{background-color:#cf3f00}.gallery-item--draft:hover:after{content:"DRAFT"}.gallery-item--modified{background-color:#fff7f0}.gallery-item--modified:hover:after{content:"MODIFIED"}.gallery-item--max-selected{opacity:.2}.gallery-item--max-selected .gallery-item__checkbox-label,.gallery-item--max-selected .gallery-item__checkbox-label:before{cursor:not-allowed}.gallery-item--dragging{opacity:.2}.gallery-item--dragging.gallery-item{cursor:-webkit-grabbing;cursor:grabbing}.gallery-item__drag-layer-item .gallery-item--dragging{opacity:1}.gallery-item__drag-layer{position:fixed;left:0;top:0;right:0;bottom:0;pointer-events:none;z-index:100}.gallery-item__drag-layer-preview{-webkit-transform:scale(.4) translate(-100%,-160%);-o-transform:scale(.4) translate(-100%,-160%);transform:scale(.4) translate(-100%,-160%);border:1px solid #29abe2}.gallery-item__drag-layer-item{display:inline-block;position:relative;opacity:1}.gallery-item__drag-layer-item .gallery-item{border-width:2px;z-index:104;height:134px}.gallery-item__drag-layer-item .gallery-item__title{display:none}.gallery-item__drag-layer-count{top:-45%;left:25%;z-index:105}.gallery-item__badge,.gallery-item__drag-layer-count{display:inline-block;position:absolute;font-size:1rem}.gallery-item__badge{top:-.5rem;right:-.5rem;z-index:99}.gallery-item__drag-shadow{display:inline-block;position:absolute;left:0;top:0;right:0;bottom:0;-webkit-transform:translate(.75rem,-.75rem);-o-transform:translate(.75rem,-.75rem);transform:translate(.75rem,-.75rem);z-index:103;border:2px solid #29abe2;background:#fff}.gallery-item__drag-shadow.gallery-item__drag-shadow--second{-webkit-transform:translate(1.5rem,-1.5rem);-o-transform:translate(1.5rem,-1.5rem);transform:translate(1.5rem,-1.5rem);z-index:102}.bulk-actions{display:-webkit-box;display:-webkit-flex;display:flex;-webkit-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:start;-webkit-align-items:flex-start;align-items:flex-start;-webkit-box-pack:start;-webkit-justify-content:flex-start;justify-content:flex-start;width:100%;padding:.76925rem 1.5385rem;margin:0 auto;position:absolute;height:53px;z-index:2;bottom:0;background-color:#f1f3f6;-webkit-transition:top .5s ease-in-out,-webkit-transform .5s ease-in-out;transition:top .5s ease-in-out,-webkit-transform .5s ease-in-out;-o-transition:top .5s ease-in-out,-o-transform .5s ease-in-out;transition:top .5s ease-in-out,transform .5s ease-in-out;transition:top .5s ease-in-out,transform .5s ease-in-out,-webkit-transform .5s ease-in-out,-o-transform .5s ease-in-out;-webkit-transform:scale(1);-o-transform:scale(1);transform:scale(1);min-width:160px;border-top:1px solid #dbe0e9}.bulk-actions>*{-webkit-box-flex:0;-webkit-flex:0;flex:0}.bulk-actions-enter{bottom:-53px}.bulk-actions-enter-active{bottom:0;-webkit-transition:bottom .2s ease-out;-o-transition:bottom .2s ease-out;transition:bottom .2s ease-out}.bulk-actions-leave{bottom:0}.bulk-actions-leave-active{bottom:-53px;-webkit-transition:bottom .2s ease-in-out .1s;-o-transition:bottom .2s ease-in-out .1s;transition:bottom .2s ease-in-out .1s}.bulk-actions .bulk-actions-counter{vertical-align:middle;min-width:28px;padding:6px;margin-right:8px;line-height:1.5384;color:#fff;text-align:center;background-color:#0071c4;border-radius:.23rem;font-weight:700}.bulk-actions .bulk-actions__action.ss-ui-button{line-height:1.5384;margin-bottom:0;height:32px}.bulk-actions .bulk-actions__action.ss-ui-button[class*=font-icon-]:before{font-size:20px;line-height:18px;position:relative;top:-1px;vertical-align:middle}.bulk-actions .chosen-single{border-radius:5px 0 0 5px;border:0;-webkit-filter:none;filter:none;background:none;-webkit-box-shadow:none;box-shadow:none;color:inherit}.bulk-actions .chosen-single:focus{-webkit-box-shadow:0 0 3px rgba(0,0,0,.2);box-shadow:0 0 3px rgba(0,0,0,.2)}.bulk-actions .chosen-single>span{text-align:left;display:inline-block;margin-right:0}.bulk-actions .chosen-single>div{position:static;display:inline-block}.bulk-actions .chosen-drop{border-radius:3px;-webkit-box-shadow:0 0 3px rgba(0,0,0,.2);box-shadow:0 0 3px rgba(0,0,0,.2);border:0}.bulk-actions .search-choice-close{display:none}.bulk-actions .chosen-results li{padding-left:22px;position:relative}.bulk-actions .chosen-results li:before{position:absolute;font-family:silverstripe;left:4px;font-size:14px;vertical-align:middle;margin-right:4px}.bulk-actions .chosen-results li:first-child::before{content:"g"}.asset-dropzone:after{position:absolute;top:0;right:-1.5385rem;bottom:0;left:-1.5385rem;background:rgba(247,248,250,.9) url() 50% no-repeat;-webkit-background-size:312px 325px;background-size:312px 325px;z-index:100}.asset-dropzone.dragging:after{content:""}.asset-dropzone--button{position:static}.uploadfield__dropzone{position:relative;left:0;top:0;right:auto;bottom:auto;margin:0 0 10px;border:2px dashed #c1cad9;border-radius:5px;padding:0;background:#fdfefe;height:78px}.uploadfield__dropzone:after{left:0;top:0;right:0;bottom:0;-webkit-box-shadow:inset 0 0 10px 0 rgba(0,0,0,.2);box-shadow:inset 0 0 10px 0 rgba(0,0,0,.2);background-image:none;background:rgba(0,0,0,.03)}.uploadfield__dropzone--hidden{display:none}.uploadfield__backdrop{position:absolute;left:0;top:0;right:0;bottom:0;cursor:pointer}.uploadfield__join:after,.uploadfield__join:before{content:" ";display:inline}.uploadfield__add-button,.uploadfield__upload-button{border:0;margin:0;padding:0;background:none;text-decoration:none;color:#0071c4}.uploadfield__add-button:hover,.uploadfield__upload-button:hover{color:#0062ab;text-decoration:underline}.uploadfield__droptext{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);-o-transform:translate(-50%,-50%);transform:translate(-50%,-50%);display:inline-block;text-align:center}.uploadfield__droptext a,.uploadfield__droptext button{cursor:pointer}.uploadfield__droptext:before{font-family:silverstripe,sans-serif;content:"v";font-size:1.7em;padding-right:20px;vertical-align:middle}.uploadfield-item{position:relative;margin:0;background-color:#fff;border:1px solid;border-color:#ced5e1;border-bottom-width:0;width:auto;-webkit-transition:-webkit-box-shadow .3s;transition:-webkit-box-shadow .3s;-o-transition:box-shadow .3s;transition:box-shadow .3s;transition:box-shadow .3s,-webkit-box-shadow .3s;height:61px}.uploadfield-item:first-child{border-top-left-radius:.192rem;border-top-right-radius:.192rem}.uploadfield-item:last-child{border-bottom-width:1px;height:62px;border-bottom-left-radius:.192rem;border-bottom-right-radius:.192rem}.uploadfield-item:not(.uploadfield-item--error):not(.uploadfield-item--folder):hover .uploadfield-item--overlay{opacity:1;display:block}.uploadfield__dropzone+.uploadfield-item{border-top-left-radius:.192rem;border-top-right-radius:.192rem}.uploadfield-item--folder .uploadfield-item__thumbnail{background:url() 12px 14px no-repeat;-webkit-background-size:27px 24px;background-size:27px 24px}.uploadfield-item__thumbnail{height:60px;width:60px;margin:0;background-repeat:no-repeat;background-position:50%;-webkit-background-size:cover;background-size:cover;border-radius:.192rem .192rem 0 0}.uploadfield-item__thumbnail--small{-webkit-background-size:auto auto;background-size:auto;background-color:#fff}.uploadfield-item__details{padding:11px 0 11px 12px;height:100%;margin:0;-webkit-box-sizing:border-box;box-sizing:border-box;position:relative;width:50px;-webkit-box-pack:center;-webkit-justify-content:center;justify-content:center}.uploadfield-item__title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uploadfield-item__meta{font-size:.846rem;text-transform:uppercase}.uploadfield-item__specs{color:#566b8d}.uploadfield-item__remove-btn{margin:0}.uploadfield-item--archive .uploadfield-item__thumbnail{background:#fff url() 50% no-repeat}.uploadfield-item--audio .uploadfield-item__thumbnail{background:#fff url() 50% no-repeat}.uploadfield-item--video .uploadfield-item__thumbnail{background:#fff url() 50% no-repeat}.uploadfield-item--document .uploadfield-item__thumbnail{background:#fff url() 50% no-repeat}.uploadfield-item--false .uploadfield-item__thumbnail{background:#fff url() 50% no-repeat}.uploadfield-item__upload-progress{height:16px;margin:22px 5px;width:30%;border-radius:10px;overflow:hidden}.uploadfield-item__upload-progress+.uploadfield-item__title .uploadfield-item__checkbox-label:before{color:#43536d}.uploadfield-item__progress-bar{height:100%;background:#29abe2;width:0}.uploadfield-item__error-message{line-height:28px;height:28px;margin:16px 5px;padding:0 10px;color:#fff;background:#d40404;border-radius:14px;max-width:25%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uploadfield-item__complete-icon{line-height:38px;padding:11px 5px}.uploadfield-item__complete-icon:after{color:#3fa142;font-size:30px;display:inline;font-family:silverstripe,sans-serif;content:"I"}.uploadfield-item__status{margin:0 .6154rem;color:#cf3f00;background-color:#fff7f0;text-transform:uppercase}.preview-image-field__container{position:relative}.preview-image-field__toolbar{position:absolute;top:50%;right:0;-webkit-transform:translateY(-50%);-o-transform:translateY(-50%);transform:translateY(-50%);height:auto;max-height:100%;border-bottom-left-radius:.23rem;border-top-left-radius:.23rem;overflow:hidden}.preview-image-field__toolbar-button--link:before{content:"="}.preview-image-field__toolbar-button--replace:before{content:"b"}.preview-image-field__toolbar-button--remove:before{content:"D"}.preview-image-field__toolbar-button{padding:11px 0;height:47px;width:47px;overflow:hidden;background:#000;opacity:.55;color:#fff;border:0}.preview-image-field__toolbar-button:active,.preview-image-field__toolbar-button:focus,.preview-image-field__toolbar-button:hover{color:#b3b3b3;text-decoration:none}.preview-image-field__toolbar-button:before{padding:0 11px;font-family:silverstripe;font-style:normal;speak:none;line-height:1;font-size:25px;height:25px;width:25px;vertical-align:middle}.preview-image-field__progress{height:18px;width:75%;position:absolute;top:50%;left:50%;-webkit-transform:translateX(-50%) translateY(-50%);-o-transform:translateX(-50%) translateY(-50%);transform:translateX(-50%) translateY(-50%);border-radius:10px;overflow:hidden;background:#e6e6e6}.preview-image-field__progress-bar{height:100%;background:#29abe2;width:0}.preview-image-field__message{position:absolute;bottom:0;left:0;right:0;opacity:.8;padding:1.5385rem}.preview-image-field__message--error{color:#fff;background:#d40404}.preview-image-field__message--success{color:#fff;background:#3fa142}@media (min-width:768px){.search{position:relative;right:auto}.search.search--active{right:0}}.search.search--active{position:relative;width:100%}.search__group{opacity:0;overflow:hidden;display:none}.search--active .search__group{-webkit-transition:opacity .3s;-o-transition:opacity .3s;transition:opacity .3s;overflow:visible;opacity:1;display:block;width:100%}.search__trigger{z-index:1}.search--active .search__trigger{display:none}.search .search__trigger{margin-right:0}.search__submit{right:37px}.search__cancel,.search__submit{top:9px;position:absolute;margin-right:0}.search__cancel{right:4px;padding-right:5px;padding-left:5px;background-color:transparent}.search__cancel:hover{background-color:#e7ebf0}.search__filter-trigger-text{display:none;opacity:0;position:absolute;-webkit-transform:translateX(-106%);-o-transform:translateX(-106%);transform:translateX(-106%);font-size:.846rem;top:7px;color:#0071c4;-webkit-transition:opacity .3s;-o-transition:opacity .3s;transition:opacity .3s}.search__filter-trigger{display:block;border:0;margin:0;border-radius:0;position:absolute;top:10px;right:79px;outline:0;overflow:visible}.search__filter-trigger:hover:not(:disabled):not(.disabled){background-color:transparent}.search__filter-trigger:hover:not(:disabled):not(.disabled):before{color:#0071c4}.search__filter-trigger:hover:not(:disabled):not(.disabled) .search__filter-trigger-text{display:block;opacity:1}.search__filter-trigger:active,.search__filter-trigger:focus,.search__filter-trigger:hover{border:0;background-color:transparent;-webkit-box-shadow:none;box-shadow:none}.search__filter-trigger:before{margin:0;-webkit-transform:rotate(180deg) translateY(2px);-o-transform:rotate(180deg) translateY(2px);transform:rotate(180deg) translateY(2px)}.search__filter-trigger.collapsed:before{-webkit-transform:rotate(0deg) translateY(0);-o-transform:rotate(0deg) translateY(0);transform:rotate(0deg) translateY(0)}.search__filter-panel{position:absolute;padding:1.5385rem;background:#fff;margin-right:1px;right:0;top:53px;z-index:9999;-webkit-box-shadow:0 2px 6px 0 rgba(0,0,0,.3);box-shadow:0 2px 6px 0 rgba(0,0,0,.3);border-radius:0 0 .23rem .23rem;width:calc(100% - 2px)}@media (min-width:768px){.search__filter-panel{width:358px}}@media (min-width:992px){.search__filter-panel{width:498px}}.search__content-field{padding-right:113px;padding-left:18px;padding-top:4px;-webkit-box-shadow:0 1px 1px 0 #cbd3df,0 1px 5px 1px #dbe0e9;box-shadow:0 1px 1px 0 #cbd3df,0 1px 5px 1px #dbe0e9;border-top:0;border-bottom:0;border-radius:0;font-size:15px;height:52px;width:0;opacity:0;float:right}.search__content-field:focus{-webkit-box-shadow:0 1px 1px #66afe9,0 0 8px rgba(102,175,233,.6);box-shadow:0 1px 1px #66afe9,0 0 8px rgba(102,175,233,.6)}.search--active .search__content-field{opacity:1;width:100%}@media (min-width:768px){.search--active .search__content-field{width:360px;-webkit-transition:width .3s,opacity .3s;-o-transition:width .3s,opacity .3s;transition:width .3s,opacity .3s}}@media (min-width:992px){.search--active .search__content-field{width:500px}}.search__content-field::-ms-clear{display:none}.insert-embed-modal .modal-content{height:auto;max-height:100%}.insert-embed-modal .modal-body{display:-webkit-box;display:-webkit-flex;display:flex;-ms-grid-column-align:stretch;justify-items:stretch;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;flex-direction:column}.insert-embed-modal--edit{width:100%}@media (min-width:768px){.insert-embed-modal--edit .btn-toolbar{margin-left:30%}}.insert-embed-modal--create{-webkit-box-flex:1;-webkit-flex:1;flex:1;width:100%}.alert+.insert-embed-modal--create{padding-top:0}.insert-embed-modal__url-create .form-control.text{padding:.75rem 1.25rem;font-size:1.231rem;line-height:1.33333;border-radius:.5rem}@media (min-width:768px){.insert-embed-modal__fields--fill-width{width:100%;display:-webkit-box;display:-webkit-flex;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;flex-direction:row}}.insert-embed-modal__preview-container{padding-bottom:1.2308rem}@media (min-width:768px){.insert-embed-modal__preview-container{padding-right:1.2308rem;width:30%}}.insert-embed-modal__preview{display:block;max-width:100%;margin:0 auto;max-height:198px}.insert-embed-modal__placement .form__field-holder>div{display:-webkit-box;display:-webkit-flex;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;flex-direction:row;-ms-grid-column-align:stretch;justify-items:stretch}.insert-embed-modal__placement .form-check{-webkit-box-flex:1;-webkit-flex:1;flex:1;margin-bottom:0;padding-left:0}.insert-embed-modal__placement .form-check:first-of-type .form-check-label span:before{border-top-left-radius:.23rem;border-bottom-left-radius:.23rem}.insert-embed-modal__placement .form-check:last-of-type .form-check-label span:before{border-top-right-radius:.23rem;border-bottom-right-radius:.23rem}.insert-embed-modal__placement .form-check-label{display:block;cursor:pointer}.insert-embed-modal__placement .form-check-label span{display:block;color:rgba(67,83,109,0);font-size:.9rem;letter-spacing:1px;text-align:center;text-transform:uppercase;-webkit-transition:color .1s ease-out;-o-transition:color .1s ease-out;transition:color .1s ease-out}.insert-embed-modal__placement .form-check-label span:before{content:" ";display:block;-webkit-box-sizing:content-box;box-sizing:content-box;height:36px;padding:5px 0;border:1px solid #dbe0e9;background:url() top no-repeat content-box;-webkit-transition:background-color .1s ease-out;-o-transition:background-color .1s ease-out;transition:background-color .1s ease-out}.insert-embed-modal__placement .form-check-label:focus span,.insert-embed-modal__placement .form-check-label:hover span{color:#43536d}.insert-embed-modal__placement .form-check-input{position:absolute;left:-9999px}.insert-embed-modal__placement .form-check-input.checked+span{color:#29abe2}.insert-embed-modal__placement .form-check-input.checked+span:before{border:1px solid #29abe2;background:url() top no-repeat content-box,#e8f5ff padding-box}.insert-embed-modal__placement .form-check .option-val--leftAlone+span:before{background-position-y:-36px}.insert-embed-modal__placement .form-check .option-val--leftAlone.checked+span:before{background-position-y:0}.insert-embed-modal__placement .form-check .option-val--center+span:before{background-position-y:-108px}.insert-embed-modal__placement .form-check .option-val--center.checked+span:before{background-position-y:-72px}.insert-embed-modal__placement .form-check .option-val--rightAlone+span:before{background-position-y:-180px}.insert-embed-modal__placement .form-check .option-val--rightAlone.checked+span:before{background-position-y:-144px}.insert-embed-modal__placement .form-check .option-val--left+span:before{background-position-y:-252px}.insert-embed-modal__placement .form-check .option-val--left.checked+span:before{background-position-y:-216px}.insert-embed-modal__placement .form-check .option-val--right+span:before{background-position-y:-324px}.insert-embed-modal__placement .form-check .option-val--right.checked+span:before{background-position-y:-288px}.gallery,.gallery__main,.gallery__outer{position:relative}.gallery__main{height:100%}@media (max-width:991.98px){.gallery__main.gallery__main--has-opened-item{display:none}}.gallery__no-item-notice{text-align:center;font-size:1.231rem;margin-top:1.2308rem}.gallery__back{position:relative}.gallery__back.ss-ui-button:before{font-size:23px}.gallery__back .gallery__back-badge{display:inline-block;position:absolute;font-size:1rem;top:-.5rem;right:-1rem}.gallery__back--droppable-hover{background-color:#e7ebf0;border-color:transparent;-webkit-transform:scale(1.3);-o-transform:scale(1.3);transform:scale(1.3);border:1px solid #29abe2}.gallery__main--selectable{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin:-1.5385rem;padding:1.5385rem}.gallery__back-container{display:inline-block}.gallery__back-container .gallery-item__droppable{margin:0}.gallery__files,.gallery__folders{display:-webkit-box;display:-webkit-flex;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row wrap;flex-flow:row wrap}@media (max-width:991.98px){.gallery__files{margin-bottom:53px}}.gallery__load{width:100%;display:inline-block}.gallery__load-more{display:block;color:#fff;cursor:pointer;margin:8px auto 24px;padding:4px;width:200px;font-size:16px;height:44px;background-color:#29abe2;border:0;border-radius:4px}.gallery__sort{display:inline-block;vertical-align:middle;padding:.3846rem .7692rem}@media (max-width:767.98px){.gallery__sort .chosen-container{width:auto!important}}.gallery__sort .chosen-container-active .chosen-single{outline:1px dotted #29abe2;outline:5px auto -webkit-focus-ring-color}.gallery .gallery__sort .chosen-single{border:0;-webkit-filter:none;filter:none;background:none;-webkit-box-shadow:none;box-shadow:none;color:inherit;margin-top:-1px}.gallery__sort .chosen-single:focus{-webkit-box-shadow:0 0 3px rgba(0,0,0,.2);box-shadow:0 0 3px rgba(0,0,0,.2)}.gallery__sort .chosen-single>span{text-align:right;color:inherit}@media (max-width:767.98px){.gallery__sort .chosen-single>span{font-size:0}.gallery__sort .chosen-single>span:after{content:"\E003";font-size:1.231rem;font-family:silverstripe;color:#566b8d}}.gallery__sort .chosen-single>span:before{content:"Sort by "}.gallery__sort .chosen-drop{min-width:160px;right:0;border-radius:3px;-webkit-box-shadow:0 0 3px rgba(0,0,0,.2);box-shadow:0 0 3px rgba(0,0,0,.2);border:0}.gallery__sort .active-result{text-transform:capitalize}.gallery__error{display:table;width:100%;height:100%}.gallery__error-message{display:table-cell;vertical-align:middle;text-align:center}.gallery__view-change-button .icon:before{vertical-align:middle}@media (min-width:544px){.gallery__state-buttons{margin-right:-.7693rem}}.gallery__state-buttons .btn-group:last-child{margin-right:0}.gallery__view-change-button{margin-right:-.76925rem}.griddle-footer>div{display:-webkit-box;display:-webkit-flex;display:flex}.griddle-page{-webkit-box-flex:1;-webkit-flex:1;flex:1;text-align:center;margin-top:-3px}.griddle-page select{height:2.7692rem;padding:.3846rem .7692rem;line-height:1.5384;color:#566b8d;border:1px solid #cbd3df;background-color:#fff;background-image:none;text-align:center;display:inline}.griddle-page select:focus{color:#566b8d;background-color:#fff;border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),rgba(102,175,233,.6);box-shadow:inset 0 1px 1px rgba(0,0,0,.075),rgba(102,175,233,.6)}.griddle-footer{width:200px;margin:0 auto}.griddle-next,.griddle-previous{width:36px}.griddle-next button,.griddle-previous button{white-space:nowrap;border:0;background:transparent;width:36px;height:30px;position:relative;border-radius:.23rem;overflow:hidden}.griddle-next button:hover,.griddle-previous button:hover{background-color:#ced5e1;border-color:transparent}.griddle-next button:hover:before,.griddle-previous button:hover:before{background-color:#ced5e1}.griddle-next button:before,.griddle-previous button:before{font-family:silverstripe;color:#566b8d;width:36px;height:30px;background-color:#f7f8fa;position:absolute;top:0;left:0;padding:.3846rem;-webkit-transition:all .2s ease-in-out;-o-transition:all .2s ease-in-out;transition:all .2s ease-in-out;font-size:1.231rem;-webkit-font-smoothing:antialiased;line-height:1.5384}.griddle-previous button:before{content:"'"}.griddle-next button:before{content:"&"}.gallery__search-message-clear{padding-left:.6154rem}.gallery__table{margin-bottom:-1.5385rem}.gallery__table td,.gallery__table th{word-wrap:break-word}.gallery__table td{word-break:break-all}.gallery__table td.gallery__table-column-image{padding:0}.gallery__table th{cursor:pointer}.gallery__table th>span{display:inline;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery__table th>span:after{color:#8f9fba;content:")";display:inline-block;font-family:silverstripe;margin-left:4px}.gallery__table tbody td{padding-top:1.8462rem;padding-bottom:1.8462rem}@media (max-width:767.98px){.gallery__table tbody td:nth-child(n+4){display:none}}.gallery__table thead td,.gallery__table thead th{height:52px}.gallery__table thead th:hover{background-color:#f1f3f6}@media (max-width:767.98px){.gallery__table thead th:nth-child(n+4){display:none}}.gallery__table .sort-ascending,.gallery__table .sort-descending{border-bottom:1px solid #29abe2}.gallery__table .sort-ascending>span:after,.gallery__table .sort-descending>span:after{color:#29abe2}.gallery__table .sort-descending>span:after{content:"*"}.gallery__table .sort-ascending>span:after{content:"("}.gallery__table .footer-container,.gallery__table .footer-container:hover{background-color:#f7f8fa;border-bottom:0}.gallery__table-row{cursor:pointer}.gallery__table-column--select{width:1%}.gallery__table-column--select input[type=checkbox]{width:14px;height:14px}.gallery__table-row--highlighted{border-color:#29abe2;background-color:#e8f5ff}.gallery__table-column--image{width:68px;max-width:68px;height:69px;text-align:center}.gallery__table .gallery__table-row>.gallery__table-column--image{padding:0;vertical-align:middle}.gallery__table .gallery__table-row>.gallery__table-column--image:first-child{max-width:none;padding-left:1.5385rem}.gallery__table-image{background-repeat:no-repeat;background-position:50%;height:68px;width:68px;-webkit-background-size:calc(68px - 1.5385rem) auto;background-size:calc(68px - 1.5385rem) auto}.gallery__table-image--image{-webkit-background-size:68px auto;background-size:68px auto}.gallery__table-image--folder{background-image:url()}.gallery__table-image--archive{background-image:url()}.gallery__table-image--audio{background-image:url()}.gallery__table-image--video{background-image:url()}.gallery__table-image--document{background-image:url()}.gallery__table-image--error{background:#d40404;height:68px;width:68px}.gallery__table-image--error:after{content:"<";line-height:68px;font-size:30px;display:inline;font-family:silverstripe,sans-serif;color:#fff;opacity:.8}.gallery__progress-bar-progress{height:100%;background:#29abe2;width:0}.gallery__progress-bar{height:16px;width:30%;border-radius:10px;overflow:hidden}.gallery__progress-bar--complete:after{color:#3fa142;font-size:20px;display:inline;font-family:silverstripe,sans-serif;content:"I"}th.sort--disabled>span:after{content:""}.editor{background-color:#f7f8fa;z-index:2;position:absolute;height:100%;left:0}@media (min-width:992px){.editor{width:300px;border-left:1px solid #ced5e1;position:relative;padding-bottom:0}}@media (min-width:1200px){.editor{width:448px}}.editor .nav-tabs{z-index:1;position:relative}.editor .editor__details{-webkit-transform:translateZ(0);transform:translateZ(0)}.editor .editor__details .btn--close-panel{margin-right:0}.editor__heading{margin-right:2.4616rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.editor__status-flag{color:#f46b00;background-color:#fff7f2;border-color:#f46b00;clear:both;text-transform:uppercase;display:inline-block;position:relative;line-height:1rem;margin-left:3px}.editor__specs{color:#566b8d;font-size:.846rem;margin-bottom:1.2308rem}.editor__top-message{margin:-1.5385rem -1.5385rem 1.2308rem}.editor__file-preview{text-align:center;margin:0 -1.5385rem .76925rem;position:relative;max-height:336px;min-height:60px;overflow:hidden;display:block;-webkit-box-align:center;-webkit-align-items:center;align-items:center;text-decoration:none}.editor__file-preview:not(.editor__file-preview--folder):hover .editor__thumbnail{-webkit-transform:scale(1.04);-o-transform:scale(1.04);transform:scale(1.04)}.editor__file-preview--folder{margin-left:0;margin-right:0;width:100%}.editor__file-preview-link:before{position:absolute;top:50%;left:50%;margin-top:-25px;margin-left:-25px;padding:11px;height:50px;width:50px;border-radius:50%;background-color:rgba(0,0,0,.6);color:#fff;font-size:22px;opacity:0;content:"=";font-family:silverstripe;line-height:27px;z-index:1;-webkit-transition:all .5s;-o-transition:all .5s;transition:all .5s}.editor__file-preview-link:active:before,.editor__file-preview-link:hover,.editor__file-preview-link:hover:before{text-decoration:none;opacity:1}.editor__thumbnail{max-width:100%;max-height:336px;min-height:60px;margin:auto;-webkit-transform:scale(1);-o-transform:scale(1);transform:scale(1);-webkit-transition:all .5s;-o-transition:all .5s;transition:all .5s}.editor__file-preview-message--file-missing{margin:2.4616rem 0 1.2308rem;font-size:1.231rem;color:#d40404;text-align:center}@media (max-width:991.98px){.editor__heading,.editor__specs{text-align:center;margin-right:1.8462rem;margin-left:1.8462rem}.btn--close-panel{float:left;right:auto;margin-right:0;margin-left:-15px;color:#566b8d}.btn--close-panel:before{content:"5"}}.relative-time[title]{cursor:pointer;text-decoration:underline}.asset-admin .popover-field .popover{-webkit-box-shadow:0 2px 5px 0 rgba(0,0,0,.1),0 2px 10px 0 rgba(0,0,0,.1);box-shadow:0 2px 5px 0 rgba(0,0,0,.1),0 2px 10px 0 rgba(0,0,0,.1);font-size:1rem;min-width:230px}.asset-admin .popover-field .popover:focus{outline:none}.asset-admin .popover-field .popover.bottom .arrow,.asset-admin .popover-field .popover.top .arrow{margin-left:-5px}.asset-admin .popover-field .popover.top{margin-top:-10px}.asset-admin .popover-field .popover.left .arrow,.asset-admin .popover-field .popover.right .arrow{margin-top:-3px}.asset-admin .popover-field .popover.left{margin-left:-10px}.asset-admin .popover-field .popover-body{padding:.5rem .75rem}.asset-admin .popover-field .popover-body ul{padding-left:0!important;list-style-type:none;margin-left:-1.2308rem + 1px;margin-right:-1.2308rem + 1px;margin-bottom:0}.asset-admin .popover-field .popover-body a{display:block;padding:.3077rem 1.2308rem;color:#43536d}.asset-admin .popover-field .popover-body a:hover{text-decoration:none;background-color:#eef0f4;color:#43536d}.asset-admin .popover-field .popover-body .btn{padding-left:calc(1.2308rem - 1px);padding-right:calc(1.2308rem - 1px);margin-left:calc(-.75rem + 1px);margin-right:calc(-.75rem + 1px);display:block;width:calc(100% + 1.5rem - 2px);text-align:left;border-radius:0}.asset-admin .popover-field .popover-body .btn:hover{background-color:#e9f0f4}.asset-admin__toolbar-extra{width:auto}.insert-media-modal.modal-lg{width:calc(100% - 4.9232rem);max-width:1600px;margin-top:0;margin-left:auto;margin-right:auto;height:calc(100% - 53px)}@media (max-width:991.98px){.insert-media-modal.modal-lg{width:calc(100% - 1rem);height:calc(100% - .5rem);margin:0 auto}}.insert-media-modal .modal-content{height:100%;border-top-left-radius:0;border-top-right-radius:0}.insert-media-modal .modal-body{padding:0;height:100%}.insert-media-modal .editor__details{height:calc(100vh - 106px)}@media (max-width:991.98px){.insert-media-modal .editor__details{height:100%}}@media (min-width:992px){.insert-media-modal .btn--close-panel{display:none}}.insert-media-modal .tab-content{margin-bottom:1.2308rem}.insert-media-modal .fieldgroup.fill-width .field.flexbox-area-grow:first-child{margin-right:1.5385rem}.insert-media-modal .asset-admin--multi-select [name=action_insert]{display:none}@media (min-width:992px){.insert-media-modal .asset-admin--single-select [name=action_insert]{display:none}}@media (max-width:991.98px){.insert-media-modal .asset-admin--multi-select [name=action_insert]{display:block}}.insert-media-modal__main{height:calc(100vh - 106px)}.insert-media-modal__close-button{float:right;height:32px;font-size:28px;opacity:.5;margin:10px -10px 10px 0}.insert-media-modal__close-button:hover{opacity:.7}.insert-media-modal__close-button span{overflow:hidden;display:block;margin-top:-6px}.history-item{padding-top:1rem}.history-item:focus,.history-item:hover{background-color:#f1f3f6}.history-item p{margin-bottom:0}.list-group-flush:first-child .history-item:first-child{border-top:1px solid #ced5e1}.history-item__date,.history-item__version{opacity:.7;font-size:.846rem;margin-bottom:1px}.history-item__date{display:block}.history-item__version{position:absolute;right:1.5385rem;top:.9231rem;font-size:.846rem;opacity:.7}.history-item__status-flag{color:#3fa142;text-transform:uppercase;font-size:.923rem}.history-list{position:relative;min-height:50vh}.history-list>form{display:block}.history-list>.list-group{margin-top:calc(-1.5385rem - 1px)}.history-list .editor__file-preview-link,.history-list .editor__file-preview-message--file-missing{max-width:50%;position:relative;display:block;text-align:center;font-size:10px;padding:10px;background:#f1f3f6;border:1px solid #dbe0e9;margin:0 auto 10px}.history-list .editor__specs{text-align:center}.history-list__back{padding:5px;position:absolute;top:0;left:-.76925rem;z-index:2} \ No newline at end of file +.gallery-item{opacity:1;position:relative;background-color:#fff;border:1px solid;border-color:#dbe0e9 #ced5e1 #c1cad9;width:178px;border-radius:.192rem;-webkit-transition:-webkit-box-shadow .3s;transition:-webkit-box-shadow .3s;-o-transition:box-shadow .3s;transition:box-shadow .3s;transition:box-shadow .3s,-webkit-box-shadow .3s;height:174px;-webkit-transition:opacity .25s linear;-o-transition:opacity .25s linear;transition:opacity .25s linear}.gallery-item:hover{-webkit-box-shadow:0 1px 4px rgba(0,0,0,.2);box-shadow:0 1px 4px rgba(0,0,0,.2);cursor:pointer}.gallery-item:not(.gallery-item--error):not(.gallery-item--folder):hover .gallery-item--overlay{opacity:1;display:block}.gallery-item--dropping{border-color:#29abe2;background-color:#e8f5ff}.gallery-item__draggable,.gallery-item__droppable{margin:0 1.2308rem 1.2308rem 0}.gallery-item__draggable>.gallery-item__droppable,.gallery-item__droppable>.gallery-item__draggable{margin:0}.gallery-item--folder{height:54px}.gallery-item--folder .gallery-item__thumbnail{background:url() 12px 14px no-repeat;-webkit-background-size:27px 24px;background-size:27px 24px;height:52px;width:45px;float:left}.gallery-item--folder .gallery-item__title{padding-top:17px;padding-bottom:17px;padding-left:0;width:131px;height:52px}.gallery-item--folder .gallery-item__checkbox-label{margin-top:5px}.gallery-item__thumbnail{height:132px;width:176px;margin:0 auto;background-repeat:no-repeat;background-position:50%;border-top-left-radius:.192rem;border-top-right-radius:.192rem;-webkit-background-size:cover;background-size:cover}.gallery-item__thumbnail--error{background-color:#dd3636}.gallery-item__thumbnail--no-preview{background-color:#566b8d}.gallery-item__thumbnail--loading{background:#fff url() 50% no-repeat}@media only screen and (-o-min-device-pixel-ratio:2/1),only screen and (-webkit-min-device-pixel-ratio:2),only screen and (min-device-pixel-ratio:2),only screen and (min-resolution:2dppx),only screen and (min-resolution:192dpi){.gallery-item__thumbnail--loading{background:#fff url() 50% no-repeat;-webkit-background-size:43px 43px;background-size:43px 43px}}.gallery-item__thumbnail--small{-webkit-background-size:auto auto;background-size:auto;background-color:#fff}.gallery-item__title{padding:11px 12px;height:40px;width:176px;margin:0;overflow:hidden;-webkit-box-sizing:border-box;box-sizing:border-box;text-overflow:ellipsis;white-space:nowrap;position:relative}.gallery-item--selectable .gallery-item__title{padding-right:32px}.asset-admin--single-select .gallery-item--selectable:not(.gallery-item--selected) .gallery-item__title{padding-right:12px}.gallery-item__checkbox{margin:13px 4px;-webkit-transform:scale(.1);-o-transform:scale(.1);transform:scale(.1);z-index:-1;position:absolute}.gallery-item__checkbox-label{width:30px;height:40px;position:absolute;right:0;top:0;margin-bottom:0}.asset-admin--single-select .gallery-item--selectable .gallery-item__checkbox-label{display:none}.gallery-item--selectable .gallery-item__checkbox-label:before{cursor:pointer;top:0;bottom:0;right:0;height:19px;width:19px;margin:auto 10px;position:absolute;border:1px solid #ced5e1;border-radius:.192rem;font-size:1.15em;padding:1px;color:transparent;background-color:#fff}.asset-admin--single-select .gallery-item--selected .gallery-item__checkbox-label{display:block}.asset-admin--single-select .gallery-item--selected .gallery-item__checkbox-label:before{margin:8px;border-radius:100%;font-size:1.5em}.gallery-item--selectable .gallery-item__checkbox-label:not(.gallery-item__checkbox-label--disabled):hover:before{border:1px solid #29abe2}.gallery-item--error .gallery-item__checkbox-label:before,.gallery-item__upload-progress+.gallery-item__title .gallery-item__checkbox-label:before{font-size:19px;border:0;border-radius:0;padding:0}.gallery-item--error .gallery-item__checkbox-label:hover:before,.gallery-item__upload-progress+.gallery-item__title .gallery-item__checkbox-label:hover:before{border:0}.gallery-item--error .gallery-item__checkbox-label,.gallery-item--error .gallery-item__thumbnail,.gallery-item--error .gallery-item__title,.gallery-item--error:hover{cursor:not-allowed}.gallery-item--error .gallery-item__checkbox-label:before{color:#d40404}.gallery-item__error-message{position:absolute;top:calc(50% - 20px);left:50%;-webkit-transform:translateX(-50%) translateY(-50%);-o-transform:translateX(-50%) translateY(-50%);transform:translateX(-50%) translateY(-50%);max-height:calc(100% - 40px);overflow:hidden;width:90%;color:#fff;background-color:#dd3636;text-align:center}.gallery-item--error .gallery-item__thumbnail,.gallery-item--missing .gallery-item__thumbnail{position:relative}.gallery-item--error .gallery-item__thumbnail:after,.gallery-item--missing .gallery-item__thumbnail:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#dd3636;border-radius:2px 2px 0 0}.gallery-item--error:hover .gallery-item__error-message,.gallery-item--error:hover .gallery-item__thumbnail:after,.gallery-item--missing:hover .gallery-item__error-message,.gallery-item--missing:hover .gallery-item__thumbnail:after{background:#d81d1d}.gallery-item--overlay{background:rgba(48,59,77,.5);position:absolute;top:0;right:0;left:0;opacity:0;display:none;-webkit-transition-property:opacity,background;-o-transition-property:opacity,background;transition-property:opacity,background;-webkit-transition-duration:.5s;-o-transition-duration:.5s;transition-duration:.5s;border-top-left-radius:.192rem;border-top-right-radius:.192rem;color:#fff;height:132px;width:100%;font-size:14px;padding-top:56px;text-align:center}.gallery-item--overlay:before{margin-right:5px}.gallery-item--selected{border-color:#29abe2}.gallery-item--selected .gallery-item__checkbox-label:before{border-color:#29abe2;background-color:#29abe2;color:#fff}.gallery__main--dragging .gallery-item--selected{opacity:.2}.gallery-item--highlighted,.gallery-item__drag-shadow{border-color:#29abe2;background-color:#e8f5ff}.gallery-item--focussed .gallery-item--overlay{opacity:1;display:block}.gallery-item--archive .gallery-item__thumbnail{background:#fff url() 50% no-repeat}.gallery-item--audio .gallery-item__thumbnail{background:#fff url() 50% no-repeat}.gallery-item--video .gallery-item__thumbnail{background:#fff url() 50% no-repeat}.gallery-item--document .gallery-item__thumbnail{background:#fff url() 50% no-repeat}.gallery-item--false .gallery-item__thumbnail{background:#fff url() 50% no-repeat}.gallery-item__upload-progress{height:18px;width:75%;position:absolute;top:calc(50% - 20px);left:50%;-webkit-transform:translateX(-50%) translateY(-50%);-o-transform:translateX(-50%) translateY(-50%);transform:translateX(-50%) translateY(-50%);border-radius:10px;overflow:hidden;background-color:#aebace}.gallery-item__upload-progress+.gallery-item__title .gallery-item__checkbox-label:before{color:#43536d}.gallery-item__progress-bar{height:100%;background:#29abe2;width:0}.gallery-item--draft,.gallery-item--modified{position:absolute;top:.76925rem;left:.76925rem;display:block;width:8px;height:8px;border:1px solid #cf3f00;-webkit-box-shadow:0 0 1px .5px #fff;box-shadow:0 0 1px .5px #fff;border-radius:100%;z-index:1}.gallery-item--draft:hover:after,.gallery-item--modified:hover:after{top:-4px;font-size:.75rem;font-weight:200;position:absolute;color:#fff;margin-left:.9231rem}.gallery-item--draft{background-color:#cf3f00}.gallery-item--draft:hover:after{content:"DRAFT"}.gallery-item--modified{background-color:#fff7f0}.gallery-item--modified:hover:after{content:"MODIFIED"}.gallery-item--max-selected{opacity:.2}.gallery-item--max-selected .gallery-item__checkbox-label,.gallery-item--max-selected .gallery-item__checkbox-label:before{cursor:not-allowed}.gallery-item--dragging{opacity:.2}.gallery-item--dragging.gallery-item{cursor:-webkit-grabbing;cursor:grabbing}.gallery-item__drag-layer-item .gallery-item--dragging{opacity:1}.gallery-item__drag-layer{position:fixed;left:0;top:0;right:0;bottom:0;pointer-events:none;z-index:100}.gallery-item__drag-layer-preview{-webkit-transform:scale(.4) translate(-100%,-160%);-o-transform:scale(.4) translate(-100%,-160%);transform:scale(.4) translate(-100%,-160%);border:1px solid #29abe2}.gallery-item__drag-layer-item{display:inline-block;position:relative;opacity:1}.gallery-item__drag-layer-item .gallery-item{border-width:2px;z-index:104;height:134px}.gallery-item__drag-layer-item .gallery-item__title{display:none}.gallery-item__drag-layer-count{top:-45%;left:25%;z-index:105}.gallery-item__badge,.gallery-item__drag-layer-count{display:inline-block;position:absolute;font-size:1rem}.gallery-item__badge{top:-.5rem;right:-.5rem;z-index:99}.gallery-item__drag-shadow{display:inline-block;position:absolute;left:0;top:0;right:0;bottom:0;-webkit-transform:translate(.75rem,-.75rem);-o-transform:translate(.75rem,-.75rem);transform:translate(.75rem,-.75rem);z-index:103;border:2px solid #29abe2;background:#fff}.gallery-item__drag-shadow.gallery-item__drag-shadow--second{-webkit-transform:translate(1.5rem,-1.5rem);-o-transform:translate(1.5rem,-1.5rem);transform:translate(1.5rem,-1.5rem);z-index:102}.bulk-actions{display:-webkit-box;display:-webkit-flex;display:flex;-webkit-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:start;-webkit-align-items:flex-start;align-items:flex-start;-webkit-box-pack:start;-webkit-justify-content:flex-start;justify-content:flex-start;width:100%;padding:.76925rem 1.5385rem;margin:0 auto;position:absolute;height:53px;z-index:2;bottom:0;background-color:#f1f3f6;-webkit-transition:top .5s ease-in-out,-webkit-transform .5s ease-in-out;transition:top .5s ease-in-out,-webkit-transform .5s ease-in-out;-o-transition:top .5s ease-in-out,-o-transform .5s ease-in-out;transition:top .5s ease-in-out,transform .5s ease-in-out;transition:top .5s ease-in-out,transform .5s ease-in-out,-webkit-transform .5s ease-in-out,-o-transform .5s ease-in-out;-webkit-transform:scale(1);-o-transform:scale(1);transform:scale(1);min-width:160px;border-top:1px solid #dbe0e9}.bulk-actions>*{-webkit-box-flex:0;-webkit-flex:0;flex:0}.bulk-actions-enter{bottom:-53px}.bulk-actions-enter-active{bottom:0;-webkit-transition:bottom .2s ease-out;-o-transition:bottom .2s ease-out;transition:bottom .2s ease-out}.bulk-actions-leave{bottom:0}.bulk-actions-leave-active{bottom:-53px;-webkit-transition:bottom .2s ease-in-out .1s;-o-transition:bottom .2s ease-in-out .1s;transition:bottom .2s ease-in-out .1s}.bulk-actions .bulk-actions-counter{vertical-align:middle;min-width:28px;padding:6px;margin-right:8px;line-height:1.5384;color:#fff;text-align:center;background-color:#0071c4;border-radius:.23rem;font-weight:700}.bulk-actions .bulk-actions__action.ss-ui-button{line-height:1.5384;margin-bottom:0;height:32px}.bulk-actions .bulk-actions__action.ss-ui-button[class*=font-icon-]:before{font-size:20px;line-height:18px;position:relative;top:-1px;vertical-align:middle}.bulk-actions .chosen-single{border-radius:5px 0 0 5px;border:0;-webkit-filter:none;filter:none;background:none;-webkit-box-shadow:none;box-shadow:none;color:inherit}.bulk-actions .chosen-single:focus{-webkit-box-shadow:0 0 3px rgba(0,0,0,.2);box-shadow:0 0 3px rgba(0,0,0,.2)}.bulk-actions .chosen-single>span{text-align:left;display:inline-block;margin-right:0}.bulk-actions .chosen-single>div{position:static;display:inline-block}.bulk-actions .chosen-drop{border-radius:3px;-webkit-box-shadow:0 0 3px rgba(0,0,0,.2);box-shadow:0 0 3px rgba(0,0,0,.2);border:0}.bulk-actions .search-choice-close{display:none}.bulk-actions .chosen-results li{padding-left:22px;position:relative}.bulk-actions .chosen-results li:before{position:absolute;font-family:silverstripe;left:4px;font-size:14px;vertical-align:middle;margin-right:4px}.bulk-actions .chosen-results li:first-child::before{content:"g"}.asset-dropzone:after{position:absolute;top:0;right:-1.5385rem;bottom:0;left:-1.5385rem;background:rgba(247,248,250,.9) url() 50% no-repeat;-webkit-background-size:312px 325px;background-size:312px 325px;z-index:100}.asset-dropzone.dragging:after{content:""}.asset-dropzone--button{position:static}.uploadfield__dropzone{position:relative;left:0;top:0;right:auto;bottom:auto;margin:0 0 10px;border:2px dashed #c1cad9;border-radius:5px;padding:0;background:#fdfefe;height:78px}.uploadfield__dropzone:after{left:0;top:0;right:0;bottom:0;-webkit-box-shadow:inset 0 0 10px 0 rgba(0,0,0,.2);box-shadow:inset 0 0 10px 0 rgba(0,0,0,.2);background-image:none;background:rgba(0,0,0,.03)}.uploadfield__dropzone--hidden{display:none}.uploadfield__backdrop{position:absolute;left:0;top:0;right:0;bottom:0;cursor:pointer}.uploadfield__join:after,.uploadfield__join:before{content:" ";display:inline}.uploadfield__add-button,.uploadfield__upload-button{border:0;margin:0;padding:0;background:none;text-decoration:none;color:#0071c4}.uploadfield__add-button:hover,.uploadfield__upload-button:hover{color:#0062ab;text-decoration:underline}.uploadfield__droptext{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);-o-transform:translate(-50%,-50%);transform:translate(-50%,-50%);display:inline-block;text-align:center}.uploadfield__droptext a,.uploadfield__droptext button{cursor:pointer}.uploadfield__droptext:before{font-family:silverstripe,sans-serif;content:"v";font-size:1.7em;padding-right:20px;vertical-align:middle}.uploadfield-item{position:relative;margin:0;background-color:#fff;border:1px solid;border-color:#ced5e1;border-bottom-width:0;width:auto;-webkit-transition:-webkit-box-shadow .3s;transition:-webkit-box-shadow .3s;-o-transition:box-shadow .3s;transition:box-shadow .3s;transition:box-shadow .3s,-webkit-box-shadow .3s;height:61px}.uploadfield-item:first-child{border-top-left-radius:.192rem;border-top-right-radius:.192rem}.uploadfield-item:last-child{border-bottom-width:1px;height:62px;border-bottom-left-radius:.192rem;border-bottom-right-radius:.192rem}.uploadfield-item:not(.uploadfield-item--error):not(.uploadfield-item--folder):hover .uploadfield-item--overlay{opacity:1;display:block}.uploadfield__dropzone+.uploadfield-item{border-top-left-radius:.192rem;border-top-right-radius:.192rem}.uploadfield-item--folder .uploadfield-item__thumbnail{background:url() 12px 14px no-repeat;-webkit-background-size:27px 24px;background-size:27px 24px}.uploadfield-item__thumbnail{height:60px;width:60px;margin:0;background-repeat:no-repeat;background-position:50%;-webkit-background-size:cover;background-size:cover;border-radius:.192rem .192rem 0 0}.uploadfield-item__thumbnail--small{-webkit-background-size:auto auto;background-size:auto;background-color:#fff}.uploadfield-item__details{padding:11px 0 11px 12px;height:100%;margin:0;-webkit-box-sizing:border-box;box-sizing:border-box;position:relative;width:50px;-webkit-box-pack:center;-webkit-justify-content:center;justify-content:center}.uploadfield-item__title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uploadfield-item__meta{font-size:.846rem;text-transform:uppercase}.uploadfield-item__specs{color:#566b8d}.uploadfield-item__remove-btn{margin:0}.uploadfield-item--archive .uploadfield-item__thumbnail{background:#fff url() 50% no-repeat}.uploadfield-item--audio .uploadfield-item__thumbnail{background:#fff url() 50% no-repeat}.uploadfield-item--video .uploadfield-item__thumbnail{background:#fff url() 50% no-repeat}.uploadfield-item--document .uploadfield-item__thumbnail{background:#fff url() 50% no-repeat}.uploadfield-item--false .uploadfield-item__thumbnail{background:#fff url() 50% no-repeat}.uploadfield-item__upload-progress{height:16px;margin:22px 5px;width:30%;border-radius:10px;overflow:hidden}.uploadfield-item__upload-progress+.uploadfield-item__title .uploadfield-item__checkbox-label:before{color:#43536d}.uploadfield-item__progress-bar{height:100%;background:#29abe2;width:0}.uploadfield-item__error-message{line-height:28px;height:28px;margin:16px 5px;padding:0 10px;color:#fff;background:#d40404;border-radius:14px;max-width:25%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uploadfield-item__complete-icon{line-height:38px;padding:11px 5px}.uploadfield-item__complete-icon:after{color:#3fa142;font-size:30px;display:inline;font-family:silverstripe,sans-serif;content:"I"}.uploadfield-item__status{margin:0 .6154rem;color:#cf3f00;background-color:#fff7f0;text-transform:uppercase}.preview-image-field__container{position:relative}.preview-image-field__toolbar{position:absolute;top:50%;right:0;-webkit-transform:translateY(-50%);-o-transform:translateY(-50%);transform:translateY(-50%);height:auto;max-height:100%;border-bottom-left-radius:.23rem;border-top-left-radius:.23rem;overflow:hidden}.preview-image-field__toolbar-button--link:before{content:"="}.preview-image-field__toolbar-button--replace:before{content:"b"}.preview-image-field__toolbar-button--remove:before{content:"D"}.preview-image-field__toolbar-button{padding:11px 0;height:47px;width:47px;overflow:hidden;background:#000;opacity:.55;color:#fff;border:0}.preview-image-field__toolbar-button:active,.preview-image-field__toolbar-button:focus,.preview-image-field__toolbar-button:hover{color:#b3b3b3;text-decoration:none}.preview-image-field__toolbar-button:before{padding:0 11px;font-family:silverstripe;font-style:normal;speak:none;line-height:1;font-size:25px;height:25px;width:25px;vertical-align:middle}.preview-image-field__progress{height:18px;width:75%;position:absolute;top:50%;left:50%;-webkit-transform:translateX(-50%) translateY(-50%);-o-transform:translateX(-50%) translateY(-50%);transform:translateX(-50%) translateY(-50%);border-radius:10px;overflow:hidden;background:#e6e6e6}.preview-image-field__progress-bar{height:100%;background:#29abe2;width:0}.preview-image-field__message{position:absolute;bottom:0;left:0;right:0;opacity:.8;padding:1.5385rem}.preview-image-field__message--error{color:#fff;background:#d40404}.preview-image-field__message--success{color:#fff;background:#3fa142}@media (min-width:768px){.search{position:relative;right:auto}.search.search--active{right:0}}.search.search--active{position:relative;width:100%}.search__group{opacity:0;overflow:hidden;display:none}.search--active .search__group{-webkit-transition:opacity .3s;-o-transition:opacity .3s;transition:opacity .3s;overflow:visible;opacity:1;display:block;width:100%}.search__trigger{z-index:1}.search--active .search__trigger{display:none}.search .search__trigger{margin-right:0}.search__submit{right:37px}.search__cancel,.search__submit{top:9px;position:absolute;margin-right:0}.search__cancel{right:4px;padding-right:5px;padding-left:5px;background-color:transparent}.search__cancel:hover{background-color:#e7ebf0}.search__filter-trigger-text{display:none;opacity:0;position:absolute;-webkit-transform:translateX(-106%);-o-transform:translateX(-106%);transform:translateX(-106%);font-size:.846rem;top:7px;color:#0071c4;-webkit-transition:opacity .3s;-o-transition:opacity .3s;transition:opacity .3s}.search__filter-trigger{display:block;border:0;margin:0;border-radius:0;position:absolute;top:10px;right:79px;outline:0;overflow:visible}.search__filter-trigger:hover:not(:disabled):not(.disabled){background-color:transparent}.search__filter-trigger:hover:not(:disabled):not(.disabled):before{color:#0071c4}.search__filter-trigger:hover:not(:disabled):not(.disabled) .search__filter-trigger-text{display:block;opacity:1}.search__filter-trigger:active,.search__filter-trigger:focus,.search__filter-trigger:hover{border:0;background-color:transparent;-webkit-box-shadow:none;box-shadow:none}.search__filter-trigger:before{margin:0;-webkit-transform:rotate(180deg) translateY(2px);-o-transform:rotate(180deg) translateY(2px);transform:rotate(180deg) translateY(2px)}.search__filter-trigger.collapsed:before{-webkit-transform:rotate(0deg) translateY(0);-o-transform:rotate(0deg) translateY(0);transform:rotate(0deg) translateY(0)}.search__filter-panel{position:absolute;padding:1.5385rem;background:#fff;margin-right:1px;right:0;top:53px;z-index:9999;-webkit-box-shadow:0 2px 6px 0 rgba(0,0,0,.3);box-shadow:0 2px 6px 0 rgba(0,0,0,.3);border-radius:0 0 .23rem .23rem;width:calc(100% - 2px)}@media (min-width:768px){.search__filter-panel{width:358px}}@media (min-width:992px){.search__filter-panel{width:498px}}.search__content-field{padding-right:113px;padding-left:18px;padding-top:4px;-webkit-box-shadow:0 1px 1px 0 #cbd3df,0 1px 5px 1px #dbe0e9;box-shadow:0 1px 1px 0 #cbd3df,0 1px 5px 1px #dbe0e9;border-top:0;border-bottom:0;border-radius:0;font-size:15px;height:52px;width:0;opacity:0;float:right}.search__content-field:focus{-webkit-box-shadow:0 1px 1px #66afe9,0 0 8px rgba(102,175,233,.6);box-shadow:0 1px 1px #66afe9,0 0 8px rgba(102,175,233,.6)}.search--active .search__content-field{opacity:1;width:100%}@media (min-width:768px){.search--active .search__content-field{width:360px;-webkit-transition:width .3s,opacity .3s;-o-transition:width .3s,opacity .3s;transition:width .3s,opacity .3s}}@media (min-width:992px){.search--active .search__content-field{width:500px}}.search__content-field::-ms-clear{display:none}.insert-embed-modal .modal-content{height:auto;max-height:100%}.insert-embed-modal .modal-body{display:-webkit-box;display:-webkit-flex;display:flex;-ms-grid-column-align:stretch;justify-items:stretch;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;flex-direction:column}.insert-embed-modal--edit{width:100%}@media (min-width:768px){.insert-embed-modal--edit .btn-toolbar{margin-left:30%}}.insert-embed-modal--create{-webkit-box-flex:1;-webkit-flex:1;flex:1;width:100%}.alert+.insert-embed-modal--create{padding-top:0}.insert-embed-modal__url-create .form-control.text{padding:.75rem 1.25rem;font-size:1.231rem;line-height:1.33333;border-radius:.5rem}@media (min-width:768px){.insert-embed-modal__fields--fill-width{width:100%;display:-webkit-box;display:-webkit-flex;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;flex-direction:row}}.insert-embed-modal__preview-container{padding-bottom:1.2308rem}@media (min-width:768px){.insert-embed-modal__preview-container{padding-right:1.2308rem;width:30%}}.insert-embed-modal__preview{display:block;max-width:100%;margin:0 auto;max-height:198px}.insert-embed-modal__placement .form__field-holder>div{display:-webkit-box;display:-webkit-flex;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;flex-direction:row;-ms-grid-column-align:stretch;justify-items:stretch}.insert-embed-modal__placement .form-check{-webkit-box-flex:1;-webkit-flex:1;flex:1;margin-bottom:0;padding-left:0}.insert-embed-modal__placement .form-check:first-of-type .form-check-label span:before{border-top-left-radius:.23rem;border-bottom-left-radius:.23rem}.insert-embed-modal__placement .form-check:last-of-type .form-check-label span:before{border-top-right-radius:.23rem;border-bottom-right-radius:.23rem}.insert-embed-modal__placement .form-check-label{display:block;cursor:pointer}.insert-embed-modal__placement .form-check-label span{display:block;color:rgba(67,83,109,0);font-size:.9rem;letter-spacing:1px;text-align:center;text-transform:uppercase;-webkit-transition:color .1s ease-out;-o-transition:color .1s ease-out;transition:color .1s ease-out}.insert-embed-modal__placement .form-check-label span:before{content:" ";display:block;-webkit-box-sizing:content-box;box-sizing:content-box;height:36px;padding:5px 0;border:1px solid #dbe0e9;background:url() top no-repeat content-box;-webkit-transition:background-color .1s ease-out;-o-transition:background-color .1s ease-out;transition:background-color .1s ease-out}.insert-embed-modal__placement .form-check-label:focus span,.insert-embed-modal__placement .form-check-label:hover span{color:#43536d}.insert-embed-modal__placement .form-check-input{position:absolute;left:-9999px}.insert-embed-modal__placement .form-check-input.checked+span{color:#29abe2}.insert-embed-modal__placement .form-check-input.checked+span:before{border:1px solid #29abe2;background:url() top no-repeat content-box,#e8f5ff padding-box}.insert-embed-modal__placement .form-check .option-val--leftAlone+span:before{background-position-y:-36px}.insert-embed-modal__placement .form-check .option-val--leftAlone.checked+span:before{background-position-y:0}.insert-embed-modal__placement .form-check .option-val--center+span:before{background-position-y:-108px}.insert-embed-modal__placement .form-check .option-val--center.checked+span:before{background-position-y:-72px}.insert-embed-modal__placement .form-check .option-val--rightAlone+span:before{background-position-y:-180px}.insert-embed-modal__placement .form-check .option-val--rightAlone.checked+span:before{background-position-y:-144px}.insert-embed-modal__placement .form-check .option-val--left+span:before{background-position-y:-252px}.insert-embed-modal__placement .form-check .option-val--left.checked+span:before{background-position-y:-216px}.insert-embed-modal__placement .form-check .option-val--right+span:before{background-position-y:-324px}.insert-embed-modal__placement .form-check .option-val--right.checked+span:before{background-position-y:-288px}.gallery,.gallery__main,.gallery__outer{position:relative}.gallery__main{height:100%}@media (max-width:991.98px){.gallery__main.gallery__main--has-opened-item{display:none}}.gallery__no-item-notice{text-align:center;font-size:1.231rem;margin-top:1.2308rem}.gallery__back{position:relative}.gallery__back.ss-ui-button:before{font-size:23px}.gallery__back .gallery__back-badge{display:inline-block;position:absolute;font-size:1rem;top:-.5rem;right:-1rem}.gallery__back--droppable-hover{background-color:#e7ebf0;border-color:transparent;-webkit-transform:scale(1.3);-o-transform:scale(1.3);transform:scale(1.3);border:1px solid #29abe2}.gallery__main--selectable{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin:-1.5385rem;padding:1.5385rem}.gallery__back-container{display:inline-block}.gallery__back-container .gallery-item__droppable{margin:0}.gallery__files,.gallery__folders{display:-webkit-box;display:-webkit-flex;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row wrap;flex-flow:row wrap}@media (max-width:991.98px){.gallery__files{margin-bottom:53px}}.gallery__load{width:100%;display:inline-block}.gallery__load-more{display:block;color:#fff;cursor:pointer;margin:8px auto 24px;padding:4px;width:200px;font-size:16px;height:44px;background-color:#29abe2;border:0;border-radius:4px}.gallery__sort{display:inline-block;vertical-align:middle;padding:.3846rem .7692rem}@media (max-width:767.98px){.gallery__sort .chosen-container{width:auto!important}}.gallery__sort .chosen-container-active .chosen-single{outline:1px dotted #29abe2;outline:5px auto -webkit-focus-ring-color}.gallery .gallery__sort .chosen-single{border:0;-webkit-filter:none;filter:none;background:none;-webkit-box-shadow:none;box-shadow:none;color:inherit;margin-top:-1px}.gallery__sort .chosen-single:focus{-webkit-box-shadow:0 0 3px rgba(0,0,0,.2);box-shadow:0 0 3px rgba(0,0,0,.2)}.gallery__sort .chosen-single>span{text-align:right;color:inherit}@media (max-width:767.98px){.gallery__sort .chosen-single>span{font-size:0}.gallery__sort .chosen-single>span:after{content:"\E003";font-size:1.231rem;font-family:silverstripe;color:#566b8d}}.gallery__sort .chosen-single>span:before{content:"Sort by "}.gallery__sort .chosen-drop{min-width:160px;right:0;border-radius:3px;-webkit-box-shadow:0 0 3px rgba(0,0,0,.2);box-shadow:0 0 3px rgba(0,0,0,.2);border:0}.gallery__sort .active-result{text-transform:capitalize}.gallery__error{display:table;width:100%;height:100%}.gallery__error-message{display:table-cell;vertical-align:middle;text-align:center}.gallery__view-change-button .icon:before{vertical-align:middle}@media (min-width:544px){.gallery__state-buttons{margin-right:-.7693rem}}.gallery__state-buttons .btn-group:last-child{margin-right:0}.gallery__view-change-button{margin-right:-.76925rem}.griddle-footer>div{display:-webkit-box;display:-webkit-flex;display:flex}.griddle-page{-webkit-box-flex:1;-webkit-flex:1;flex:1;text-align:center;margin-top:-3px}.griddle-page select{height:2.7692rem;padding:.3846rem .7692rem;line-height:1.5384;color:#566b8d;border:1px solid #cbd3df;background-color:#fff;background-image:none;text-align:center;display:inline}.griddle-page select:focus{color:#566b8d;background-color:#fff;border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),rgba(102,175,233,.6);box-shadow:inset 0 1px 1px rgba(0,0,0,.075),rgba(102,175,233,.6)}.griddle-footer{width:200px;margin:0 auto}.griddle-next,.griddle-previous{width:36px}.griddle-next button,.griddle-previous button{white-space:nowrap;border:0;background:transparent;width:36px;height:30px;position:relative;border-radius:.23rem;overflow:hidden}.griddle-next button:hover,.griddle-previous button:hover{background-color:#ced5e1;border-color:transparent}.griddle-next button:hover:before,.griddle-previous button:hover:before{background-color:#ced5e1}.griddle-next button:before,.griddle-previous button:before{font-family:silverstripe;color:#566b8d;width:36px;height:30px;background-color:#f7f8fa;position:absolute;top:0;left:0;padding:.3846rem;-webkit-transition:all .2s ease-in-out;-o-transition:all .2s ease-in-out;transition:all .2s ease-in-out;font-size:1.231rem;-webkit-font-smoothing:antialiased;line-height:1.5384}.griddle-previous button:before{content:"'"}.griddle-next button:before{content:"&"}.gallery__search-message-clear{padding-left:.6154rem}.gallery__table{margin-bottom:-1.5385rem}.gallery__table td,.gallery__table th{word-wrap:break-word}.gallery__table td{word-break:break-all}.gallery__table td.gallery__table-column-image{padding:0}.gallery__table th{cursor:pointer}.gallery__table th>span{display:inline;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery__table th>span:after{color:#8f9fba;content:")";display:inline-block;font-family:silverstripe;margin-left:4px}.gallery__table tbody td{padding-top:1.8462rem;padding-bottom:1.8462rem}@media (max-width:767.98px){.gallery__table tbody td:nth-child(n+4){display:none}}.gallery__table thead td,.gallery__table thead th{height:52px}.gallery__table thead th:hover{background-color:#f1f3f6}@media (max-width:767.98px){.gallery__table thead th:nth-child(n+4){display:none}}.gallery__table .sort-ascending,.gallery__table .sort-descending{border-bottom:1px solid #29abe2}.gallery__table .sort-ascending>span:after,.gallery__table .sort-descending>span:after{color:#29abe2}.gallery__table .sort-descending>span:after{content:"*"}.gallery__table .sort-ascending>span:after{content:"("}.gallery__table .footer-container,.gallery__table .footer-container:hover{background-color:#f7f8fa;border-bottom:0}.gallery__table-row{cursor:pointer}.gallery__table-column--select{width:1%}.gallery__table-column--select input[type=checkbox]{width:14px;height:14px}.gallery__table-row--highlighted{border-color:#29abe2;background-color:#e8f5ff}.gallery__table-column--image{width:68px;max-width:68px;height:69px;text-align:center}.gallery__table .gallery__table-row>.gallery__table-column--image{padding:0;vertical-align:middle}.gallery__table .gallery__table-row>.gallery__table-column--image:first-child{max-width:none;padding-left:1.5385rem}.gallery__table-image{background-repeat:no-repeat;background-position:50%;height:68px;width:68px;-webkit-background-size:calc(68px - 1.5385rem) auto;background-size:calc(68px - 1.5385rem) auto}.gallery__table-image--image{-webkit-background-size:68px auto;background-size:68px auto}.gallery__table-image--folder{background-image:url()}.gallery__table-image--archive{background-image:url()}.gallery__table-image--audio{background-image:url()}.gallery__table-image--video{background-image:url()}.gallery__table-image--document{background-image:url()}.gallery__table-image--error{background:#d40404;height:68px;width:68px}.gallery__table-image--error:after{content:"<";line-height:68px;font-size:30px;display:inline;font-family:silverstripe,sans-serif;color:#fff;opacity:.8}.gallery__progress-bar-progress{height:100%;background:#29abe2;width:0}.gallery__progress-bar{height:16px;width:30%;border-radius:10px;overflow:hidden}.gallery__progress-bar--complete:after{color:#3fa142;font-size:20px;display:inline;font-family:silverstripe,sans-serif;content:"I"}th.sort--disabled>span:after{content:""}.editor{background-color:#f7f8fa;z-index:2;position:absolute;height:100%;left:0}@media (min-width:992px){.editor{width:300px;border-left:1px solid #ced5e1;position:relative;padding-bottom:0}}@media (min-width:1200px){.editor{width:448px}}.editor .nav-tabs{z-index:1;position:relative}.editor .editor__details{-webkit-transform:translateZ(0);transform:translateZ(0)}.editor .editor__details .btn--close-panel{margin-right:0}.editor__heading{margin-right:2.4616rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.editor__status-flag{color:#f46b00;background-color:#fff7f2;border-color:#f46b00;clear:both;text-transform:uppercase;display:inline-block;position:relative;line-height:1rem;margin-left:3px}.editor__specs{color:#566b8d;font-size:.846rem;margin-bottom:1.2308rem}.editor__top-message{margin:-1.5385rem -1.5385rem 1.2308rem}.editor__file-preview{text-align:center;margin:0 -1.5385rem .76925rem;position:relative;max-height:336px;min-height:60px;overflow:hidden;display:block;-webkit-box-align:center;-webkit-align-items:center;align-items:center;text-decoration:none}.editor__file-preview:not(.editor__file-preview--folder):hover .editor__thumbnail{-webkit-transform:scale(1.04);-o-transform:scale(1.04);transform:scale(1.04)}.editor__file-preview--folder{margin-left:0;margin-right:0;width:100%}.editor__file-preview-link:before{position:absolute;top:50%;left:50%;margin-top:-25px;margin-left:-25px;padding:11px;height:50px;width:50px;border-radius:50%;background-color:rgba(0,0,0,.6);color:#fff;font-size:22px;opacity:0;content:"=";font-family:silverstripe;line-height:27px;z-index:1;-webkit-transition:all .5s;-o-transition:all .5s;transition:all .5s}.editor__file-preview-link:active:before,.editor__file-preview-link:hover,.editor__file-preview-link:hover:before{text-decoration:none;opacity:1}.editor__thumbnail{max-width:100%;max-height:336px;min-height:60px;margin:auto;-webkit-transform:scale(1);-o-transform:scale(1);transform:scale(1);-webkit-transition:all .5s;-o-transition:all .5s;transition:all .5s}.editor__file-preview-message--file-missing{margin:2.4616rem 0 1.2308rem;font-size:1.231rem;color:#d40404;text-align:center}@media (max-width:991.98px){.editor__heading,.editor__specs{text-align:center;margin-right:1.8462rem;margin-left:1.8462rem}.btn--close-panel{float:left;right:auto;margin-right:0;margin-left:-15px;color:#566b8d}.btn--close-panel:before{content:"5"}}.relative-time[title]{cursor:pointer;text-decoration:underline}.asset-admin .popover-field .popover{-webkit-box-shadow:0 2px 5px 0 rgba(0,0,0,.1),0 2px 10px 0 rgba(0,0,0,.1);box-shadow:0 2px 5px 0 rgba(0,0,0,.1),0 2px 10px 0 rgba(0,0,0,.1);font-size:1rem;min-width:230px}.asset-admin .popover-field .popover:focus{outline:none}.asset-admin .popover-field .popover.bottom .arrow,.asset-admin .popover-field .popover.top .arrow{margin-left:-5px}.asset-admin .popover-field .popover.top{margin-top:-10px}.asset-admin .popover-field .popover.left .arrow,.asset-admin .popover-field .popover.right .arrow{margin-top:-3px}.asset-admin .popover-field .popover.left{margin-left:-10px}.asset-admin .popover-field .popover-body{padding:.5rem .75rem}.asset-admin .popover-field .popover-body ul{padding-left:0!important;list-style-type:none;margin-left:-1.2308rem + 1px;margin-right:-1.2308rem + 1px;margin-bottom:0}.asset-admin .popover-field .popover-body a{display:block;padding:.3077rem 1.2308rem;color:#43536d}.asset-admin .popover-field .popover-body a:hover{text-decoration:none;background-color:#eef0f4;color:#43536d}.asset-admin .popover-field .popover-body .btn{padding-left:calc(1.2308rem - 1px);padding-right:calc(1.2308rem - 1px);margin-left:calc(-.75rem + 1px);margin-right:calc(-.75rem + 1px);display:block;width:calc(100% + 1.5rem - 2px);text-align:left;border-radius:0}.asset-admin .popover-field .popover-body .btn:hover{background-color:#e9f0f4}.asset-admin__toolbar-extra{width:auto}.insert-media-modal.modal-lg{width:calc(100% - 4.9232rem);max-width:1600px;margin-top:0;margin-left:auto;margin-right:auto;height:calc(100% - 53px)}@media (max-width:991.98px){.insert-media-modal.modal-lg{width:calc(100% - 1rem);height:calc(100% - .5rem);margin:0 auto}}.insert-media-modal .modal-content{height:100%;border-top-left-radius:0;border-top-right-radius:0}.insert-media-modal .modal-body{padding:0;height:100%}.insert-media-modal .editor__details{height:calc(100vh - 106px)}@media (max-width:991.98px){.insert-media-modal .editor__details{height:100%}}@media (min-width:992px){.insert-media-modal .btn--close-panel{display:none}}.insert-media-modal .tab-content{margin-bottom:1.2308rem}.insert-media-modal .fieldgroup.fill-width .field.flexbox-area-grow:first-child{margin-right:1.5385rem}.insert-media-modal .asset-admin--multi-select [name=action_insert]{display:none}@media (min-width:992px){.insert-media-modal .asset-admin--single-select [name=action_insert]{display:none}}@media (max-width:991.98px){.insert-media-modal .asset-admin--multi-select [name=action_insert]{display:block}}.insert-media-modal__main{height:calc(100vh - 106px)}.insert-media-modal__close-button{float:right;height:32px;font-size:28px;opacity:.5;margin:10px -10px 10px 0}.insert-media-modal__close-button:hover{opacity:.7}.insert-media-modal__close-button span{overflow:hidden;display:block;margin-top:-6px}.history-item{padding-top:1rem}.history-item:focus,.history-item:hover{background-color:#f1f3f6}.history-item p{margin-bottom:0}.list-group-flush:first-child .history-item:first-child{border-top:1px solid #ced5e1}.history-item__date,.history-item__version{opacity:.7;font-size:.846rem;margin-bottom:1px}.history-item__date{display:block}.history-item__version{position:absolute;right:1.5385rem;top:.9231rem;font-size:.846rem;opacity:.7}.history-item__status-flag{color:#3fa142;text-transform:uppercase;font-size:.923rem}.history-list{position:relative;min-height:50vh}.history-list>form{display:block}.history-list>.list-group{margin-top:calc(-1.5385rem - 1px)}.history-list .editor__file-preview-link,.history-list .editor__file-preview-message--file-missing{max-width:50%;position:relative;display:block;text-align:center;font-size:10px;padding:10px;background:#f1f3f6;border:1px solid #dbe0e9;margin:0 auto 10px}.history-list .editor__specs{text-align:center}.history-list__back{padding:5px;position:absolute;top:0;left:-.76925rem;z-index:2} +/*# sourceMappingURL=bundle.css.map*/ \ No newline at end of file diff --git a/client/src/boot/registerQueries.js b/client/src/boot/registerQueries.js index d0a6c9a3d..9807fdd32 100644 --- a/client/src/boot/registerQueries.js +++ b/client/src/boot/registerQueries.js @@ -1,10 +1,10 @@ import Injector from 'lib/Injector'; import { fileInterface, file, folder } from 'lib/fileFragments'; - +import readFilesQuery from 'state/files/readFilesQuery'; const registerQueries = () => { Injector.query.registerFragment('FileInterfaceFields', fileInterface); Injector.query.registerFragment('FileFields', file); Injector.query.registerFragment('FolderFields', folder); + Injector.query.register('ReadFilesQuery', readFilesQuery); }; - export default registerQueries; diff --git a/client/src/containers/AssetAdmin/AssetAdmin.js b/client/src/containers/AssetAdmin/AssetAdmin.js index 78edddfd4..a46bcb562 100644 --- a/client/src/containers/AssetAdmin/AssetAdmin.js +++ b/client/src/containers/AssetAdmin/AssetAdmin.js @@ -14,12 +14,12 @@ import Breadcrumb from 'components/Breadcrumb/Breadcrumb'; import Toolbar from 'components/Toolbar/Toolbar'; import { withApollo } from 'react-apollo'; import Search, { hasFilters } from 'components/Search/Search'; -import readFilesQuery from 'state/files/readFilesQuery'; import deleteFilesMutation from 'state/files/deleteFilesMutation'; import unpublishFilesMutation from 'state/files/unpublishFilesMutation'; import publishFilesMutation from 'state/files/publishFilesMutation'; import CONSTANTS from 'constants/index'; import configShape from 'lib/configShape'; +import { injectGraphql } from 'lib/Injector'; function getFormSchema({ config, viewAction, folderId, fileId, type }) { let schemaUrl = null; @@ -837,7 +837,7 @@ export { AssetAdmin as Component, getFormSchema }; export default compose( connect(mapStateToProps, mapDispatchToProps), - readFilesQuery, + injectGraphql('ReadFilesQuery'), deleteFilesMutation, unpublishFilesMutation, publishFilesMutation, diff --git a/client/src/state/files/readFilesQuery.js b/client/src/state/files/readFilesQuery.js index c848a108d..bd7b39442 100644 --- a/client/src/state/files/readFilesQuery.js +++ b/client/src/state/files/readFilesQuery.js @@ -2,48 +2,49 @@ import { graphql } from 'react-apollo'; import gql from 'graphql-tag'; import { fileInterface, file as fileFragment, folder as folderFragment } from 'lib/fileFragments'; import { hasFilters } from 'components/Search/Search'; +import { graphqlTemplates} from 'lib/Injector'; -// GraphQL Query -const query = gql` - query ReadFiles($limit:Int!, $offset:Int!, $rootFilter: FileFilterInput, - $childrenFilter: FileFilterInput, $sortBy:[ChildrenSortInputType] - ) { - readFiles(filter: $rootFilter) { - pageInfo { - totalCount - } - edges { - node { - ...FileInterfaceFields - ...FileFields - ...on Folder { - children(limit:$limit, offset:$offset, filter: $childrenFilter, sortBy:$sortBy) { - pageInfo { - totalCount - } - edges { - node { - ...FileInterfaceFields - ...FileFields - ...FolderFields - } - } - } - parents { - id - title - } - } - } - } - } - } - ${fileInterface} - ${fileFragment} - ${folderFragment} -`; +// // GraphQL Query +// const query = gql` +// query ReadFiles($limit:Int!, $offset:Int!, $rootFilter: FileFilterInput, +// $childrenFilter: FileFilterInput, $sortBy:[ChildrenSortInputType] +// ) { +// readFiles(filter: $rootFilter) { +// pageInfo { +// totalCount +// } +// edges { +// node { +// ...FileInterfaceFields +// ...FileFields +// ...on Folder { +// children(limit:$limit, offset:$offset, filter: $childrenFilter, sortBy:$sortBy) { +// pageInfo { +// totalCount +// } +// edges { +// node { +// ...FileInterfaceFields +// ...FileFields +// ...FolderFields +// } +// } +// } +// parents { +// id +// title +// } +// } +// } +// } +// } +// } +// ${fileInterface} +// ${fileFragment} +// ${folderFragment} +// `; -const config = { +const apolloConfig = { options({ sectionConfig, folderId, fileId, query: params }) { const filter = Object.assign({}, params.filter); const childrenFilter = Object.assign( @@ -131,6 +132,63 @@ const config = { }, }; -export { query, config }; - -export default graphql(query, config); +const { READ } = graphqlTemplates; +const query = { + apolloConfig, + templateName: READ, + pluralName: 'Files', + pagination: false, + params: { + limit: 'Int!', + offset: 'Int!', + rootFilter: 'FileFilterInput', + childrenFilter: 'FileFilterInput', + sortBy: '[ChildrenSortInputType]', + }, + args: { + 'root': { + filter: 'rootFilter' + }, + 'root/edges/node/...on Folder/children': { + limit: 'limit', + offset: 'offset', + filter: 'childrenFilter', + sortBy: 'sortBy', + }, + }, + fragments: [ + 'FileInterfaceFields', + 'FileFields', + 'FolderFields', + ], + fields: [ + 'pageInfo', [ + 'totalCount', + ], + 'edges', [ + 'node', [ + '...FileInterfaceFields', + '...FileFields', + '...on Folder', [ + 'children', [ + 'pageInfo', [ + 'totalCount', + ], + 'edges', [ + 'node', [ + '...FileInterfaceFields', + '...FileFields', + '...FolderFields', + ] + ] + ], + 'parents', [ + 'id', + 'title', + ] + ] + ] + ], + ], +}; +export default query; \ No newline at end of file