Submit
Path:
~
/
home
/
contenidosenred
/
public_html
/
OD
/
wp-content
/
plugins
/
masvideos
/
assets
/
js
/
blocks
/
File Content:
movies.js
(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){ "use strict"; var _ShortcodeAtts = require("../components/ShortcodeAtts"); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { keys.push.apply(keys, Object.getOwnPropertySymbols(object)); } if (enumerableOnly) keys = keys.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } 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; } var __ = wp.i18n.__; var registerBlockType = wp.blocks.registerBlockType; var InspectorControls = wp.editor.InspectorControls; var Fragment = wp.element.Fragment; var _wp$components = wp.components, ServerSideRender = _wp$components.ServerSideRender, Disabled = _wp$components.Disabled, PanelBody = _wp$components.PanelBody; registerBlockType('masvideos/movies', { title: __('Movies Block', 'masvideos'), icon: 'editor-video', category: 'masvideos-blocks', edit: function edit(props) { var attributes = props.attributes, className = props.className, setAttributes = props.setAttributes; var onChangeShortcodeAtts = function onChangeShortcodeAtts(newShortcodeAtts) { setAttributes(_objectSpread({}, newShortcodeAtts)); }; return wp.element.createElement(Fragment, null, wp.element.createElement(InspectorControls, null, wp.element.createElement(PanelBody, { title: __('Movies Attributes', 'masvideos'), initialOpen: true }, wp.element.createElement(_ShortcodeAtts.ShortcodeAtts, { postType: "movie", catTaxonomy: "movie_genre", tagTaxonomy: "movie_tag", attributes: _objectSpread({}, attributes), updateShortcodeAtts: onChangeShortcodeAtts }))), wp.element.createElement(Disabled, null, wp.element.createElement(ServerSideRender, { block: "masvideos/movies", attributes: attributes }))); }, save: function save() { // Rendering in PHP return null; } }); },{"../components/ShortcodeAtts":5}],2:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Item = void 0; /** * Item Component. * * @param {string} itemTitle - Current item title. * @param {function} clickHandler - this is the handling function for the add/remove function * @param {Integer} itemId - Current item ID * @param icon * @returns {*} Item HTML. */ var Item = function Item(_ref) { var _ref$title = _ref.title; _ref$title = _ref$title === void 0 ? {} : _ref$title; var itemTitle = _ref$title.rendered, name = _ref.name, clickHandler = _ref.clickHandler, itemId = _ref.id, icon = _ref.icon; return wp.element.createElement("article", { className: "item" }, wp.element.createElement("div", { className: "item-body" }, wp.element.createElement("h3", { className: "item-title" }, itemTitle, name)), wp.element.createElement("button", { onClick: function onClick() { return clickHandler(itemId); } }, icon)); }; exports.Item = Item; },{}],3:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ItemList = void 0; var _Item = require("./Item"); function _extends() { _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; }; return _extends.apply(this, arguments); } var __ = wp.i18n.__; /** * ItemList Component * @param object props - Component props. * @returns {*} * @constructor */ var ItemList = function ItemList(props) { var _props$filtered = props.filtered, filtered = _props$filtered === void 0 ? false : _props$filtered, _props$loading = props.loading, loading = _props$loading === void 0 ? false : _props$loading, _props$items = props.items, items = _props$items === void 0 ? [] : _props$items, _props$action = props.action, action = _props$action === void 0 ? function () {} : _props$action, _props$icon = props.icon, icon = _props$icon === void 0 ? null : _props$icon; if (loading) { return wp.element.createElement("p", { className: "loading-items" }, __('Loading ...', 'masvideos')); } if (filtered && items.length < 1) { return wp.element.createElement("div", { className: "item-list" }, wp.element.createElement("p", null, __('Your query yielded no results, please try again.', 'masvideos'))); } if (!items || items.length < 1) { return wp.element.createElement("p", { className: "no-items" }, __('Not found.', 'masvideos')); } return wp.element.createElement("div", { className: "item-list" }, items.map(function (item) { return wp.element.createElement(_Item.Item, _extends({ key: item.id }, item, { clickHandler: action, icon: icon })); })); }; exports.ItemList = ItemList; },{"./Item":2}],4:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.PostSelector = void 0; var _ItemList = require("./ItemList"); var api = _interopRequireWildcard(require("../utils/api")); var _usefulFuncs = require("../utils/useful-funcs"); 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)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } } function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); } function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); } function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { keys.push.apply(keys, Object.getOwnPropertySymbols(object)); } if (enumerableOnly) keys = keys.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } 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 _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); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } var __ = wp.i18n.__; var Icon = wp.components.Icon; var Component = wp.element.Component; /** * PostSelector Component */ var PostSelector = /*#__PURE__*/ function (_Component) { _inherits(PostSelector, _Component); /** * Constructor for PostSelector Component. * Sets up state, and creates bindings for functions. * @param object props - current component properties. */ function PostSelector(props) { var _this; _classCallCheck(this, PostSelector); _this = _possibleConstructorReturn(this, _getPrototypeOf(PostSelector).apply(this, arguments)); _this.props = props; _this.state = { posts: [], loading: false, type: props.postType || 'post', types: [], filter: '', filterLoading: false, filterPosts: [], initialLoading: false, selectedPosts: [] }; _this.addPost = _this.addPost.bind(_assertThisInitialized(_this)); _this.removePost = _this.removePost.bind(_assertThisInitialized(_this)); _this.handleInputFilterChange = _this.handleInputFilterChange.bind(_assertThisInitialized(_this)); _this.doPostFilter = (0, _usefulFuncs.debounce)(_this.doPostFilter.bind(_assertThisInitialized(_this)), 300); _this.getSelectedPostIds = _this.getSelectedPostIds.bind(_assertThisInitialized(_this)); _this.getSelectedPosts = _this.getSelectedPosts.bind(_assertThisInitialized(_this)); return _this; } /** * When the component mounts it calls this function. * Fetches posts types, selected posts then makes first call for posts */ _createClass(PostSelector, [{ key: "componentDidMount", value: function componentDidMount() { var _this2 = this; this.setState({ initialLoading: true }); api.getPostTypes().then(function (response) { _this2.setState({ types: response }, function () { _this2.retrieveSelectedPosts().then(function (selectedPosts) { if (selectedPosts) { _this2.setState({ initialLoading: false, selectedPosts: selectedPosts }); } else { _this2.setState({ initialLoading: false }); } }); }); }); } /** * GetPosts wrapper, builds the request argument based state and parameters passed/ * @param {object} args - desired arguments (can be empty). * @returns {Promise<T>} */ }, { key: "getPosts", value: function getPosts() { var _this3 = this; var args = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var postIds = this.getSelectedPostIds(); var defaultArgs = { per_page: 10, type: this.state.type, search: this.state.filter }; var requestArguments = _objectSpread({}, defaultArgs, {}, args); requestArguments.restBase = this.state.types[this.state.type].rest_base; return api.getPosts(requestArguments).then(function (response) { if (requestArguments.search) { _this3.setState({ filterPosts: response.filter(function (_ref) { var id = _ref.id; return postIds.indexOf(id) === -1; }) }); return response; } _this3.setState({ posts: (0, _usefulFuncs.uniqueById)([].concat(_toConsumableArray(_this3.state.posts), _toConsumableArray(response))) }); // return response to continue the chain return response; }); } /** * Gets the selected posts by id from the `posts` state object and sorts them by their position in the selected array. * @returns Array of objects. */ }, { key: "getSelectedPostIds", value: function getSelectedPostIds() { var selectedPostIds = this.props.selectedPostIds; if (selectedPostIds) { var postIds = Array.isArray(selectedPostIds) ? selectedPostIds : selectedPostIds.split(','); return postIds; } return []; } /** * Gets the selected posts by id from the `posts` state object and sorts them by their position in the selected array. * @returns Array of objects. */ }, { key: "getSelectedPosts", value: function getSelectedPosts(postIds) { var postList = (0, _usefulFuncs.uniqueById)([].concat(_toConsumableArray(this.state.filterPosts), _toConsumableArray(this.state.posts))); var selectedPosts = postList.filter(function (_ref2) { var id = _ref2.id; return postIds.indexOf(id) !== -1; }).sort(function (a, b) { var aIndex = postIds.indexOf(a.id); var bIndex = postIds.indexOf(b.id); if (aIndex > bIndex) { return 1; } if (aIndex < bIndex) { return -1; } return 0; }); this.setState({ selectedPosts: selectedPosts }); } /** * Makes the necessary api calls to fetch the selected posts and returns a promise. * @returns {*} */ }, { key: "retrieveSelectedPosts", value: function retrieveSelectedPosts() { var _this$props = this.props, postType = _this$props.postType, selectedPostIds = _this$props.selectedPostIds; var types = this.state.types; var postIds = this.getSelectedPostIds().join(','); if (!postIds) { // return a fake promise that auto resolves. return new Promise(function (resolve) { return resolve(); }); } var post_args = { include: postIds, per_page: 100, postType: postType }; if (this.props.postStatus) { post_args.status = this.props.postStatus; } return this.getPosts(_objectSpread({}, post_args)); } /** * Adds desired post id to the selectedPostIds List * @param {Integer} post_id */ }, { key: "addPost", value: function addPost(post_id) { if (this.state.filter) { var post = this.state.filterPosts.filter(function (p) { return p.id === post_id; }); var posts = (0, _usefulFuncs.uniqueById)([].concat(_toConsumableArray(this.state.posts), _toConsumableArray(post))); this.setState({ posts: posts }); } if (this.props.selectSingle) { var selectedPostIds = [post_id]; this.props.updateSelectedPostIds(selectedPostIds); this.getSelectedPosts(selectedPostIds); } else { var postIds = this.getSelectedPostIds(); var _selectedPostIds = [].concat(_toConsumableArray(postIds), [post_id]); this.props.updateSelectedPostIds(_selectedPostIds); this.getSelectedPosts(_selectedPostIds); } } /** * Removes desired post id to the selectedPostIds List * @param {Integer} post_id */ }, { key: "removePost", value: function removePost(post_id) { var postIds = this.getSelectedPostIds(); var selectedPostIds = _toConsumableArray(postIds).filter(function (id) { return id !== post_id; }); this.props.updateSelectedPostIds(selectedPostIds); this.getSelectedPosts(selectedPostIds); } /** * Handles the search box input value * @param string type - comes from the event object target. */ }, { key: "handleInputFilterChange", value: function handleInputFilterChange() { var _this4 = this; var _ref3 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, _ref3$target = _ref3.target; _ref3$target = _ref3$target === void 0 ? {} : _ref3$target; var _ref3$target$value = _ref3$target.value, filter = _ref3$target$value === void 0 ? '' : _ref3$target$value; this.setState({ filter: filter }, function () { if (!filter) { // remove filtered posts return _this4.setState({ filteredPosts: [], filtering: false }); } _this4.doPostFilter(); }); } /** * Actual api call for searching for query, this function is debounced in constructor. */ }, { key: "doPostFilter", value: function doPostFilter() { var _this5 = this; var _this$state$filter = this.state.filter, filter = _this$state$filter === void 0 ? '' : _this$state$filter; if (!filter) { return; } this.setState({ filtering: true, filterLoading: true }); var post_args = {}; if (this.props.postStatus) { post_args.status = this.props.postStatus; } this.getPosts(_objectSpread({}, post_args)).then(function () { _this5.setState({ filterLoading: false }); }); } /** * Renders the PostSelector component. */ }, { key: "render", value: function render() { var postList = this.state.filtering && !this.state.filterLoading ? this.state.filterPosts : []; var addIcon = wp.element.createElement(Icon, { icon: "plus" }); var removeIcon = wp.element.createElement(Icon, { icon: "minus" }); var searchinputuniqueId = 'searchinput-' + Math.random().toString(36).substr(2, 16); return wp.element.createElement("div", { className: "components-base-control components-post-selector" }, wp.element.createElement("div", { className: "components-base-control__field--selected" }, wp.element.createElement("h2", null, __('Search Post', 'masvideos')), wp.element.createElement(_ItemList.ItemList, { items: _toConsumableArray(this.state.selectedPosts), loading: this.state.initialLoading, action: this.removePost, icon: removeIcon })), wp.element.createElement("div", { className: "components-base-control__field" }, wp.element.createElement("label", { htmlFor: searchinputuniqueId, className: "components-base-control__label" }, wp.element.createElement(Icon, { icon: "search" })), wp.element.createElement("input", { className: "components-text-control__input", id: searchinputuniqueId, type: "search", placeholder: __('Please enter your search query...', 'masvideos'), value: this.state.filter, onChange: this.handleInputFilterChange }), wp.element.createElement(_ItemList.ItemList, { items: postList, loading: this.state.initialLoading || this.state.loading || this.state.filterLoading, filtered: this.state.filtering, action: this.addPost, icon: addIcon }))); } }]); return PostSelector; }(Component); exports.PostSelector = PostSelector; },{"../utils/api":7,"../utils/useful-funcs":8,"./ItemList":3}],5:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ShortcodeAtts = void 0; var _PostSelector = require("./PostSelector"); var _TermSelector = require("./TermSelector"); function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } var __ = wp.i18n.__; var Component = wp.element.Component; var _wp$components = wp.components, RangeControl = _wp$components.RangeControl, SelectControl = _wp$components.SelectControl, CheckboxControl = _wp$components.CheckboxControl; var applyFilters = wp.hooks.applyFilters; /** * ShortcodeAtts Component */ var ShortcodeAtts = /*#__PURE__*/ function (_Component) { _inherits(ShortcodeAtts, _Component); /** * Constructor for ShortcodeAtts Component. * Sets up state, and creates bindings for functions. * @param object props - current component properties. */ function ShortcodeAtts(props) { var _this; _classCallCheck(this, ShortcodeAtts); _this = _possibleConstructorReturn(this, _getPrototypeOf(ShortcodeAtts).apply(this, arguments)); _this.props = props; _this.onChangeLimit = _this.onChangeLimit.bind(_assertThisInitialized(_this)); _this.onChangeColumns = _this.onChangeColumns.bind(_assertThisInitialized(_this)); _this.onChangeOrderby = _this.onChangeOrderby.bind(_assertThisInitialized(_this)); _this.onChangeOrder = _this.onChangeOrder.bind(_assertThisInitialized(_this)); _this.onChangeIds = _this.onChangeIds.bind(_assertThisInitialized(_this)); _this.onChangeCategory = _this.onChangeCategory.bind(_assertThisInitialized(_this)); _this.onChangeGenre = _this.onChangeGenre.bind(_assertThisInitialized(_this)); _this.onChangeTag = _this.onChangeTag.bind(_assertThisInitialized(_this)); _this.onChangeFeatured = _this.onChangeFeatured.bind(_assertThisInitialized(_this)); _this.onChangeTopRated = _this.onChangeTopRated.bind(_assertThisInitialized(_this)); return _this; } _createClass(ShortcodeAtts, [{ key: "onChangeLimit", value: function onChangeLimit(newLimit) { this.props.updateShortcodeAtts({ limit: newLimit }); } }, { key: "onChangeColumns", value: function onChangeColumns(newColumns) { this.props.updateShortcodeAtts({ columns: newColumns }); } }, { key: "onChangeOrderby", value: function onChangeOrderby(newOrderby) { this.props.updateShortcodeAtts({ orderby: newOrderby }); } }, { key: "onChangeOrder", value: function onChangeOrder(newOrder) { this.props.updateShortcodeAtts({ order: newOrder }); } }, { key: "onChangeIds", value: function onChangeIds(newIds) { this.props.updateShortcodeAtts({ ids: newIds.join(',') }); } }, { key: "onChangeCategory", value: function onChangeCategory(newCategory) { this.props.updateShortcodeAtts({ category: newCategory.join(',') }); } }, { key: "onChangeGenre", value: function onChangeGenre(newGenre) { this.props.updateShortcodeAtts({ genre: newGenre.join(',') }); } }, { key: "onChangeTag", value: function onChangeTag(newTag) { this.props.updateShortcodeAtts({ tag: newTag.join(',') }); } }, { key: "onChangeFeatured", value: function onChangeFeatured(newFeatured) { this.props.updateShortcodeAtts({ featured: newFeatured }); } }, { key: "onChangeTopRated", value: function onChangeTopRated(newTopRated) { this.props.updateShortcodeAtts({ top_rated: newTopRated }); } /** * Renders the ShortcodeAtts component. */ }, { key: "render", value: function render() { var _this$props = this.props, attributes = _this$props.attributes, postType = _this$props.postType, catTaxonomy = _this$props.catTaxonomy, tagTaxonomy = _this$props.tagTaxonomy, _this$props$minLimit = _this$props.minLimit, minLimit = _this$props$minLimit === void 0 ? 1 : _this$props$minLimit, _this$props$maxLimit = _this$props.maxLimit, maxLimit = _this$props$maxLimit === void 0 ? 20 : _this$props$maxLimit, _this$props$minColumn = _this$props.minColumns, minColumns = _this$props$minColumn === void 0 ? 1 : _this$props$minColumn, _this$props$maxColumn = _this$props.maxColumns, maxColumns = _this$props$maxColumn === void 0 ? 6 : _this$props$maxColumn, hideFields = _this$props.hideFields; var limit = attributes.limit, columns = attributes.columns, orderby = attributes.orderby, order = attributes.order, ids = attributes.ids, category = attributes.category, genre = attributes.genre, tag = attributes.tag, featured = attributes.featured, top_rated = attributes.top_rated; return wp.element.createElement("div", null, !(hideFields && hideFields.includes('limit')) ? wp.element.createElement(RangeControl, { label: __('Limit', 'masvideos'), value: limit, onChange: this.onChangeLimit, min: applyFilters('masvideos.component.shortcodeAtts.limit.min', minLimit), max: applyFilters('masvideos.component.shortcodeAtts.limit.max', maxLimit) }) : '', !(hideFields && hideFields.includes('columns')) ? wp.element.createElement(RangeControl, { label: __('Columns', 'masvideos'), value: columns, onChange: this.onChangeColumns, min: applyFilters('masvideos.component.shortcodeAtts.columns.min', minColumns), max: applyFilters('masvideos.component.shortcodeAtts.columns.max', maxColumns) }) : '', !(hideFields && hideFields.includes('orderby')) ? wp.element.createElement(SelectControl, { label: __('Orderby', 'masvideos'), value: orderby, options: applyFilters('masvideos.component.shortcodeAtts.orderby.options', [{ label: __('Title', 'masvideos'), value: 'title' }, { label: __('Date', 'masvideos'), value: postType === 'movie' ? 'release_date' : 'date' }, { label: __('ID', 'masvideos'), value: 'id' }, { label: __('Random', 'masvideos'), value: 'rand' }], this.props), onChange: this.onChangeOrderby }) : '', !(hideFields && hideFields.includes('order')) ? wp.element.createElement(SelectControl, { label: __('Order', 'masvideos'), value: order, options: applyFilters('masvideos.component.shortcodeAtts.order.options', [{ label: __('ASC', 'masvideos'), value: 'ASC' }, { label: __('DESC', 'masvideos'), value: 'DESC' }], this.props), onChange: this.onChangeOrder }) : '', !(hideFields && hideFields.includes('ids')) ? wp.element.createElement(_PostSelector.PostSelector, { postType: postType, selectedPostIds: ids ? ids.split(',').map(Number) : [], updateSelectedPostIds: this.onChangeIds }) : '', postType === 'video' && catTaxonomy && !(hideFields && hideFields.includes('category')) ? wp.element.createElement(_TermSelector.TermSelector, { postType: postType, taxonomy: catTaxonomy, title: __('Search Category', 'masvideos'), selectedTermIds: category ? category.split(',').map(Number) : [], updateSelectedTermIds: this.onChangeCategory }) : catTaxonomy && !(hideFields && hideFields.includes('genre')) ? wp.element.createElement(_TermSelector.TermSelector, { postType: postType, taxonomy: catTaxonomy, title: __('Search Genre', 'masvideos'), selectedTermIds: genre ? genre.split(',').map(Number) : [], updateSelectedTermIds: this.onChangeGenre }) : '', !(hideFields && hideFields.includes('tag')) ? wp.element.createElement(_TermSelector.TermSelector, { postType: postType, taxonomy: tagTaxonomy, title: __('Search Tag', 'masvideos'), selectedTermIds: tag ? tag.split(',').map(Number) : [], updateSelectedTermIds: this.onChangeTag }) : '', !(hideFields && hideFields.includes('featured')) ? wp.element.createElement(CheckboxControl, { label: __('Featured', 'masvideos'), help: __('Check to select featured posts.', 'masvideos'), checked: featured, onChange: this.onChangeFeatured }) : '', !(hideFields && hideFields.includes('top_rated')) ? wp.element.createElement(CheckboxControl, { label: __('Top Rated', 'masvideos'), help: __('Check to select top rated posts.', 'masvideos'), checked: top_rated, onChange: this.onChangeTopRated }) : ''); } }]); return ShortcodeAtts; }(Component); exports.ShortcodeAtts = ShortcodeAtts; },{"./PostSelector":4,"./TermSelector":6}],6:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.TermSelector = void 0; var _ItemList = require("./ItemList"); var api = _interopRequireWildcard(require("../utils/api")); var _usefulFuncs = require("../utils/useful-funcs"); 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)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } } function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); } function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); } function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { keys.push.apply(keys, Object.getOwnPropertySymbols(object)); } if (enumerableOnly) keys = keys.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } 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 _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); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } var __ = wp.i18n.__; var Icon = wp.components.Icon; var Component = wp.element.Component; /** * TermSelector Component */ var TermSelector = /*#__PURE__*/ function (_Component) { _inherits(TermSelector, _Component); /** * Constructor for TermSelector Component. * Sets up state, and creates bindings for functions. * @param object props - current component properties. */ function TermSelector(props) { var _this; _classCallCheck(this, TermSelector); _this = _possibleConstructorReturn(this, _getPrototypeOf(TermSelector).apply(this, arguments)); _this.props = props; _this.state = { terms: [], loading: false, type: props.postType || 'post', taxonomy: props.taxonomy || 'category', taxonomies: [], filter: '', filterLoading: false, filterTerms: [], initialLoading: false }; _this.addTerm = _this.addTerm.bind(_assertThisInitialized(_this)); _this.removeTerm = _this.removeTerm.bind(_assertThisInitialized(_this)); _this.handleInputFilterChange = _this.handleInputFilterChange.bind(_assertThisInitialized(_this)); _this.doTermFilter = (0, _usefulFuncs.debounce)(_this.doTermFilter.bind(_assertThisInitialized(_this)), 300); return _this; } /** * When the component mounts it calls this function. * Fetches terms taxonomies, selected terms then makes first call for terms */ _createClass(TermSelector, [{ key: "componentDidMount", value: function componentDidMount() { var _this2 = this; this.setState({ initialLoading: true }); api.getTaxonomies({ type: this.state.type }).then(function (response) { _this2.setState({ taxonomies: response }, function () { _this2.retrieveSelectedTerms().then(function () { _this2.setState({ initialLoading: false }); }); }); }); } /** * GetTerms wrapper, builds the request argument based state and parameters passed/ * @param {object} args - desired arguments (can be empty). * @returns {Promise<T>} */ }, { key: "getTerms", value: function getTerms() { var _this3 = this; var args = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var selectedTermIds = this.props.selectedTermIds; var defaultArgs = { per_page: 10, type: this.state.type, taxonomy: this.state.taxonomy, search: this.state.filter }; var requestArguments = _objectSpread({}, defaultArgs, {}, args); requestArguments.restBase = this.state.taxonomies[this.state.taxonomy].rest_base; return api.getTerms(requestArguments).then(function (response) { if (requestArguments.search) { _this3.setState({ filterTerms: response.filter(function (_ref) { var id = _ref.id; return selectedTermIds.indexOf(id) === -1; }) }); return response; } _this3.setState({ terms: (0, _usefulFuncs.uniqueById)([].concat(_toConsumableArray(_this3.state.terms), _toConsumableArray(response))) }); // return response to continue the chain return response; }); } /** * Gets the selected terms by id from the `terms` state object and sorts them by their position in the selected array. * @returns Array of objects. */ }, { key: "getSelectedTerms", value: function getSelectedTerms() { var _this4 = this; var selectedTermIds = this.props.selectedTermIds; return this.state.terms.filter(function (_ref2) { var id = _ref2.id; return selectedTermIds.indexOf(id) !== -1; }).sort(function (a, b) { var aIndex = _this4.props.selectedTermIds.indexOf(a.id); var bIndex = _this4.props.selectedTermIds.indexOf(b.id); if (aIndex > bIndex) { return 1; } if (aIndex < bIndex) { return -1; } return 0; }); } /** * Makes the necessary api calls to fetch the selected terms and returns a promise. * @returns {*} */ }, { key: "retrieveSelectedTerms", value: function retrieveSelectedTerms() { var _this$props = this.props, termType = _this$props.termType, selectedTermIds = _this$props.selectedTermIds; var taxonomies = this.state.taxonomies; if (selectedTermIds && !selectedTermIds.length > 0) { // return a fake promise that auto resolves. return new Promise(function (resolve) { return resolve(); }); } return this.getTerms({ include: this.props.selectedTermIds.join(','), per_page: 100, termType: termType }); } /** * Adds desired term id to the selectedTermIds List * @param {Integer} term_id */ }, { key: "addTerm", value: function addTerm(term_id) { if (this.state.filter) { var term = this.state.filterTerms.filter(function (p) { return p.id === term_id; }); var terms = (0, _usefulFuncs.uniqueById)([].concat(_toConsumableArray(this.state.terms), _toConsumableArray(term))); this.setState({ terms: terms }); } this.props.updateSelectedTermIds([].concat(_toConsumableArray(this.props.selectedTermIds), [term_id])); } /** * Removes desired term id to the selectedTermIds List * @param {Integer} term_id */ }, { key: "removeTerm", value: function removeTerm(term_id) { this.props.updateSelectedTermIds(_toConsumableArray(this.props.selectedTermIds).filter(function (id) { return id !== term_id; })); } /** * Handles the search box input value * @param string type - comes from the event object target. */ }, { key: "handleInputFilterChange", value: function handleInputFilterChange() { var _this5 = this; var _ref3 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, _ref3$target = _ref3.target; _ref3$target = _ref3$target === void 0 ? {} : _ref3$target; var _ref3$target$value = _ref3$target.value, filter = _ref3$target$value === void 0 ? '' : _ref3$target$value; this.setState({ filter: filter }, function () { if (!filter) { // remove filtered terms return _this5.setState({ filteredTerms: [], filtering: false }); } _this5.doTermFilter(); }); } /** * Actual api call for searching for query, this function is debounced in constructor. */ }, { key: "doTermFilter", value: function doTermFilter() { var _this6 = this; var _this$state$filter = this.state.filter, filter = _this$state$filter === void 0 ? '' : _this$state$filter; if (!filter) { return; } this.setState({ filtering: true, filterLoading: true }); this.getTerms().then(function () { _this6.setState({ filterLoading: false }); }); } /** * Renders the TermSelector component. */ }, { key: "render", value: function render() { var _this$props$title = this.props.title, title = _this$props$title === void 0 ? __('Search Term', 'masvideos') : _this$props$title; var isFiltered = this.state.filtering; var termList = isFiltered && !this.state.filterLoading ? this.state.filterTerms : []; var SelectedTermList = this.getSelectedTerms(); var addIcon = wp.element.createElement(Icon, { icon: "plus" }); var removeIcon = wp.element.createElement(Icon, { icon: "minus" }); var searchinputuniqueId = 'searchinput-' + Math.random().toString(36).substr(2, 16); return wp.element.createElement("div", { className: "components-base-control components-term-selector" }, wp.element.createElement("div", { className: "components-base-control__field--selected" }, wp.element.createElement("h2", null, title), wp.element.createElement(_ItemList.ItemList, { items: SelectedTermList, loading: this.state.initialLoading, action: this.removeTerm, icon: removeIcon })), wp.element.createElement("div", { className: "components-base-control__field" }, wp.element.createElement("label", { htmlFor: searchinputuniqueId, className: "components-base-control__label" }, wp.element.createElement(Icon, { icon: "search" })), wp.element.createElement("input", { className: "components-text-control__input", id: searchinputuniqueId, type: "search", placeholder: __('Please enter your search query...', 'masvideos'), value: this.state.filter, onChange: this.handleInputFilterChange }), wp.element.createElement(_ItemList.ItemList, { items: termList, loading: this.state.initialLoading || this.state.loading || this.state.filterLoading, filtered: isFiltered, action: this.addTerm, icon: addIcon }))); } }]); return TermSelector; }(Component); exports.TermSelector = TermSelector; },{"../utils/api":7,"../utils/useful-funcs":8,"./ItemList":3}],7:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.getTerms = exports.getTaxonomies = exports.getPosts = exports.getPostTypes = void 0; function _extends() { _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; }; return _extends.apply(this, arguments); } function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } var _wp = wp, apiFetch = _wp.apiFetch; /** * Makes a get request to the PostTypes endpoint. * * @returns {Promise<any>} */ var getPostTypes = function getPostTypes() { return apiFetch({ path: '/wp/v2/types' }); }; /** * Makes a get request to the desired post type and builds the query string based on an object. * * @param {string|boolean} restBase - rest base for the query. * @param {object} args * @returns {Promise<any>} */ exports.getPostTypes = getPostTypes; var getPosts = function getPosts(_ref) { var _ref$restBase = _ref.restBase, restBase = _ref$restBase === void 0 ? false : _ref$restBase, args = _objectWithoutProperties(_ref, ["restBase"]); var queryString = Object.keys(args).map(function (arg) { return "".concat(arg, "=").concat(args[arg]); }).join('&'); var path = "/wp/v2/".concat(restBase, "?").concat(queryString, "&_embed"); return apiFetch({ path: path }); }; /** * Makes a get request to the PostType Taxonomies endpoint. * * @returns {Promise<any>} */ exports.getPosts = getPosts; var getTaxonomies = function getTaxonomies(_ref2) { var args = _extends({}, _ref2); var queryString = Object.keys(args).map(function (arg) { return "".concat(arg, "=").concat(args[arg]); }).join('&'); var path = "/wp/v2/taxonomies?".concat(queryString, "&_embed"); return apiFetch({ path: path }); }; /** * Makes a get request to the desired post type and builds the query string based on an object. * * @param {string|boolean} restBase - rest base for the query. * @param {object} args * @returns {Promise<any>} */ exports.getTaxonomies = getTaxonomies; var getTerms = function getTerms(_ref3) { var _ref3$restBase = _ref3.restBase, restBase = _ref3$restBase === void 0 ? false : _ref3$restBase, args = _objectWithoutProperties(_ref3, ["restBase"]); var queryString = Object.keys(args).map(function (arg) { return "".concat(arg, "=").concat(args[arg]); }).join('&'); var path = "/wp/v2/".concat(restBase, "?").concat(queryString, "&_embed"); return apiFetch({ path: path }); }; exports.getTerms = getTerms; },{}],8:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.debounce = exports.uniqueById = exports.uniqueBy = void 0; /** * Returns a unique array of objects based on a desired key. * @param {array} arr - array of objects. * @param {string|int} key - key to filter objects by */ var uniqueBy = function uniqueBy(arr, key) { var keys = []; return arr.filter(function (item) { if (keys.indexOf(item[key]) !== -1) { return false; } return keys.push(item[key]); }); }; /** * Returns a unique array of objects based on the id property. * @param {array} arr - array of objects to filter. * @returns {*} */ exports.uniqueBy = uniqueBy; var uniqueById = function uniqueById(arr) { return uniqueBy(arr, 'id'); }; /** * Debounce a function by limiting how often it can run. * @param {function} func - callback function * @param {Integer} wait - Time in milliseconds how long it should wait. * @returns {Function} */ exports.uniqueById = uniqueById; var debounce = function debounce(func, wait) { var timeout = null; return function () { var context = this; var args = arguments; var later = function later() { func.apply(context, args); }; clearTimeout(timeout); timeout = setTimeout(later, wait); }; }; exports.debounce = debounce; },{}]},{},[1]) //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","assets/esnext/blocks/movies.js","assets/esnext/components/Item.js","assets/esnext/components/ItemList.js","assets/esnext/components/PostSelector.js","assets/esnext/components/ShortcodeAtts.js","assets/esnext/components/TermSelector.js","assets/esnext/utils/api.js","assets/esnext/utils/useful-funcs.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","import { ShortcodeAtts } from '../components/ShortcodeAtts';\n\nconst { __ } = wp.i18n;\nconst { registerBlockType } = wp.blocks;\nconst { InspectorControls } = wp.editor;\nconst { Fragment } = wp.element;\nconst { ServerSideRender, Disabled, PanelBody } = wp.components;\n\nregisterBlockType( 'masvideos/movies', {\n    title: __('Movies Block', 'masvideos'),\n\n    icon: 'editor-video',\n\n    category: 'masvideos-blocks',\n\n    edit: ( ( props ) => {\n        const { attributes, className, setAttributes } = props;\n\n        const onChangeShortcodeAtts = newShortcodeAtts => {\n            setAttributes( { ...newShortcodeAtts } );\n        };\n\n        return (\n            <Fragment>\n                <InspectorControls>\n                    <PanelBody\n                        title={__('Movies Attributes', 'masvideos')}\n                        initialOpen={ true }\n                    >\n                        <ShortcodeAtts\n                            postType = 'movie'\n                            catTaxonomy = 'movie_genre'\n                            tagTaxonomy = 'movie_tag'\n                            attributes = { { ...attributes } }\n                            updateShortcodeAtts = { onChangeShortcodeAtts }\n                        />\n                    </PanelBody>\n                </InspectorControls>\n                <Disabled>\n                    <ServerSideRender\n                        block = \"masvideos/movies\"\n                        attributes = { attributes }\n                    />\n                </Disabled>\n            </Fragment>\n        );\n    } ),\n\n    save() {\n        // Rendering in PHP\n        return null;\n    },\n} );","\n/**\n * Item Component.\n *\n * @param {string} itemTitle - Current item title.\n * @param {function} clickHandler - this is the handling function for the add/remove function\n * @param {Integer} itemId - Current item ID\n * @param icon\n * @returns {*} Item HTML.\n */\nexport const Item = ({ title: { rendered: itemTitle } = {}, name, clickHandler, id: itemId, icon }) => (\n    <article className=\"item\">\n        <div className=\"item-body\">\n            <h3 className=\"item-title\">{itemTitle}{name}</h3>\n        </div>\n        <button onClick={() => clickHandler(itemId)}>{icon}</button>\n    </article>\n);","import { Item } from './Item';\n\nconst { __ } = wp.i18n;\n\n/**\n * ItemList Component\n * @param object props - Component props.\n * @returns {*}\n * @constructor\n */\nexport const ItemList = props => {\n    const { filtered = false, loading = false, items = [], action = () => {}, icon = null } = props;\n\n    if (loading) {\n        return <p className=\"loading-items\">{__('Loading ...', 'masvideos')}</p>;\n    }\n\n    if (filtered && items.length < 1) {\n        return (\n            <div className=\"item-list\">\n                <p>{__('Your query yielded no results, please try again.', 'masvideos')}</p>\n            </div>\n        );\n    }\n\n    if ( ! items || items.length < 1 ) {\n        return <p className=\"no-items\">{__('Not found.', 'masvideos')}</p>\n    }\n\n    return (\n        <div className=\"item-list\">\n            {items.map((item) => <Item key={item.id} {...item} clickHandler={action} icon={icon} />)}\n        </div>\n    );\n};","import { ItemList } from './ItemList';\nimport * as api from '../utils/api';\nimport { uniqueById, debounce } from '../utils/useful-funcs';\n\nconst { __ } = wp.i18n;\nconst { Icon } = wp.components;\nconst { Component } = wp.element;\n\n/**\n * PostSelector Component\n */\nexport class PostSelector extends Component {\n    /**\n     * Constructor for PostSelector Component.\n     * Sets up state, and creates bindings for functions.\n     * @param object props - current component properties.\n     */\n    constructor(props) {\n        super(...arguments);\n        this.props = props;\n\n        this.state = {\n            posts: [],\n            loading: false,\n            type: props.postType || 'post',\n            types: [],\n            filter: '',\n            filterLoading: false,\n            filterPosts: [],\n            initialLoading: false,\n            selectedPosts: [],\n        };\n\n        this.addPost = this.addPost.bind(this);\n        this.removePost = this.removePost.bind(this);\n        this.handleInputFilterChange = this.handleInputFilterChange.bind(this);\n        this.doPostFilter = debounce(this.doPostFilter.bind(this), 300);\n        this.getSelectedPostIds = this.getSelectedPostIds.bind(this);\n        this.getSelectedPosts = this.getSelectedPosts.bind(this);\n    }\n\n    /**\n     * When the component mounts it calls this function.\n     * Fetches posts types, selected posts then makes first call for posts\n     */\n    componentDidMount() {\n        this.setState({\n            initialLoading: true,\n        });\n\n        api.getPostTypes()\n            .then(( response ) => {\n                this.setState({\n                    types: response\n                }, () => {\n                    this.retrieveSelectedPosts()\n                        .then(( selectedPosts ) => {\n                            if( selectedPosts ) {\n                                this.setState({\n                                    initialLoading: false,\n                                    selectedPosts: selectedPosts,\n                                });\n                            } else {\n                                this.setState({\n                                    initialLoading: false,\n                                });\n                            }\n                        })\n                });\n            });\n    }\n\n    /**\n     * GetPosts wrapper, builds the request argument based state and parameters passed/\n     * @param {object} args - desired arguments (can be empty).\n     * @returns {Promise<T>}\n     */\n    getPosts(args = {}) {\n        const postIds = this.getSelectedPostIds();\n\n        const defaultArgs = {\n            per_page: 10,\n            type: this.state.type,\n            search: this.state.filter,\n        };\n\n        const requestArguments = {\n            ...defaultArgs,\n            ...args\n        };\n\n        requestArguments.restBase = this.state.types[this.state.type].rest_base;\n\n        return api.getPosts(requestArguments)\n            .then(response => {\n                if (requestArguments.search) {\n                    this.setState({\n                        filterPosts: response.filter(({ id }) => postIds.indexOf(id) === -1),\n                    });\n\n                    return response;\n                }\n\n                this.setState({\n                    posts: uniqueById([...this.state.posts, ...response]),\n                });\n\n                // return response to continue the chain\n                return response;\n            });\n    }\n\n    /**\n     * Gets the selected posts by id from the `posts` state object and sorts them by their position in the selected array.\n     * @returns Array of objects.\n     */\n    getSelectedPostIds() {\n        const { selectedPostIds } = this.props;\n\n        if( selectedPostIds ) {\n            const postIds = Array.isArray( selectedPostIds ) ? selectedPostIds : selectedPostIds.split(',');\n            return postIds;\n        }\n\n        return [];\n    }\n\n    /**\n     * Gets the selected posts by id from the `posts` state object and sorts them by their position in the selected array.\n     * @returns Array of objects.\n     */\n    getSelectedPosts( postIds ) {\n        const postList = uniqueById([\n            ...this.state.filterPosts,\n            ...this.state.posts\n        ]);\n        const selectedPosts = postList\n            .filter(({ id }) => postIds.indexOf(id) !== -1)\n            .sort((a, b) => {\n                const aIndex = postIds.indexOf(a.id);\n                const bIndex = postIds.indexOf(b.id);\n\n                if (aIndex > bIndex) {\n                    return 1;\n                }\n\n                if (aIndex < bIndex) {\n                    return -1;\n                }\n\n                return 0;\n            });\n\n        this.setState({\n            selectedPosts: selectedPosts,\n        });\n    }\n\n    /**\n     * Makes the necessary api calls to fetch the selected posts and returns a promise.\n     * @returns {*}\n     */\n    retrieveSelectedPosts() {\n        const { postType, selectedPostIds } = this.props;\n        const { types } = this.state;\n\n        const postIds = this.getSelectedPostIds().join(',');\n\n        if ( ! postIds ) {\n            // return a fake promise that auto resolves.\n            return new Promise((resolve) => resolve());\n        }\n\n        let post_args = {\n            include: postIds,\n            per_page: 100,\n            postType\n        };\n\n        if( this.props.postStatus ) {\n            post_args.status = this.props.postStatus;\n        }\n\n        return this.getPosts({\n            ...post_args\n        });\n    }\n\n    /**\n     * Adds desired post id to the selectedPostIds List\n     * @param {Integer} post_id\n     */\n    addPost(post_id) {\n        if (this.state.filter) {\n            const post = this.state.filterPosts.filter(p => p.id === post_id);\n            const posts = uniqueById([\n                ...this.state.posts,\n                ...post\n            ]);\n\n            this.setState({\n                posts\n            });\n        }\n\n        if( this.props.selectSingle ) {\n            const selectedPostIds = [ post_id ];\n            this.props.updateSelectedPostIds( selectedPostIds );\n            this.getSelectedPosts( selectedPostIds );\n        } else {\n            const postIds = this.getSelectedPostIds();\n            const selectedPostIds = [ ...postIds, post_id ];\n            this.props.updateSelectedPostIds( selectedPostIds );\n            this.getSelectedPosts( selectedPostIds );\n        }\n    }\n\n    /**\n     * Removes desired post id to the selectedPostIds List\n     * @param {Integer} post_id\n     */\n    removePost(post_id) {\n        const postIds = this.getSelectedPostIds();\n        const selectedPostIds = [ ...postIds ].filter(id => id !== post_id);\n        this.props.updateSelectedPostIds( selectedPostIds );\n        this.getSelectedPosts( selectedPostIds );\n    }\n\n    /**\n     * Handles the search box input value\n     * @param string type - comes from the event object target.\n     */\n    handleInputFilterChange({ target: { value:filter = '' } = {} } = {}) {\n        this.setState({\n            filter\n        }, () => {\n            if (!filter) {\n                // remove filtered posts\n                return this.setState({ filteredPosts: [], filtering: false });\n            }\n\n            this.doPostFilter();\n        })\n    }\n\n    /**\n     * Actual api call for searching for query, this function is debounced in constructor.\n     */\n    doPostFilter() {\n        const { filter = '' } = this.state;\n\n        if (!filter) {\n            return;\n        }\n\n        this.setState({\n            filtering: true,\n            filterLoading: true\n        });\n\n        let post_args = {};\n\n        if( this.props.postStatus ) {\n            post_args.status = this.props.postStatus;\n        }\n\n        this.getPosts({\n            ...post_args\n        }).then(() => {\n            this.setState({\n                filterLoading: false\n            });\n        });\n    }\n\n    /**\n     * Renders the PostSelector component.\n     */\n    render() {\n        const postList = this.state.filtering && !this.state.filterLoading ? this.state.filterPosts : [];\n\n        const addIcon = <Icon icon=\"plus\" />;\n        const removeIcon = <Icon icon=\"minus\" />;\n\n        const searchinputuniqueId = 'searchinput-' + Math.random().toString(36).substr(2, 16);\n\n        return (\n            <div className=\"components-base-control components-post-selector\">\n                <div className=\"components-base-control__field--selected\">\n                    <h2>{__('Search Post', 'masvideos')}</h2>\n                    <ItemList\n                        items={ [...this.state.selectedPosts] }\n                        loading={this.state.initialLoading}\n                        action={this.removePost}\n                        icon={removeIcon}\n                    />\n                </div>\n                <div className=\"components-base-control__field\">\n                    <label htmlFor={searchinputuniqueId} className=\"components-base-control__label\">\n                        <Icon icon=\"search\" />\n                    </label>\n                    <input\n                        className=\"components-text-control__input\"\n                        id={searchinputuniqueId}\n                        type=\"search\"\n                        placeholder={__('Please enter your search query...', 'masvideos')}\n                        value={this.state.filter}\n                        onChange={this.handleInputFilterChange}\n                    />\n                    <ItemList\n                        items={postList}\n                        loading={this.state.initialLoading||this.state.loading||this.state.filterLoading}\n                        filtered={this.state.filtering}\n                        action={this.addPost}\n                        icon={addIcon}\n                    />\n                </div>\n            </div>\n        );\n    }\n}","import { PostSelector } from './PostSelector';\nimport { TermSelector } from './TermSelector';\n\nconst { __ } = wp.i18n;\nconst { Component } = wp.element;\nconst { RangeControl, SelectControl, CheckboxControl } = wp.components;\nconst { applyFilters } = wp.hooks;\n\n/**\n * ShortcodeAtts Component\n */\nexport class ShortcodeAtts extends Component {\n    /**\n     * Constructor for ShortcodeAtts Component.\n     * Sets up state, and creates bindings for functions.\n     * @param object props - current component properties.\n     */\n    constructor(props) {\n        super(...arguments);\n        this.props = props;\n\n        this.onChangeLimit = this.onChangeLimit.bind(this);\n        this.onChangeColumns = this.onChangeColumns.bind(this);\n        this.onChangeOrderby = this.onChangeOrderby.bind(this);\n        this.onChangeOrder = this.onChangeOrder.bind(this);\n        this.onChangeIds = this.onChangeIds.bind(this);\n        this.onChangeCategory = this.onChangeCategory.bind(this);\n        this.onChangeGenre = this.onChangeGenre.bind(this);\n        this.onChangeTag = this.onChangeTag.bind(this);\n        this.onChangeFeatured = this.onChangeFeatured.bind(this);\n        this.onChangeTopRated = this.onChangeTopRated.bind(this);\n    }\n\n    onChangeLimit( newLimit ) {\n        this.props.updateShortcodeAtts({\n            limit: newLimit\n        });\n    }\n\n    onChangeColumns( newColumns ) {\n        this.props.updateShortcodeAtts({\n            columns: newColumns\n        });\n    }\n\n    onChangeOrderby( newOrderby ) {\n        this.props.updateShortcodeAtts({\n            orderby: newOrderby\n        });\n    }\n\n    onChangeOrder( newOrder ) {\n        this.props.updateShortcodeAtts({\n            order: newOrder\n        });\n    }\n\n    onChangeIds( newIds ) {\n        this.props.updateShortcodeAtts({\n            ids: newIds.join(',')\n        });\n    }\n\n    onChangeCategory( newCategory ) {\n        this.props.updateShortcodeAtts({\n            category: newCategory.join(',')\n        });\n    }\n\n    onChangeGenre( newGenre ) {\n        this.props.updateShortcodeAtts({\n            genre: newGenre.join(',')\n        });\n    }\n\n    onChangeTag( newTag ) {\n        this.props.updateShortcodeAtts({\n            tag: newTag.join(',')\n        });\n    }\n\n    onChangeFeatured( newFeatured ) {\n        this.props.updateShortcodeAtts({\n            featured: newFeatured\n        });\n    }\n\n    onChangeTopRated( newTopRated ) {\n        this.props.updateShortcodeAtts({\n            top_rated: newTopRated\n        });\n    }\n\n    /**\n     * Renders the ShortcodeAtts component.\n     */\n    render() {\n        const { attributes, postType, catTaxonomy, tagTaxonomy, minLimit = 1, maxLimit = 20, minColumns = 1, maxColumns = 6, hideFields } = this.props;\n        const { limit, columns, orderby, order, ids, category, genre, tag, featured, top_rated } = attributes;\n\n        return (\n            <div>\n                { !( hideFields && hideFields.includes('limit') ) ? (\n                <RangeControl\n                    label={__('Limit', 'masvideos')}\n                    value={ limit }\n                    onChange={ this.onChangeLimit }\n                    min={ applyFilters( 'masvideos.component.shortcodeAtts.limit.min', minLimit ) }\n                    max={ applyFilters( 'masvideos.component.shortcodeAtts.limit.max', maxLimit ) }\n                />\n                ) : '' }\n                { !( hideFields && hideFields.includes('columns') ) ? (\n                <RangeControl\n                    label={__('Columns', 'masvideos')}\n                    value={ columns }\n                    onChange={ this.onChangeColumns }\n                    min={ applyFilters( 'masvideos.component.shortcodeAtts.columns.min', minColumns ) }\n                    max={ applyFilters( 'masvideos.component.shortcodeAtts.columns.max', maxColumns ) }\n                />\n                ) : '' }\n                { !( hideFields && hideFields.includes('orderby') ) ? (\n                <SelectControl\n                    label={__('Orderby', 'masvideos')}\n                    value={ orderby }\n                    options={ applyFilters( 'masvideos.component.shortcodeAtts.orderby.options', [\n                        { label: __('Title', 'masvideos'), value: 'title' },\n                        { label: __('Date', 'masvideos'), value: ( postType === 'movie' ? 'release_date' : 'date' ) },\n                        { label: __('ID', 'masvideos'), value: 'id' },\n                        { label: __('Random', 'masvideos'), value: 'rand' },\n                    ], this.props ) }\n                    onChange={ this.onChangeOrderby }\n                />\n                ) : '' }\n                { !( hideFields && hideFields.includes('order') ) ? (\n                <SelectControl\n                    label={__('Order', 'masvideos')}\n                    value={ order }\n                    options={ applyFilters( 'masvideos.component.shortcodeAtts.order.options', [\n                        { label: __('ASC', 'masvideos'), value: 'ASC' },\n                        { label: __('DESC', 'masvideos'), value: 'DESC' },\n                    ], this.props ) }\n                    onChange={ this.onChangeOrder }\n                />\n                ) : '' }\n                { !( hideFields && hideFields.includes('ids') ) ? (\n                <PostSelector\n                    postType = { postType }\n                    selectedPostIds={ ids ? ids.split(',').map(Number) : [] }\n                    updateSelectedPostIds={ this.onChangeIds }\n                />\n                ) : '' }\n                { ( postType === 'video' ) && catTaxonomy && !( hideFields && hideFields.includes('category') ) ? (\n                <TermSelector\n                    postType = { postType }\n                    taxonomy = { catTaxonomy }\n                    title = { __('Search Category', 'masvideos') }\n                    selectedTermIds={ category ? category.split(',').map(Number) : [] }\n                    updateSelectedTermIds={ this.onChangeCategory }\n                />\n                ) : ( catTaxonomy && !( hideFields && hideFields.includes('genre') ) ? (\n                <TermSelector\n                    postType = { postType }\n                    taxonomy = { catTaxonomy }\n                    title = { __('Search Genre', 'masvideos') }\n                    selectedTermIds={ genre ? genre.split(',').map(Number) : [] }\n                    updateSelectedTermIds={ this.onChangeGenre }\n                />\n                ) : '' ) }\n                { !( hideFields && hideFields.includes('tag') ) ? (\n                <TermSelector\n                    postType = { postType }\n                    taxonomy = { tagTaxonomy }\n                    title = { __('Search Tag', 'masvideos') }\n                    selectedTermIds={ tag ? tag.split(',').map(Number) : [] }\n                    updateSelectedTermIds={ this.onChangeTag }\n                />\n                ) : '' }\n                { !( hideFields && hideFields.includes('featured') ) ? (\n                <CheckboxControl\n                    label={__('Featured', 'masvideos')}\n                    help={__('Check to select featured posts.', 'masvideos')}\n                    checked={ featured }\n                    onChange={ this.onChangeFeatured }\n                />\n                ) : '' }\n                { !( hideFields && hideFields.includes('top_rated') ) ? (\n                <CheckboxControl\n                    label={__('Top Rated', 'masvideos')}\n                    help={__('Check to select top rated posts.', 'masvideos')}\n                    checked={ top_rated }\n                    onChange={ this.onChangeTopRated }\n                />\n                ) : '' }\n            </div>\n        );\n    }\n}","import { ItemList } from \"./ItemList\";\nimport * as api from '../utils/api';\nimport { uniqueById, debounce } from '../utils/useful-funcs';\n\nconst { __ } = wp.i18n;\nconst { Icon } = wp.components;\nconst { Component } = wp.element;\n\n/**\n * TermSelector Component\n */\nexport class TermSelector extends Component {\n    /**\n     * Constructor for TermSelector Component.\n     * Sets up state, and creates bindings for functions.\n     * @param object props - current component properties.\n     */\n    constructor(props) {\n        super(...arguments);\n        this.props = props;\n\n        this.state = {\n            terms: [],\n            loading: false,\n            type: props.postType || 'post',\n            taxonomy: props.taxonomy || 'category',\n            taxonomies: [],\n            filter: '',\n            filterLoading: false,\n            filterTerms: [],\n            initialLoading: false,\n        };\n\n        this.addTerm = this.addTerm.bind(this);\n        this.removeTerm = this.removeTerm.bind(this);\n        this.handleInputFilterChange = this.handleInputFilterChange.bind(this);\n        this.doTermFilter = debounce(this.doTermFilter.bind(this), 300);\n    }\n\n    /**\n     * When the component mounts it calls this function.\n     * Fetches terms taxonomies, selected terms then makes first call for terms\n     */\n    componentDidMount() {\n        this.setState({\n            initialLoading: true,\n        });\n\n        api.getTaxonomies( { type: this.state.type } )\n            .then(( response ) => {\n                this.setState({\n                    taxonomies: response\n                }, () => {\n                    this.retrieveSelectedTerms()\n                        .then(() => {\n                            this.setState({\n                                initialLoading: false,\n                            });\n                        })\n                });\n            });\n    }\n\n    /**\n     * GetTerms wrapper, builds the request argument based state and parameters passed/\n     * @param {object} args - desired arguments (can be empty).\n     * @returns {Promise<T>}\n     */\n    getTerms(args = {}) {\n        const { selectedTermIds } = this.props;\n\n        const defaultArgs = {\n            per_page: 10,\n            type: this.state.type,\n            taxonomy: this.state.taxonomy,\n            search: this.state.filter,\n        };\n\n        const requestArguments = {\n            ...defaultArgs,\n            ...args\n        };\n\n        requestArguments.restBase = this.state.taxonomies[this.state.taxonomy].rest_base;\n\n        return api.getTerms(requestArguments)\n            .then(response => {\n                if (requestArguments.search) {\n                    this.setState({\n                        filterTerms: response.filter(({ id }) => selectedTermIds.indexOf(id) === -1),\n                    });\n\n                    return response;\n                }\n\n                this.setState({\n                    terms: uniqueById([...this.state.terms, ...response]),\n                });\n\n                // return response to continue the chain\n                return response;\n            });\n    }\n\n    /**\n     * Gets the selected terms by id from the `terms` state object and sorts them by their position in the selected array.\n     * @returns Array of objects.\n     */\n    getSelectedTerms() {\n        const { selectedTermIds } = this.props;\n        return this.state.terms\n            .filter(({ id }) => selectedTermIds.indexOf(id) !== -1)\n            .sort((a, b) => {\n                const aIndex = this.props.selectedTermIds.indexOf(a.id);\n                const bIndex = this.props.selectedTermIds.indexOf(b.id);\n\n                if (aIndex > bIndex) {\n                    return 1;\n                }\n\n                if (aIndex < bIndex) {\n                    return -1;\n                }\n\n                return 0;\n            });\n    }\n\n    /**\n     * Makes the necessary api calls to fetch the selected terms and returns a promise.\n     * @returns {*}\n     */\n    retrieveSelectedTerms() {\n        const { termType, selectedTermIds } = this.props;\n        const { taxonomies } = this.state;\n\n        if ( selectedTermIds && !selectedTermIds.length > 0 ) {\n            // return a fake promise that auto resolves.\n            return new Promise((resolve) => resolve());\n        }\n\n        return this.getTerms({\n            include: this.props.selectedTermIds.join(','),\n            per_page: 100,\n            termType\n        });\n    }\n\n    /**\n     * Adds desired term id to the selectedTermIds List\n     * @param {Integer} term_id\n     */\n    addTerm(term_id) {\n        if (this.state.filter) {\n            const term = this.state.filterTerms.filter(p => p.id === term_id);\n            const terms = uniqueById([\n                ...this.state.terms,\n                ...term\n            ]);\n\n            this.setState({\n                terms\n            });\n        }\n\n        this.props.updateSelectedTermIds([\n            ...this.props.selectedTermIds,\n            term_id\n        ]);\n    }\n\n    /**\n     * Removes desired term id to the selectedTermIds List\n     * @param {Integer} term_id\n     */\n    removeTerm(term_id) {\n        this.props.updateSelectedTermIds([\n            ...this.props.selectedTermIds\n        ].filter(id => id !== term_id));\n    }\n\n    /**\n     * Handles the search box input value\n     * @param string type - comes from the event object target.\n     */\n    handleInputFilterChange({ target: { value:filter = '' } = {} } = {}) {\n        this.setState({\n            filter\n        }, () => {\n            if (!filter) {\n                // remove filtered terms\n                return this.setState({ filteredTerms: [], filtering: false });\n            }\n\n            this.doTermFilter();\n        })\n    }\n\n    /**\n     * Actual api call for searching for query, this function is debounced in constructor.\n     */\n    doTermFilter() {\n        const { filter = '' } = this.state;\n\n        if (!filter) {\n            return;\n        }\n\n        this.setState({\n            filtering: true,\n            filterLoading: true\n        });\n\n        this.getTerms()\n            .then(() => {\n                this.setState({\n                    filterLoading: false\n                });\n            });\n    }\n\n    /**\n     * Renders the TermSelector component.\n     */\n    render() {\n        const { title = __('Search Term', 'masvideos') } = this.props;\n        const isFiltered = this.state.filtering;\n        const termList = isFiltered && !this.state.filterLoading ? this.state.filterTerms : [];\n        const SelectedTermList  = this.getSelectedTerms();\n\n        const addIcon = <Icon icon=\"plus\" />;\n        const removeIcon = <Icon icon=\"minus\" />;\n\n        const searchinputuniqueId = 'searchinput-' + Math.random().toString(36).substr(2, 16);\n\n        return (\n            <div className=\"components-base-control components-term-selector\">\n                <div className=\"components-base-control__field--selected\">\n                    <h2>{ title }</h2>\n                    <ItemList\n                        items={SelectedTermList}\n                        loading={this.state.initialLoading}\n                        action={this.removeTerm}\n                        icon={removeIcon}\n                    />\n                </div>\n                <div className=\"components-base-control__field\">\n                    <label htmlFor={searchinputuniqueId} className=\"components-base-control__label\">\n                        <Icon icon=\"search\" />\n                    </label>\n                    <input\n                        className=\"components-text-control__input\"\n                        id={searchinputuniqueId}\n                        type=\"search\"\n                        placeholder={__('Please enter your search query...', 'masvideos')}\n                        value={this.state.filter}\n                        onChange={this.handleInputFilterChange}\n                    />\n                    <ItemList\n                        items={termList}\n                        loading={this.state.initialLoading||this.state.loading||this.state.filterLoading}\n                        filtered={isFiltered}\n                        action={this.addTerm}\n                        icon={addIcon}\n                    />\n                </div>\n            </div>\n        );\n    }\n}","const { apiFetch } = wp;\n\n/**\n * Makes a get request to the PostTypes endpoint.\n *\n * @returns {Promise<any>}\n */\nexport const getPostTypes = () => {\n    return apiFetch( { path: '/wp/v2/types' } );\n};\n\n/**\n * Makes a get request to the desired post type and builds the query string based on an object.\n *\n * @param {string|boolean} restBase - rest base for the query.\n * @param {object} args\n * @returns {Promise<any>}\n */\nexport const getPosts = ({ restBase = false, ...args }) => {\n    const queryString = Object.keys(args).map(arg => `${arg}=${args[arg]}`).join('&');\n\n    let path = `/wp/v2/${restBase}?${queryString}&_embed`;\n    return apiFetch( { path: path } );\n};\n\n/**\n * Makes a get request to the PostType Taxonomies endpoint.\n *\n * @returns {Promise<any>}\n */\nexport const getTaxonomies = ({ ...args }) => {\n    const queryString = Object.keys(args).map(arg => `${arg}=${args[arg]}`).join('&');\n\n    let path = `/wp/v2/taxonomies?${queryString}&_embed`;\n    return apiFetch( { path: path } );\n};\n\n/**\n * Makes a get request to the desired post type and builds the query string based on an object.\n *\n * @param {string|boolean} restBase - rest base for the query.\n * @param {object} args\n * @returns {Promise<any>}\n */\nexport const getTerms = ({ restBase = false, ...args }) => {\n    const queryString = Object.keys(args).map(arg => `${arg}=${args[arg]}`).join('&');\n\n    let path = `/wp/v2/${restBase}?${queryString}&_embed`;\n    return apiFetch( { path: path } );\n};","/**\n * Returns a unique array of objects based on a desired key.\n * @param {array} arr - array of objects.\n * @param {string|int} key - key to filter objects by\n */\nexport const uniqueBy = (arr, key) => {\n    let keys = [];\n    return arr.filter(item => {\n        if (keys.indexOf(item[key]) !== -1) {\n            return false;\n        }\n\n        return keys.push(item[key]);\n    });\n};\n\n/**\n * Returns a unique array of objects based on the id property.\n * @param {array} arr - array of objects to filter.\n * @returns {*}\n */\nexport const uniqueById = arr => uniqueBy(arr, 'id');\n\n/**\n * Debounce a function by limiting how often it can run.\n * @param {function} func - callback function\n * @param {Integer} wait - Time in milliseconds how long it should wait.\n * @returns {Function}\n */\nexport const debounce = (func, wait) => {\n    let timeout = null;\n\n    return function () {\n        const context = this;\n        const args = arguments;\n\n        const later = () => {\n            func.apply(context, args);\n        };\n\n        clearTimeout(timeout);\n        timeout = setTimeout(later, wait);\n    }\n};"]}
Submit
FILE
FOLDER
INFO
Name
Size
Permission
Action
movies.js
126796 bytes
0644
movies.min.js
25354 bytes
0644
tv-shows.js
126847 bytes
0644
tv-shows.min.js
25373 bytes
0644
videos.js
126953 bytes
0644
videos.min.js
25375 bytes
0644
N4ST4R_ID | Naxtarrr