CRM_Utils_Array::value('display_name', $fields),
'contact.individual_prefix' => CRM_Utils_Array::value('individual_prefix', $fields),
'contact.formal_title' => CRM_Utils_Array::value('formal_title', $fields),
'contact.first_name' => CRM_Utils_Array::value('first_name', $fields),
'contact.middle_name' => CRM_Utils_Array::value('middle_name', $fields),
'contact.last_name' => CRM_Utils_Array::value('last_name', $fields),
'contact.individual_suffix' => CRM_Utils_Array::value('individual_suffix', $fields),
'contact.address_name' => CRM_Utils_Array::value('address_name', $fields),
'contact.street_address' => CRM_Utils_Array::value('street_address', $fields),
'contact.supplemental_address_1' => CRM_Utils_Array::value('supplemental_address_1', $fields),
'contact.supplemental_address_2' => CRM_Utils_Array::value('supplemental_address_2', $fields),
'contact.city' => CRM_Utils_Array::value('city', $fields),
'contact.state_province_name' => CRM_Utils_Array::value('state_province_name', $fields),
'contact.county' => CRM_Utils_Array::value('county', $fields),
'contact.state_province' => CRM_Utils_Array::value('state_province', $fields),
'contact.postal_code' => $fullPostalCode,
'contact.country' => CRM_Utils_Array::value('country', $fields),
'contact.world_region' => CRM_Utils_Array::value('world_region', $fields),
'contact.geo_code_1' => CRM_Utils_Array::value('geo_code_1', $fields),
'contact.geo_code_2' => CRM_Utils_Array::value('geo_code_2', $fields),
'contact.current_employer' => CRM_Utils_Array::value('current_employer', $fields),
'contact.nick_name' => CRM_Utils_Array::value('nick_name', $fields),
'contact.email' => CRM_Utils_Array::value('email', $fields),
'contact.im' => CRM_Utils_Array::value('im', $fields),
'contact.do_not_email' => CRM_Utils_Array::value('do_not_email', $fields),
'contact.do_not_phone' => CRM_Utils_Array::value('do_not_phone', $fields),
'contact.do_not_mail' => CRM_Utils_Array::value('do_not_mail', $fields),
'contact.do_not_sms' => CRM_Utils_Array::value('do_not_sms', $fields),
'contact.do_not_trade' => CRM_Utils_Array::value('do_not_trade', $fields),
'contact.job_title' => CRM_Utils_Array::value('job_title', $fields),
'contact.birth_date' => CRM_Utils_Array::value('birth_date', $fields),
'contact.gender' => CRM_Utils_Array::value('gender', $fields),
'contact.is_opt_out' => CRM_Utils_Array::value('is_opt_out', $fields),
'contact.home_URL' => CRM_Utils_Array::value('home_URL', $fields),
'contact.preferred_mail_format' => CRM_Utils_Array::value('preferred_mail_format', $fields),
'contact.phone' => CRM_Utils_Array::value('phone', $fields),
'contact.home_URL' => CRM_Utils_Array::value('home_URL', $fields),
'contact.contact_source' => CRM_Utils_Array::value('contact_source', $fields),
'contact.external_identifier' => CRM_Utils_Array::value('external_identifier', $fields),
'contact.contact_id' => CRM_Utils_Array::value('id', $fields),
'contact.household_name' => CRM_Utils_Array::value('display_name', $fields),
'contact.organization_name' => CRM_Utils_Array::value('display_name', $fields),
'contact.legal_name' => CRM_Utils_Array::value('legal_name', $fields),
'contact.preferred_communication_method' => CRM_Utils_Array::value('preferred_communication_method', $fields),
'contact.communication_style' => CRM_Utils_Array::value('communication_style', $fields),
'contact.addressee' => CRM_Utils_Array::value('addressee_display', $fields),
'contact.email_greeting' => CRM_Utils_Array::value('email_greeting_display', $fields),
'contact.postal_greeting' => CRM_Utils_Array::value('postal_greeting_display', $fields),
);
}
else {
$replacements = array(
'contact.address_name' => "" . $fields['address_name'] . "",
'contact.street_address' => "" . $fields['street_address'] . "",
'contact.supplemental_address_1' => "" . $fields['supplemental_address_1'] . "",
'contact.supplemental_address_2' => $fields['supplemental_address_2'],
'contact.city' => "" . $fields['city'] . "",
'contact.state_province_name' => "" . $fields['state_province_name'] . "",
'contact.county' => "" . $fields['county'],
'contact.state_province' => "" . $fields['state_province'] . "",
'contact.postal_code' => "" . $fullPostalCode . "",
'contact.country' => "" . $fields['country'] . "",
'contact.world_region' => "" . $fields['world_region'] . "",
);
// erase all empty ones, so we dont get blank lines
foreach (array_keys($replacements) as $key) {
$exactKey = substr($key, 0, 8) == 'contact.' ? substr($key, 8) : $key;
if ($key != 'contact.postal_code' &&
CRM_Utils_Array::value($exactKey, $fields) == NULL
) {
$replacements[$key] = '';
}
}
if (empty($fullPostalCode)) {
$replacements['contact.postal_code'] = '';
}
}
// replacements in case of Custom Token
if (stristr($formatted, 'custom_')) {
$customToken = array_keys($fields);
foreach ($customToken as $value) {
if (substr($value, 0, 7) == 'custom_') {
$replacements["contact.{$value}"] = $fields["{$value}"];
}
}
}
// also sub all token fields
if ($tokenFields) {
foreach ($tokenFields as $token) {
$replacements["{$token}"] = CRM_Utils_Array::value("{$token}", $fields);
}
}
// for every token, replace {fooTOKENbar} with fooVALUEbar if
// the value is not empty, otherwise drop the whole {fooTOKENbar}
foreach ($replacements as $token => $value) {
if ($value && is_string($value) || is_numeric($value)) {
$formatted = preg_replace("/{([^{}]*)\b{$token}\b([^{}]*)}/u", "\${1}{$value}\${2}", $formatted);
}
else {
$formatted = preg_replace("/{[^{}]*\b{$token}\b[^{}]*}/u", '', $formatted);
}
}
// drop any {...} constructs from lines' ends
if (!$microformat) {
$formatted = "\n$formatted\n";
}
else {
if ($microformat == 1) {
$formatted = "\n\n$formatted
\n";
}
else {
$formatted = "\n$formatted
\n";
}
}
$formatted = preg_replace('/\n{[^{}]*}/u', "\n", $formatted);
$formatted = preg_replace('/{[^{}]*}\n/u', "\n", $formatted);
// if there are any 'sibling' {...} constructs, replace them with the
// contents of the first one; for example, when there's no state_province:
// 1. {city}{, }{state_province}{ }{postal_code}
// 2. San Francisco{, }{ }12345
// 3. San Francisco, 12345
$formatted = preg_replace('/{([^{}]*)}({[^{}]*})+/u', '\1', $formatted);
// drop any remaining curly braces leaving their contents
$formatted = str_replace(array('{', '}'), '', $formatted);
// drop any empty lines left after the replacements
$formatted = preg_replace('/^[ \t]*[\r\n]+/m', '', $formatted);
if (!$microformat) {
$finalFormatted = $formatted;
}
else {
// remove \n from each line and only add at the end
// this hack solves formatting issue, when we convert nl2br
$lines = array();
$count = 1;
$finalFormatted = NULL;
$formattedArray = explode("\n", $formatted);
$formattedArray = array_filter($formattedArray);
foreach ($formattedArray as $line) {
$line = trim($line);
if ($line) {
if ($count > 1 && $count < count($formattedArray)) {
$line = "$line\n";
}
$finalFormatted .= $line;
$count++;
}
}
}
return $finalFormatted;
}
/**
* @param $format
*
* @return array
*/
public static function sequence($format) {
// also compute and store the address sequence
$addressSequence = array(
'address_name',
'street_address',
'supplemental_address_1',
'supplemental_address_2',
'city',
'county',
'state_province',
'postal_code',
'country',
);
// get the field sequence from the format
$newSequence = array();
foreach ($addressSequence as $field) {
if (substr_count($format, $field)) {
$newSequence[strpos($format, $field)] = $field;
}
}
ksort($newSequence);
// add the addressSequence fields that are missing in the addressFormat
// to the end of the list, so that (for example) if state_province is not
// specified in the addressFormat it's still in the address-editing form
$newSequence = array_merge($newSequence, $addressSequence);
$newSequence = array_unique($newSequence);
return $newSequence;
}
}