HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux WebLive 5.15.0-79-generic #86-Ubuntu SMP Mon Jul 10 16:07:21 UTC 2023 x86_64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/html/wpmuhibbah/wp-content/plugins/give/src/DonationForms/resources/app/form/Section.tsx
import {withTemplateWrapper} from '@givewp/forms/app/templates';
import SectionNode from '@givewp/forms/app/fields/SectionNode';
import useVisibilityCondition from '@givewp/forms/app/hooks/useVisibilityCondition';
import {Field, isField, Section as SectionType} from '@givewp/forms/types';
import DonationFormErrorBoundary from '@givewp/forms/app/errors/boundaries/DonationFormErrorBoundary';
import {useEffect} from '@wordpress/element';

const formTemplates = window.givewp.form.templates;
const FormSectionTemplate = withTemplateWrapper(formTemplates.layouts.section, 'section');

export default function Section({section}: {section: SectionType}) {
    const showNode = useVisibilityCondition(section.visibilityConditions);
    const {unregister} = window.givewp.form.hooks.useFormContext();

    useEffect(() => {
        if (showNode) {
            return;
        }

        section.walkNodes((field: Field) => {
            unregister(field.name);
        }, isField);
    }, [showNode]);

    if (!showNode) {
        return null;
    }

    return (
        <FormSectionTemplate section={section}>
            {section.nodes.map((node) => (
                <DonationFormErrorBoundary key={node.name}>
                    <SectionNode node={node} />
                </DonationFormErrorBoundary>
            ))}
        </FormSectionTemplate>
    );
}