HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux spn-python 5.15.0-89-generic #99-Ubuntu SMP Mon Oct 30 20:42:41 UTC 2023 x86_64
User: arjun (1000)
PHP: 8.1.2-1ubuntu2.20
Disabled: NONE
Upload Files
File: /var/www/html/bwcdev/wp-content/plugins/contact-widgets/includes/blocks/contact/js/contact-block.js
import contactBlockIcons from './block-icons';
import BlockOrderControl from './block-order-control';

/**
 * Internal block libraries
 */
const { __ } = wp.i18n;

const {
    registerBlockType
} = wp.blocks;

const {
  BlockControls,
  InspectorControls,
  AlignmentToolbar,
  RichText
} = wp.editor;

const {
    Toolbar,
    Button,
    Tooltip,
    PanelBody,
    PanelRow,
    FormToggle,
    TextControl
} = wp.components;

/**
 * Register block
 */
export default registerBlockType( 'contact-widgets/contact-block', {
  title: __( 'Contact Details', 'contact-widgets' ),
  description: __( 'Display contact details on your site.', 'contact-widgets' ),
  category: 'widgets',
  icon: 'email-alt',
  keywords: [
    __( 'Email', 'contact-widgets' ),
    __( 'Phone', 'contact-widgets' ),
    __( 'Map', 'contact-widgets' ),
  ],
  attributes: {
    fields: {
      type: 'array',
      selector: '.fields',
      default: [
        {
          label: __( 'Title', 'contact-widgets' ),
        },
        {
          label: __( 'Email', 'contact-widgets' ),
        },
        {
          label: __( 'Phone', 'contact-widgets' ),
        },
        {
          label: __( 'Fax', 'contact-widgets' ),
        },
        {
          label: __( 'Address', 'contact-widgets' ),
        },
      ]
    },
    title: {
      type: 'string',
      source: 'text',
      selector: '.contact-title',
    },
    email: {
      type: 'string',
      source: 'text',
      selector: '.contact-email',
    },
    phone: {
      type: 'string',
      source: 'text',
      selector: '.contact-phone',
    },
    fax: {
      type: 'string',
      source: 'text',
      selector: '.contact-fax',
    },
    address: {
      type: 'array',
      source: 'children',
      selector: '.contact-address',
    },
    displayLabels: {
      type: 'boolean',
      default: true,
    },
    displayMapOfAddress: {
      type: 'boolean',
      default: true,
    },
  },
  getEditWrapperProps( attributes ) {
    const { blockAlignment } = attributes;
    if ( 'left' === blockAlignment || 'right' === blockAlignment || 'full' === blockAlignment ) {
      return { 'data-align': blockAlignment };
    }
  },
  edit: props => {

    const { attributes: { textAlignment, blockAlignment, fields, title, email, phone, fax, address, displayLabels, displayMapOfAddress }, isSelected, className, setAttributes } = props;
    const toggleDisplayLabels = () => setAttributes( { displayLabels: ! displayLabels } );
    const toggleDisplayMapOfAddress = () => setAttributes( { displayMapOfAddress: ! displayMapOfAddress } );

    return [

      // Inspector Controls
      <InspectorControls key="contact-block-inspector-controls">
        <PanelBody
          title={ __( 'Contact Details Controls', 'contact-widgets' ) }
        >
          <PanelRow>
            <label htmlFor="display-labels-toggle" >
              { __( 'Display Labels', 'contact-widgets' ) }
            </label>
            <FormToggle
              id="display-labels-toggle"
              label={ __( 'Display Labels', 'contact-widgets' ) }
              checked={ displayLabels }
              onChange={ toggleDisplayLabels }
            />
          </PanelRow>
          <PanelRow>
            <label htmlFor="display-map-of-address-toggle">
              { __( 'Display Map of Address', 'contact-widgets' ) }
            </label>
            <FormToggle
              id="display-map-of-address-toggle"
              label={ __( 'Display Map of Address', 'contact-widgets' ) }
              checked={ displayMapOfAddress }
              onChange={ toggleDisplayMapOfAddress }
            />
          </PanelRow>
          <PanelRow>
            <BlockOrderControl { ...{ setAttributes, ...props } } />
          </PanelRow>
        </PanelBody>
      </InspectorControls>,

      // Custom Toolbar
      <BlockControls key="contact-block-controls">
        <AlignmentToolbar
          value={ textAlignment }
          onChange={ ( textAlignment ) => props.setAttributes( { textAlignment } ) }
        />
        <Toolbar>
          <Tooltip text={ __( 'Display Labels', 'contact-widgets' )  }>
            <Button onClick={ toggleDisplayLabels }>
              {contactBlockIcons.label}
            </Button>
          </Tooltip>
        </Toolbar>
        <Toolbar>
          <Tooltip text={ __( 'Display Map of Address', 'contact-widgets' )  }>
            <Button onClick={ toggleDisplayMapOfAddress }>
              {contactBlockIcons.map}
            </Button>
          </Tooltip>
        </Toolbar>
      </BlockControls>,

      // Admin Block Markup
      <div
        className={ className }
        key={ className }
      >
        { renderFields( props.setAttributes, isSelected, fields, displayLabels, displayMapOfAddress, { 'title': title, 'email': email, 'phone': phone, 'fax': fax, 'address': address } ) }
      </div>
    ];
  },

  save: props => {

    const { attributes: { textAlignment, blockAlignment, fields, title, email, phone, fax, address, displayLabels, displayMapOfAddress }, className } = props;

    return (
      <div
      className={ className }
      key={ className }
      >
        { renderFields( props.setAttributes, false, fields, displayLabels, displayMapOfAddress, { 'title': title, 'email': email, 'phone': phone, 'fax': fax, 'address': address } ) }
      </div>
    );
  },
} );

/**
 * Render the contact widget fields
 *
 * @param  {array}    setAttributes       Block properties
 * @param  {boolean}  isSelected          Wheter or not this field is selected
 * @param  {array}    fields              Contact widget fields
 * @param  {boolean}  displayLabels       Whether or not to display the field labels
 * @param  {boolean}  displayMapOfAddress Whether or not to display the map
 * @param  {array}    values              Current form values
 */
function renderFields( setAttributes, isSelected, fields, displayLabels, displayMapOfAddress, values ) {

  var mapAddress = setupMapAddress( values.address );
  const labelClass = displayLabels ? 'has-label' : 'no-label';
  const mapClass = displayMapOfAddress ? 'has-map' : labelClass;

  var fieldMarkup = fields.map( function( field ) {

    switch( field.label ) {

      case 'Title':

        if ( ! isSelected && ! values.title ) {

          return;

        }

        return <li key={ field.label } className={ labelClass }>
          { isSelected ? (
            <div>
              <strong>{ field.label }</strong>
              <TextControl
                name={ field.label.toLowerCase() }
                placeholder={ field.label }
                value={ values.title }
                onChange={ title => setAttributes( { title } ) }
              />
            </div>
          ) : (
            <h4 className="contact-title">{ values.title }</h4>
          ) }
        </li>;

      case 'Email':

        if ( ! isSelected && ! values.email ) {

          return;

        }

        return <li key={ field.label } className={ labelClass }>
          { isSelected ? (
            <div>
              <strong>{ field.label }</strong>
              <TextControl
                name={ field.label.toLowerCase() }
                placeholder={ field.label }
                value={ values.email }
                onChange={ email => setAttributes( { email } ) }
              />
            </div>
          ) : (
            <div>
              { displayLabels && values.email && (
                <strong>{ field.label }<br /></strong>
              ) }
              <div className="contact-email"><a href={ "mailto:" + values.email }>{ values.email }</a></div>
            </div>
        ) }
        </li>;

      case 'Phone':

        if ( ! isSelected && ! values.phone ) {

          return;

        }

        return <li key={ field.label } className={ labelClass }>
          { isSelected ? (
            <div>
              <strong>{ field.label }</strong>
              <TextControl
                name={ field.label.toLowerCase() }
                placeholder={ field.label }
                value={ values.phone }
                onChange={ phone => setAttributes( { phone } ) }
              />
            </div>
          ) : (
            <div>
              { displayLabels && values.phone && (
                <strong>{ field.label }<br /></strong>
              ) }
              <div className="contact-phone">{ values.phone }</div>
            </div>
          ) }
        </li>;

      case 'Fax':

        if ( ! isSelected && ! values.fax ) {

          return;

        }

        return <li key={ field.label } className={ labelClass }>
          { isSelected ? (
            <div>
              <strong>{ field.label }</strong>
              <TextControl
                name={ field.label.toLowerCase() }
                placeholder={ field.label }
                value={ values.fax }
                onChange={ fax => setAttributes( { fax } ) }
              />
            </div>
          ) : (
            <div>
              { displayLabels && values.fax && (
                <strong>{ field.label }<br /></strong>
              ) }
              <div className="contact-fax">{ values.fax }</div>
            </div>
          ) }
        </li>;

      case 'Address':

        if ( ! isSelected && ( Object.keys( values.address ).length == 0 || values.address[0].trim() == '' )  ) {

          return;

        }

        return <li key={ field.label } className={ labelClass }>
          { isSelected ? (
            <div>
              <strong>{ field.label }</strong>
              <RichText
                name={ field.label.toLowerCase() }
                placeholder={ field.label }
                value={ values.address }
                onChange={ address => setAttributes( { address } ) }
              />
            </div>
          ) : (
            <div>
              { displayLabels && ( Object.keys( values.address ).length > 0 ) && (
                <strong>{ field.label }<br /></strong>
              ) }
              <div className="contact-address"><RichText.Content value={ values.address }/></div>
              { displayMapOfAddress && ( Object.keys( values.address ).length > 0 ) && (
                <div className="has-map">
                  <iframe
                    frameBorder="0"
                    style={{ width: '100%', minHeight: '205px' }}
                    src={ "https://www.google.com/maps?q=" + mapAddress + "&output=embed&hl=%s&z=14" }
                  />
                </div>
              ) }
            </div>
          ) }
        </li>;

    }

  } );

  return <ul className="fields">{ fieldMarkup }</ul>;

}

/**
 * Format the mapAddress array value into a usable string
 *
 * @param  {array} address  Block address value
 *
 * @return {string}         Formatted address
 */
function setupMapAddress( address ) {

  if ( ! address.length ) {

    return;

  }

  var mapAddress = '';

  for ( var i = 0; i < address.length; i++ ) {

    if ( typeof address[ i ] !== 'string' ) {

      mapAddress += ' ';

      continue;

    }

    mapAddress += address[ i ];

  }

  return encodeURIComponent( mapAddress );

}