SugarClub will be undergoing planned maintenance from 08 January 2025 at 3:00 PM PDT until 08 January 2025 at 4:00 PM PDT.
The site will be inaccessible during this time. We are sorry for any inconvenience.

Is there a way to prevent the phone_office field from being populated from the account into the contact?

Hi everyone,

I'm currently seeking a way to prevent the contact's phone_office field from being populated with the account's phone_office when establishing a relationship between them.

Here's the code I've implemented:

```php

$dictionary['Contact']['fields']['account_name']['populate_list'] = array(
'billing_address_street' => 'primary_address_street',
'billing_address_city' => 'primary_address_city',
'billing_address_state' => 'primary_address_state',
'billing_address_postalcode' => 'primary_address_postalcode',
'billing_address_country' => 'primary_address_country',
);

```

I added this code to custom/Extension/modules/Contacts/Ext/Vardefs/sugarfield_account_name.php.

However, upon creating the relationship, I encountered an error, and the contact was marked as deleted=1. I also attempted making the change within modules/Accounts/vardefs.php, but encountered the same issue. I'm uncertain if there's something additional that needs to be done within the Accounts module.

Any advice or insights would be greatly appreciated. Thank you!

Parents
  • You did exactly the right thing.

    I copied your code and it worked fine in my test environment.

    Did you call a Quick Repair and Rebuild after the change?

    Please check all touched files for any wrong characters.

    In cache/modules/Contacts/Contactvardefs.php you should find the changed field definition for account_name:

        'account_name' => 
        array (
          'name' => 'account_name',
          'rname' => 'name',
          'id_name' => 'account_id',
          'vname' => 'LBL_ACCOUNT_NAME',
          'join_name' => 'accounts',
          'type' => 'relate',
          'link' => 'accounts',
          'table' => 'accounts',
          'isnull' => 'true',
          'module' => 'Accounts',
          'dbType' => 'varchar',
          'len' => 255,
          'source' => 'non-db',
          'unified_search' => true,
          'populate_list' => 
          array (
            'billing_address_street' => 'primary_address_street',
            'billing_address_city' => 'primary_address_city',
            'billing_address_state' => 'primary_address_state',
            'billing_address_postalcode' => 'primary_address_postalcode',
            'billing_address_country' => 'primary_address_country',
          ),
          'populate_confirm_label' => 'TPL_OVERWRITE_POPULATED_DATA_CONFIRM_WITH_MODULE_SINGULAR',
          'importable' => 'true',
          'exportable' => true,
          'export_link_type' => 'one',
          'audited' => true,
          'massupdate' => true,
          'hidemassupdate' => false,
          'help' => 'modified field',
          'duplicate_merge' => 'enabled',
          'duplicate_merge_dom_value' => '1',
          'merge_filter' => 'disabled',
          'reportable' => false,
          'calculated' => false,
        ),

    If you want to be sure that the polulate_list is added at the end of the definition you can write it to custom/Extension/modules/Contacts/Ext/Vardefs/_override_account_name.php and try a Quick Repair and Rebuild again.

Reply
  • You did exactly the right thing.

    I copied your code and it worked fine in my test environment.

    Did you call a Quick Repair and Rebuild after the change?

    Please check all touched files for any wrong characters.

    In cache/modules/Contacts/Contactvardefs.php you should find the changed field definition for account_name:

        'account_name' => 
        array (
          'name' => 'account_name',
          'rname' => 'name',
          'id_name' => 'account_id',
          'vname' => 'LBL_ACCOUNT_NAME',
          'join_name' => 'accounts',
          'type' => 'relate',
          'link' => 'accounts',
          'table' => 'accounts',
          'isnull' => 'true',
          'module' => 'Accounts',
          'dbType' => 'varchar',
          'len' => 255,
          'source' => 'non-db',
          'unified_search' => true,
          'populate_list' => 
          array (
            'billing_address_street' => 'primary_address_street',
            'billing_address_city' => 'primary_address_city',
            'billing_address_state' => 'primary_address_state',
            'billing_address_postalcode' => 'primary_address_postalcode',
            'billing_address_country' => 'primary_address_country',
          ),
          'populate_confirm_label' => 'TPL_OVERWRITE_POPULATED_DATA_CONFIRM_WITH_MODULE_SINGULAR',
          'importable' => 'true',
          'exportable' => true,
          'export_link_type' => 'one',
          'audited' => true,
          'massupdate' => true,
          'hidemassupdate' => false,
          'help' => 'modified field',
          'duplicate_merge' => 'enabled',
          'duplicate_merge_dom_value' => '1',
          'merge_filter' => 'disabled',
          'reportable' => false,
          'calculated' => false,
        ),

    If you want to be sure that the polulate_list is added at the end of the definition you can write it to custom/Extension/modules/Contacts/Ext/Vardefs/_override_account_name.php and try a Quick Repair and Rebuild again.

Children
No Data