/home/tuzdhajd/tuzdayscloset.com/wp-content/plugins/brizy/public/editor-client/src/index.ts
import { authorisation } from "@/authorisation";
import { authors } from "@/authors";
import { getExportBlockUrl } from "@/block";
import { form } from "@/form";
import { shortcodeContent } from "@/shortcodeContent";
import { sidebars } from "@/sidebars";
import { terms } from "@/terms";
import get from "lodash/get";
import merge from "lodash/merge";
import set from "lodash/set";
import { doAiRequest } from "./aiText";
import { autoSave } from "./autoSave";
import { getCollectionItems } from "./collectionItems/getCollectionItems";
import { searchCollectionItems } from "./collectionItems/searchCollectionItems";
import { getCollectionTypesInfo } from "./collectionTypes/getCollectionTypesInfo";
import { loadCollectionTypes } from "./collectionTypes/loadCollectionTypes";
import { getConfig } from "./config";
import { addFile } from "./customFile/addFile";
import { customIcon } from "./customIcon";
import {
  defaultKits,
  defaultLayouts,
  defaultPopups,
  defaultStories
} from "./defaultTemplates";
import { placeholderData, placeholders } from "./dynamicContent";
import { getMenu } from "./Elements/Menu";
import { handler as posts } from "./Elements/Posts";
import { featuredImage } from "./featuredImage";
import { adobeFont, uploadedFonts } from "./fonts";
import { globalBlocks } from "./globalBlocks/blocks";
import { globalPopups } from "./globalBlocks/popups";
import { heartBeat } from "./heartBeat";
import { addMedia } from "./media/addMedia";
import { addMediaGallery } from "./media/addMediaGallery";
import { getMenus } from "./menu";
import { onChange } from "./onChange";
import { onStartLoad } from "./onStartLoad";
import { popupConditions } from "./popupConditions";
import { posts as postsAPI } from "./posts";
import { publish } from "./publish";
import { getRegeneratedGlobalStyles } from "./regeneratedGlobalStyles";
import { savedBlocks } from "./savedBlocks/savedBlocks";
import { savedLayouts } from "./savedBlocks/savedLayouts";
import { savedPopups } from "./savedBlocks/savedPopups";
import { screenshots } from "./screenshots";

const config = getConfig();

if (!config) {
  throw new Error("Invalid __BRZ_PLUGIN_ENV__");
}

const api = {
  authorisation,
  ...(config.api.openAIUrl ? { textAI: { handler: doAiRequest } } : {}),
  media: {
    addMedia,
    addMediaGallery,
    mediaResizeUrl: config.api.mediaResizeUrl
  },
  customFile: {
    addFile,
    fileUrl: config.api.fileUrl
  },
  customIcon: {
    ...customIcon,
    iconUrl: config.api.iconUrl
  },
  savedBlocks,
  savedPopups,
  savedLayouts,
  popupConditions,
  globalBlocks,
  globalPopups,
  defaultKits: defaultKits(config),
  defaultPopups: defaultPopups(config),
  defaultStories: defaultStories(config),
  defaultLayouts: defaultLayouts(config),
  collectionItems: {
    searchCollectionItems,
    getCollectionItems
  },
  collectionTypes: {
    loadCollectionTypes,
    getCollectionTypesInfo
  },
  screenshots: screenshots(),
  fonts: {
    adobeFont: adobeFont()
  },
  heartBeat: heartBeat(config),
  menu: {
    getMenus: getMenus()
  },
  featuredImage,
  shortcodeContent,
  authors,
  posts: postsAPI,
  terms,
  sidebars,
  block: {
    getExportBlockUrl
  }
};

if (window.__VISUAL_CONFIG__) {
  // API
  window.__VISUAL_CONFIG__.api = merge(window.__VISUAL_CONFIG__.api, api);

  // AutoSave
  window.__VISUAL_CONFIG__.onAutoSave = autoSave;

  //onStartLoad

  window.__VISUAL_CONFIG__.onStartLoad = onStartLoad(config);

  // OnChange
  window.__VISUAL_CONFIG__.onChange = onChange;

  // UI
  if (window.__VISUAL_CONFIG__.ui) {
    window.__VISUAL_CONFIG__.ui.publish = publish;
    set(
      window.__VISUAL_CONFIG__.ui,
      ["leftSidebar", "styles"],
      getRegeneratedGlobalStyles(config)
    );
  }

  // Elements
  if (window.__VISUAL_CONFIG__.elements) {
    set(window.__VISUAL_CONFIG__.elements, ["posts", "handler"], posts);
  } else {
    set(window.__VISUAL_CONFIG__, ["elements", "posts", "handler"], posts);
  }
  set(window.__VISUAL_CONFIG__, ["elements", "menu"], getMenu(config));
  set(
    window.__VISUAL_CONFIG__,
    ["elements", "menuSimple", "getPlaceholderData"],
    placeholderData
  );

  // Dynamic Content
  if (window.__VISUAL_CONFIG__.dynamicContent) {
    set(window.__VISUAL_CONFIG__.dynamicContent, ["handler"], placeholders);
    set(
      window.__VISUAL_CONFIG__.dynamicContent,
      ["getPlaceholderData"],
      placeholderData
    );
  }

  set(
    window.__VISUAL_CONFIG__,
    ["integrations", "fonts", "upload"],
    uploadedFonts
  );

  const existingForm = get(window.__VISUAL_CONFIG__, ["integrations", "form"]);
  const updatedForm = merge({}, existingForm, form);
  set(window.__VISUAL_CONFIG__, ["integrations", "form"], updatedForm);
}