3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.5 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2014 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
31 * @copyright CiviCRM LLC (c) 2004-2014
37 * This class generates form components for Address Section
39 class CRM_Admin_Form_Preferences_Address
extends CRM_Admin_Form_Preferences
{
40 function preProcess() {
42 CRM_Utils_System
::setTitle(ts('Settings - Addresses'));
44 // Address Standardization
45 $addrProviders = array(
46 '' => '- select -') + CRM_Core_SelectValues
::addressProvider();
48 $this->_varNames
= array(
49 CRM_Core_BAO_Setting
::SYSTEM_PREFERENCES_NAME
=> array(
50 'address_options' => array(
51 'html_type' => 'checkboxes',
52 'title' => ts('Address Fields'),
55 'address_format' => array(
56 'html_type' => 'textarea',
57 'title' => ts('Display Format'),
58 'description' => NULL,
61 'mailing_format' => array(
62 'html_type' => 'textarea',
63 'title' => ts('Mailing Label Format'),
64 'description' => NULL,
68 CRM_Core_BAO_Setting
::ADDRESS_STANDARDIZATION_PREFERENCES_NAME
=> array(
69 'address_standardization_provider' => array(
70 'html_type' => 'select',
71 'title' => ts('Provider'),
72 'option_values' => $addrProviders,
75 'address_standardization_userid' => array(
76 'html_type' => 'text',
77 'title' => ts('User ID'),
78 'description' => NULL,
81 'address_standardization_url' => array(
82 'html_type' => 'text',
83 'title' => ts('Web Service URL'),
84 'description' => NULL,
96 function setDefaultValues() {
98 $defaults['address_standardization_provider'] = $this->_config
->address_standardization_provider
;
99 $defaults['address_standardization_userid'] = $this->_config
->address_standardization_userid
;
100 $defaults['address_standardization_url'] = $this->_config
->address_standardization_url
;
103 $this->addressSequence
= isset($newSequence) ?
$newSequence : "";
105 if (empty($this->_config
->address_format
)) {
106 $defaults['address_format'] = "
107 {contact.street_address}
108 {contact.supplemental_address_1}
109 {contact.supplemental_address_2}
110 {contact.city}{, }{contact.state_province}{ }{contact.postal_code}
115 $defaults['address_format'] = $this->_config
->address_format
;
118 if (empty($this->_config
->mailing_format
)) {
119 $defaults['mailing_format'] = "
121 {contact.street_address}
122 {contact.supplemental_address_1}
123 {contact.supplemental_address_2}
124 {contact.city}{, }{contact.state_province}{ }{contact.postal_code}
129 $defaults['mailing_format'] = $this->_config
->mailing_format
;
133 parent
::cbsDefaultValues($defaults);
139 * Build the form object
144 public function buildQuickForm() {
145 $this->applyFilter('__ALL__', 'trim');
147 $this->addFormRule(array('CRM_Admin_Form_Preferences_Address', 'formRule'));
149 //get the tokens for Mailing Label field
150 $tokens = CRM_Core_SelectValues
::contactTokens();
151 $this->assign('tokens', CRM_Utils_Token
::formatTokensForDisplay($tokens));
153 parent
::buildQuickForm();
161 static function formRule($fields) {
162 $p = $fields['address_standardization_provider'];
163 $u = $fields['address_standardization_userid'];
164 $w = $fields['address_standardization_url'];
166 // make sure that there is a value for all of them
167 // if any of them are set
168 if ($p ||
$u ||
$w) {
169 if (!CRM_Utils_System
::checkPHPVersion(5, FALSE)) {
170 $errors['_qf_default'] = ts('Address Standardization features require PHP version 5 or greater.');
174 if (!($p && $u && $w)) {
175 $errors['_qf_default'] = ts('You must provide values for all three Address Standarization fields.');
184 * Process the form submission
190 public function postProcess() {
191 if ($this->_action
== CRM_Core_Action
::VIEW
) {
195 $this->_params
= $this->controller
->exportValues($this->_name
);
198 // check if county option has been set
199 $options = CRM_Core_OptionGroup
::values('address_options', FALSE, FALSE, TRUE);
200 foreach ($options as $key => $title) {
201 if ($title == ts('County')) {
202 // check if the $key is present in $this->_params
203 if (isset($this->_params
['address_options']) &&
204 !empty($this->_params
['address_options'][$key])
206 // print a status message to the user if county table seems small
207 $countyCount = CRM_Core_DAO
::singleValueQuery("SELECT count(*) FROM civicrm_county");
208 if ($countyCount < 10) {
209 CRM_Core_Session
::setStatus(ts('You have enabled the County option. Please ensure you populate the county table in your CiviCRM Database. You can find extensions to populate counties in the <a %1>CiviCRM Extensions Directory</a>.', array(1 => 'href="' . CRM_Utils_System
::url('civicrm/admin/extensions', array('reset' => 1), TRUE, 'extensions-addnew') . '"')),
210 ts('Populate counties'),
218 $this->postProcessCommon();