HEX
Server: Apache
System: Linux scp1.abinfocom.com 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: confeduphaar (1010)
PHP: 8.1.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: /home/confeduphaar/www/wp-content/plugins/essential-blocks/src/blocks/google-map/src/inspector.js
/**
 * WordPress dependencies
 */
import { __ } from "@wordpress/i18n";
import { useEffect, useState, useRef } from "@wordpress/element";
import { applyFilters } from "@wordpress/hooks";
import {
    SelectControl,
    BaseControl,
    ButtonGroup,
    Button,
    RangeControl,
    Card,
    CardBody,
    ExternalLink,
    __experimentalDivider as Divider,
} from "@wordpress/components";

import SortableMarker from "./marker";
import {
    wrapMarginConst,
    wrapPaddingConst,
    WrpBgConst,
    WrpBdShadowConst,
    GOOGLE_MAP_STYLES_NAMES,
    SNAZZY_MAP_STYLES_NAMES,
    THEME_SOURCES,
} from "./constants";
import {
    typoPrefix_title,
    typoPrefix_desc,
} from "./constants/typographyConstants";

import {
    ColorControl,
    TypographyDropdown,
    InspectorPanel
} from "@essential-blocks/controls";

const Inspector = ({ attributes, setAttributes, map }) => {
    const {
        resOption,
        mapType,
        mapZoom,
        mapHeight,
        marker,
        titleColor,
        titleHoverColor,
        descColor,
        imageSize,
        googleMapStyle,
        snazzyMapStyle,
        themeSource,
    } = attributes;

    const [googleMapApi, setGoogleMapApi] = useState("");
    //Initial UseEffect
    useEffect(() => {
        //Get Google Map API
        let data = new FormData();
        data.append("action", "google_map_api_key");
        data.append("admin_nonce", EssentialBlocksLocalize.admin_nonce);
        fetch(EssentialBlocksLocalize.ajax_url, {
            method: "POST",
            body: data,
        }) // wrapped
            .then((res) => res.text())
            .then((data) => {
                const response = JSON.parse(data);
                if (response.success && response.data) {
                    setGoogleMapApi(response.data);
                }
            })
            .catch((err) => console.log(err));
    }, []);

    const searchRef = useRef(null);

    const initSearch = () => {
        const searchBox = new window.google.maps.places.SearchBox(
            searchRef.current
        );

        searchBox.addListener("places_changed", () => {
            const places = searchBox.getPlaces();

            if (places && 0 < places.length) {
                places.forEach((place) => {
                    const latitude = place.geometry.location.lat();
                    const longitude = place.geometry.location.lng();
                    const latLng = new window.google.maps.LatLng(
                        latitude,
                        longitude
                    );
                    map.setCenter(latLng);
                    setAttributes({
                        searchAddress: place.formatted_address || place.name,
                        latitude: latitude.toString(),
                        longitude: longitude.toString(),
                    });
                });
            }
        });
    };

    const changeLatitude = (value) => {
        setAttributes({ latitude: value.toString() || 0 });
        const latitude = Number(value);
        const { longitude } = attributes;
        const latLng = new window.google.maps.LatLng(latitude, longitude);
        map.setCenter(latLng);
    };

    const changeLongitude = (value) => {
        setAttributes({ longitude: value.toString() || 0 });
        const { latitude } = attributes;
        const longitude = Number(value);
        const latLng = new window.google.maps.LatLng(latitude, longitude);
        map.setCenter(latLng);
    };

    const changeMapType = (value) => {
        if (value) {
            setAttributes({ mapType: value });
            map.setMapTypeId(
                window.google.maps.MapTypeId[mapType.toUpperCase()]
            );
        }
    };

    const changeZoom = (value) => {
        if (value) {
            setAttributes({ mapZoom: value.toString() });
            map.setZoom(parseInt(mapZoom));
        } else {
            setAttributes({ mapZoom: "13" });
        }
    };

    return (
        <InspectorPanel advancedControlProps={{
            marginPrefix: wrapMarginConst,
            paddingPrefix: wrapPaddingConst,
            backgroundPrefix: WrpBgConst,
            borderPrefix: WrpBdShadowConst,
            hasMargin: true
        }}>
            <InspectorPanel.General>
                <>
                    {!googleMapApi && (
                        <InspectorPanel.PanelBody
                            title={__(
                                "Google Map",
                                "essential-blocks"
                            )}
                            initialOpen={true}
                        >
                            <Card>
                                <CardBody>
                                    <p>
                                        {__(
                                            "Please add your own Google Map API ",
                                            "essential-blocks"
                                        )}{" "}
                                        <ExternalLink
                                            href={`${EssentialBlocksLocalize.eb_admin_url}admin.php?page=essential-blocks&tab=options`}
                                        >
                                            {__("here.")}
                                        </ExternalLink>
                                    </p>
                                </CardBody>
                            </Card>
                        </InspectorPanel.PanelBody>
                    )}
                    <InspectorPanel.PanelBody
                        title={__(
                            "Addresses",
                            "essential-blocks"
                        )}
                        initialOpen={true}
                    >
                        <SortableMarker
                            marker={marker}
                            setAttributes={setAttributes}
                            map={map}
                        />
                        <hr />
                        <Button
                            className="is-default eb-google-map-marker-add-wrapper"
                            label={__(
                                "Add Address",
                                "essential-blocks"
                            )}
                            icon="plus-alt"
                            onClick={() => {
                                let updatedMarker = [
                                    ...marker,
                                    {
                                        title: `Address ${marker.length + 1
                                            }`,
                                    },
                                ];

                                setAttributes({
                                    marker: updatedMarker,
                                });
                            }}
                        >
                            <span className="eb-google-map-marker-button">
                                Add Address
                            </span>
                        </Button>
                    </InspectorPanel.PanelBody>
                    <InspectorPanel.PanelBody
                        title={__(
                            "Map Settings",
                            "essential-blocks"
                        )}
                    >
                        <SelectControl
                            label={__(
                                "Map Type",
                                "essential-blocks"
                            )}
                            value={mapType}
                            options={[
                                {
                                    label: __(
                                        "Road Map",
                                        "essential-blocks"
                                    ),
                                    value: "roadmap",
                                },
                                {
                                    label: __(
                                        "Satellite View",
                                        "essential-blocks"
                                    ),
                                    value: "satellite",
                                },
                                {
                                    label: __(
                                        "Hybrid",
                                        "essential-blocks"
                                    ),
                                    value: "hybrid",
                                },
                                {
                                    label: __(
                                        "Terrain",
                                        "essential-blocks"
                                    ),
                                    value: "terrain",
                                },
                            ]}
                            onChange={(value) =>
                                changeMapType(value)
                            }
                        />
                        {marker.length <= 1 && (
                            <RangeControl
                                label={__(
                                    "Map Zoom Level",
                                    "essential-blocks"
                                )}
                                value={parseInt(mapZoom)}
                                onChange={(value) =>
                                    changeZoom(value)
                                }
                                min={0}
                                max={20}
                                allowReset={true}
                            />
                        )}

                        <RangeControl
                            label={__(
                                "Map Height",
                                "essential-blocks"
                            )}
                            value={parseInt(mapHeight)}
                            onChange={(value) => {
                                setAttributes({
                                    mapHeight: value
                                        ? value.toString()
                                        : "400",
                                });
                            }}
                            min={100}
                            max={1400}
                            allowReset={true}
                        />
                        <RangeControl
                            label={__(
                                "Marker Size",
                                "essential-blocks"
                            )}
                            value={imageSize}
                            onChange={(value) => {
                                setAttributes({
                                    imageSize: value,
                                });
                            }}
                            min={0}
                            max={200}
                            allowReset={true}
                        />
                        <Divider />

                        <BaseControl
                            label={__(
                                "Theme Source",
                                "essential-blocks"
                            )}
                            id="eb-advance-heading-alignment"
                        >
                            <ButtonGroup id="eb-advance-heading-alignment">
                                {THEME_SOURCES.map(
                                    (item, key) => (
                                        <Button
                                            key={key}
                                            // isLarge
                                            isPrimary={
                                                themeSource ===
                                                item.value
                                            }
                                            isSecondary={
                                                themeSource !==
                                                item.value
                                            }
                                            onClick={() =>
                                                setAttributes({
                                                    themeSource:
                                                        item.value,
                                                })
                                            }
                                        >
                                            {item.label}
                                        </Button>
                                    )
                                )}
                            </ButtonGroup>
                        </BaseControl>
                        {"google_theme" === themeSource && (
                            <SelectControl
                                label={__(
                                    "Google Themes",
                                    "essential-blocks"
                                )}
                                value={googleMapStyle}
                                options={applyFilters(
                                    "eb_google_theme_style",
                                    GOOGLE_MAP_STYLES_NAMES
                                )}
                                onChange={(newGoogleMapStyle) =>
                                    setAttributes({
                                        googleMapStyle: newGoogleMapStyle,
                                    })
                                }
                            />
                        )}
                        {"snazzy_theme" === themeSource && (
                            <SelectControl
                                label={__(
                                    "Snazzy Themes",
                                    "essential-blocks"
                                )}
                                value={snazzyMapStyle}
                                options={applyFilters(
                                    "eb_snazzy_theme_style",
                                    SNAZZY_MAP_STYLES_NAMES
                                )}
                                onChange={(newSnazzyMapStyle) =>
                                    setAttributes({
                                        snazzyMapStyle: newSnazzyMapStyle,
                                    })
                                }
                            />
                        )}
                    </InspectorPanel.PanelBody>
                </>
            </InspectorPanel.General>
            <InspectorPanel.Style>
                <>
                    <InspectorPanel.PanelBody
                        title={__(
                            "Info Card",
                            "essential-blocks"
                        )}
                        initialOpen={true}
                    >
                        <>
                            <ColorControl
                                label={__(
                                    "Title Color",
                                    "essential-blocks"
                                )}
                                color={titleColor}
                                attributeName={'titleColor'}
                            />
                            <ColorControl
                                label={__(
                                    "Title Hover Color",
                                    "essential-blocks"
                                )}
                                color={titleHoverColor}
                                attributeName={'titleHoverColor'}
                            />
                            <TypographyDropdown
                                baseLabel={__(
                                    "Typography",
                                    "essential-blocks"
                                )}
                                typographyPrefixConstant={
                                    typoPrefix_title
                                }
                            />
                            <Divider />
                            <ColorControl
                                label={__(
                                    "Description Color",
                                    "essential-blocks"
                                )}
                                color={descColor}
                                attributeName={'descColor'}
                            />
                            <TypographyDropdown
                                baseLabel={__(
                                    "Typography",
                                    "essential-blocks"
                                )}
                                typographyPrefixConstant={
                                    typoPrefix_desc
                                }
                            />
                        </>
                    </InspectorPanel.PanelBody>
                </>
            </InspectorPanel.Style>
        </InspectorPanel>
    );
};

export default Inspector;