403Webshell
Server IP : 192.158.238.246  /  Your IP : 3.23.104.114
Web Server : LiteSpeed
System : Linux uniform.iwebfusion.net 4.18.0-553.27.1.lve.1.el8.x86_64 #1 SMP Wed Nov 20 15:58:00 UTC 2024 x86_64
User : jenniferflocom ( 1321)
PHP Version : 8.1.32
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /proc/7779/cwd/plugins/give/src/DonationForms/resources/app/utilities/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /proc/7779/cwd/plugins/give/src/DonationForms/resources/app/utilities/useDonationFormPubSub.ts
import {RefObject, useEffect} from 'react';
import {iframeRef} from '@givewp/form-builder/components/canvas/DesignPreview';
import {FormSettings} from '@givewp/form-builder/types';
import {FormColors, FormGoal, RequireAtLeastOne} from '@givewp/forms/types';

/**
 * Events used in design mode
 */
export const PREVIEW_EVENTS = {
    SETTINGS: 'preview:settings',
    GOAL: 'preview:goal',
    COLORS: 'preview:colors',
    CSS: 'preview:css',
    DESIGN_SETTINGS: 'preview:design-settings',
}

/**
 * Simple Publish/Subscribe system used for handling form state in preview mode
 *
 * @since 3.1.0
 */
export default function useDonationFormPubSub() {

    const events = {};

    useEffect(() => {
        addEventListener('message', eventListener, false);
        return () => removeEventListener('message', eventListener);
    }, []);

    const getMessage = (message: MessageEvent) => {
        // handle IframeResizer messages
        if (typeof message.data === 'string') {
            if (message.data.includes('[iFrameSizer]message:')) {
                return JSON.parse(message.data.replace('[iFrameSizer]message:', ''));
            }
        }

        return message.data
    }

    const eventListener = (message: MessageEvent) => {
        const {event, data} = getMessage(message);

        if (events[event]) {

            const filtered = {};
            // Allow only primitive values
            Object.entries(data).forEach(([key, value]) => {
                if (typeof value !== 'function' && typeof value !== 'object') {
                    filtered[key] = value;
                }
            });

            events[event].forEach((callback: (data: any) => void) => {
                callback(filtered);
            });
        }
    }

    const subscribe = (event: string, callback: Function) => {
        if (!events[event]) {
            events[event] = [];
        }

        events[event].push(callback);
    }

    const publish = (event: string, data: any, iframeRef: RefObject<any>) => {
        if (iframeRef.current?.sendMessage) {
            iframeRef.current.sendMessage({
                event,
                data
            });
        }
    }

    const publishSettings = (data: RequireAtLeastOne<FormSettings>) => {
        publish(PREVIEW_EVENTS.SETTINGS, data, iframeRef)
    }


    const publishDesignSettings = (data: RequireAtLeastOne<FormSettings>) => {
        publish(PREVIEW_EVENTS.DESIGN_SETTINGS, data, iframeRef)
    }

    const publishGoal = (data: RequireAtLeastOne<FormGoal>) => {
        publish(PREVIEW_EVENTS.GOAL, data, iframeRef)
    }

    const publishGoalType = (type: string) => {
        const isMoney = ['amount', 'amountFromSubscriptions'].includes(type);

        publish(PREVIEW_EVENTS.GOAL, {
            type,
            label: type,
            typeIsCount: !isMoney,
            typeIsMoney: isMoney,
        }, iframeRef)
    }

    const publishColors = (data: RequireAtLeastOne<FormColors>) => {
        publish(PREVIEW_EVENTS.COLORS, data, iframeRef)
    }

    const publishCss = (data: {customCss: string} ) => {
        publish(PREVIEW_EVENTS.CSS, data, iframeRef)
    }

    const subscribeToSettings = (callback: (data: FormSettings) => void) => {
        subscribe(PREVIEW_EVENTS.SETTINGS, callback)
    }

    const subscribeToDesignSettings = (callback: (data) => void) => {
        subscribe(PREVIEW_EVENTS.DESIGN_SETTINGS, callback)
    }

    const subscribeToGoal = (callback: (data: FormGoal) => void) => {
        subscribe(PREVIEW_EVENTS.GOAL, callback)
    }

    const subscribeToColors = (callback: (data: FormColors) => void) => {
        subscribe(PREVIEW_EVENTS.COLORS, callback)
    }

    const subscribeToCss = (callback: (data: {customCss: string}) => void) => {
        subscribe(PREVIEW_EVENTS.CSS, callback)
    }

    /**
     * Unsubscribe from event
     *
     * @param event
     */
    const unsubscribe = (event: string) => {
        if (events[event]) {
            delete events[event];
        }
    }

    /**
     * Unsubscribe from all event
     */
    const unsubscribeAll = () => {
        for (const key in PREVIEW_EVENTS) {
            delete events[key];
        }
    }

    return {
        unsubscribe,
        unsubscribeAll,
        publishGoal,
        publishGoalType,
        publishColors,
        publishCss,
        publishSettings,
        publishDesignSettings,
        subscribeToGoal,
        subscribeToColors,
        subscribeToSettings,
        subscribeToCss,
        subscribeToDesignSettings
    }
}

Youez - 2016 - github.com/yon3zu
LinuXploit