File "editor-v1-adapters.js"

Full Path: /home/fineflavourcocoa/public_html/wp-content/plugins/elementor/assets/js/packages/editor-v1-adapters/editor-v1-adapters.js
File size: 12.3 KB
MIME-type: text/plain
Charset: utf-8

/******/ (function() { // webpackBootstrap
/******/ 	"use strict";
/******/ 	var __webpack_modules__ = ({

/***/ "react":
/*!**************************!*\
  !*** external ["React"] ***!
  \**************************/
/***/ (function(module) {

module.exports = window["React"];

/***/ })

/******/ 	});
/************************************************************************/
/******/ 	// The module cache
/******/ 	var __webpack_module_cache__ = {};
/******/ 	
/******/ 	// The require function
/******/ 	function __webpack_require__(moduleId) {
/******/ 		// Check if module is in cache
/******/ 		var cachedModule = __webpack_module_cache__[moduleId];
/******/ 		if (cachedModule !== undefined) {
/******/ 			return cachedModule.exports;
/******/ 		}
/******/ 		// Create a new module (and put it into the cache)
/******/ 		var module = __webpack_module_cache__[moduleId] = {
/******/ 			// no module.id needed
/******/ 			// no module.loaded needed
/******/ 			exports: {}
/******/ 		};
/******/ 	
/******/ 		// Execute the module function
/******/ 		__webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/ 	
/******/ 		// Return the exports of the module
/******/ 		return module.exports;
/******/ 	}
/******/ 	
/************************************************************************/
/******/ 	/* webpack/runtime/define property getters */
/******/ 	!function() {
/******/ 		// define getter functions for harmony exports
/******/ 		__webpack_require__.d = function(exports, definition) {
/******/ 			for(var key in definition) {
/******/ 				if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ 					Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ 				}
/******/ 			}
/******/ 		};
/******/ 	}();
/******/ 	
/******/ 	/* webpack/runtime/hasOwnProperty shorthand */
/******/ 	!function() {
/******/ 		__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }
/******/ 	}();
/******/ 	
/******/ 	/* webpack/runtime/make namespace object */
/******/ 	!function() {
/******/ 		// define __esModule on exports
/******/ 		__webpack_require__.r = function(exports) {
/******/ 			if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ 				Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ 			}
/******/ 			Object.defineProperty(exports, '__esModule', { value: true });
/******/ 		};
/******/ 	}();
/******/ 	
/************************************************************************/
var __webpack_exports__ = {};
// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
!function() {
/*!*******************************************************************!*\
  !*** ./node_modules/@elementor/editor-v1-adapters/dist/index.mjs ***!
  \*******************************************************************/
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */   __privateDispatchReadyEvent: function() { return /* binding */ dispatchReadyEvent; },
/* harmony export */   __privateFlushListeners: function() { return /* binding */ flushListeners; },
/* harmony export */   __privateGetCurrentEditMode: function() { return /* binding */ getCurrentEditMode; },
/* harmony export */   __privateIsRouteActive: function() { return /* binding */ isRouteActive; },
/* harmony export */   __privateListenTo: function() { return /* binding */ listenTo; },
/* harmony export */   __privateOpenRoute: function() { return /* binding */ openRoute; },
/* harmony export */   __privateRegisterRoute: function() { return /* binding */ registerRoute; },
/* harmony export */   __privateRunCommand: function() { return /* binding */ runCommand; },
/* harmony export */   __privateSetReady: function() { return /* binding */ setReady; },
/* harmony export */   __privateUseIsPreviewMode: function() { return /* binding */ useIsPreviewMode; },
/* harmony export */   __privateUseIsRouteActive: function() { return /* binding */ useIsRouteActive; },
/* harmony export */   __privateUseListenTo: function() { return /* binding */ useListenTo; },
/* harmony export */   __privateUseRouteStatus: function() { return /* binding */ useRouteStatus; },
/* harmony export */   commandEndEvent: function() { return /* binding */ commandEndEvent; },
/* harmony export */   commandStartEvent: function() { return /* binding */ commandStartEvent; },
/* harmony export */   editModeChangeEvent: function() { return /* binding */ editModeChangeEvent; },
/* harmony export */   routeCloseEvent: function() { return /* binding */ routeCloseEvent; },
/* harmony export */   routeOpenEvent: function() { return /* binding */ routeOpenEvent; },
/* harmony export */   v1ReadyEvent: function() { return /* binding */ v1ReadyEvent; },
/* harmony export */   windowEvent: function() { return /* binding */ windowEvent; }
/* harmony export */ });
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react");
// src/dispatchers/utils.ts
function isJQueryDeferred(value) {
  return !!value && "object" === typeof value && Object.hasOwn(value, "promise") && Object.hasOwn(value, "then") && Object.hasOwn(value, "fail");
}
function promisifyJQueryDeferred(deferred) {
  return new Promise((resolve, reject) => {
    deferred.then(resolve, reject);
  });
}

// src/dispatchers/dispatchers.ts
function runCommand(command, args) {
  const extendedWindow = window;
  if (!extendedWindow.$e?.run) {
    return Promise.reject("`$e.run()` is not available");
  }
  const result = extendedWindow.$e.run(command, args);
  if (result instanceof Promise) {
    return result;
  }
  if (isJQueryDeferred(result)) {
    return promisifyJQueryDeferred(result);
  }
  return Promise.resolve(result);
}
function openRoute(route) {
  const extendedWindow = window;
  if (!extendedWindow.$e?.route) {
    return Promise.reject("`$e.route()` is not available");
  }
  try {
    return Promise.resolve(
      extendedWindow.$e.route(route)
    );
  } catch (e) {
    return Promise.reject(e);
  }
}
function registerRoute(route) {
  const extendedWindow = window;
  if (!extendedWindow.$e?.routes?.register) {
    return Promise.reject("`$e.routes.register()` is not available");
  }
  const routeParts = route.split("/");
  if (routeParts.length < 2) {
    return Promise.reject(`\`${route}\` is an invalid route`);
  }
  const componentRoute = routeParts.pop();
  const component = routeParts.join("/");
  try {
    return Promise.resolve(
      extendedWindow.$e.routes.register(component, componentRoute, () => null)
    );
  } catch (e) {
    return Promise.reject(e);
  }
}

// src/hooks/use-listen-to.ts


// src/listeners/event-creators.ts
var commandStartEvent = (command) => {
  return {
    type: "command",
    name: command,
    state: "before"
  };
};
var commandEndEvent = (command) => {
  return {
    type: "command",
    name: command,
    state: "after"
  };
};
var routeOpenEvent = (route) => {
  return {
    type: "route",
    name: route,
    state: "open"
  };
};
var routeCloseEvent = (route) => {
  return {
    type: "route",
    name: route,
    state: "close"
  };
};
var windowEvent = (event) => {
  return {
    type: "window-event",
    name: event
  };
};
var v1ReadyEvent = () => {
  return windowEvent("elementor/initialized");
};
var editModeChangeEvent = () => {
  return windowEvent("elementor/edit-mode/change");
};

// src/listeners/is-ready.ts
var ready = false;
function isReady() {
  return ready;
}
function setReady(value) {
  ready = value;
}

// src/listeners/utils.ts
function dispatchReadyEvent() {
  return getV1LoadingPromise().then(() => {
    setReady(true);
    window.dispatchEvent(new CustomEvent("elementor/initialized"));
  });
}
function getV1LoadingPromise() {
  const v1LoadingPromise = window.__elementorEditorV1LoadingPromise;
  if (!v1LoadingPromise) {
    return Promise.reject("Elementor Editor V1 is not loaded");
  }
  return v1LoadingPromise;
}
function normalizeEvent(e) {
  if (e instanceof CustomEvent && e.detail?.command) {
    return {
      type: "command",
      command: e.detail.command,
      args: e.detail.args,
      originalEvent: e
    };
  }
  if (e instanceof CustomEvent && e.detail?.route) {
    return {
      type: "route",
      route: e.detail.route,
      originalEvent: e
    };
  }
  return {
    type: "window-event",
    event: e.type,
    originalEvent: e
  };
}

// src/listeners/listeners.ts
var callbacksByEvent = /* @__PURE__ */ new Map();
var abortController = new AbortController();
function listenTo(eventDescriptors, callback) {
  if (!Array.isArray(eventDescriptors)) {
    eventDescriptors = [eventDescriptors];
  }
  const cleanups = eventDescriptors.map((event) => {
    const { type, name } = event;
    switch (type) {
      case "command":
        return registerCommandListener(name, event.state, callback);
      case "route":
        return registerRouteListener(name, event.state, callback);
      case "window-event":
        return registerWindowEventListener(name, callback);
    }
  });
  return () => {
    cleanups.forEach((cleanup) => cleanup());
  };
}
function flushListeners() {
  abortController.abort();
  callbacksByEvent.clear();
  setReady(false);
  abortController = new AbortController();
}
function registerCommandListener(command, state, callback) {
  return registerWindowEventListener(`elementor/commands/run/${state}`, (e) => {
    const shouldRunCallback = e.type === "command" && e.command === command;
    if (shouldRunCallback) {
      callback(e);
    }
  });
}
function registerRouteListener(route, state, callback) {
  return registerWindowEventListener(`elementor/routes/${state}`, (e) => {
    const shouldRunCallback = e.type === "route" && e.route.startsWith(route);
    if (shouldRunCallback) {
      callback(e);
    }
  });
}
function registerWindowEventListener(event, callback) {
  const isFirstListener = !callbacksByEvent.has(event);
  if (isFirstListener) {
    callbacksByEvent.set(event, []);
    addListener(event);
  }
  callbacksByEvent.get(event)?.push(callback);
  return () => {
    const callbacks = callbacksByEvent.get(event);
    if (!callbacks?.length) {
      return;
    }
    const filtered = callbacks.filter((cb) => cb !== callback);
    callbacksByEvent.set(event, filtered);
  };
}
function addListener(event) {
  window.addEventListener(
    event,
    makeEventHandler(event),
    { signal: abortController.signal }
  );
}
function makeEventHandler(event) {
  return (e) => {
    if (!isReady()) {
      return;
    }
    const normalizedEvent = normalizeEvent(e);
    callbacksByEvent.get(event)?.forEach((callback) => {
      callback(normalizedEvent);
    });
  };
}

// src/hooks/use-listen-to.ts
function useListenTo(event, getSnapshot, deps = []) {
  const [snapshot, setSnapshot] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(() => getSnapshot());
  (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {
    const updateState = () => setSnapshot(getSnapshot());
    updateState();
    return listenTo(event, updateState);
  }, deps);
  return snapshot;
}

// src/readers/index.ts
function isRouteActive(route) {
  const extendedWindow = window;
  return !!extendedWindow.$e?.routes?.isPartOf(route);
}
function getCurrentEditMode() {
  const extendedWindow = window;
  return extendedWindow.elementor?.channels?.dataEditMode?.request?.("activeMode");
}

// src/hooks/use-is-preview-mode.ts
function useIsPreviewMode() {
  return useListenTo(
    editModeChangeEvent(),
    () => getCurrentEditMode() === "preview"
  );
}

// src/hooks/use-is-route-active.ts
function useIsRouteActive(route) {
  return useListenTo(
    [
      routeOpenEvent(route),
      routeCloseEvent(route)
    ],
    () => isRouteActive(route),
    [route]
  );
}

// src/hooks/use-route-status.ts
function useRouteStatus(route, {
  blockOnKitRoutes = true,
  blockOnPreviewMode = true
} = {}) {
  const isRouteActive2 = useIsRouteActive(route);
  const isKitRouteActive = useIsRouteActive("panel/global");
  const isPreviewMode = useIsPreviewMode();
  const isActive = isRouteActive2 && !(blockOnPreviewMode && isPreviewMode);
  const isBlocked = blockOnPreviewMode && isPreviewMode || blockOnKitRoutes && isKitRouteActive;
  return {
    isActive,
    isBlocked
  };
}

//# sourceMappingURL=index.mjs.map
}();
(window.elementorV2 = window.elementorV2 || {}).editorV1Adapters = __webpack_exports__;
/******/ })()
;