/*
+--------------------------------------------------------------------+
- | CiviCRM version 4.3 |
+ | CiviCRM version 4.4 |
+--------------------------------------------------------------------+
| Copyright CiviCRM LLC (c) 2004-2013 |
+--------------------------------------------------------------------+
/**
* Defines 'uf field' within a group.
*
- * @param $groupId int Valid uf_group id
- *
* @param $params array Associative array of property name/value pairs to create new uf field.
*
+ * @throws API_Exception
+ * @internal param int $groupId Valid uf_group id
+ *
* @return Newly created $ufFieldArray array
*
* @access public
civicrm_api3_verify_one_mandatory($params, NULL, array('field_name', 'uf_group_id'));
$groupId = CRM_Utils_Array::value('uf_group_id', $params);
if ((int) $groupId < 1) {
- return civicrm_api3_create_error('Params must be a field_name-carrying array and a positive integer.');
+ throw new API_Exception('Params must be a field_name-carrying array and a positive integer.');
}
$field_type = CRM_Utils_Array::value('field_type', $params);
$phone_type = CRM_Utils_Array::value('phone_type_id', $params, CRM_Utils_Array::value('phone_type', $params));
if (! CRM_Core_BAO_UFField::isValidFieldName($field_name)) {
- return civicrm_api3_create_error('The field_name is not valid');
+ throw new API_Exception('The field_name is not valid');
}
$params['field_name'] = array($field_type, $field_name, $location_type_id, $phone_type);
$params['group_id'] = $groupId;
}
- $ids = array();
+ $ids = $ufFieldArray = array();
$ids['uf_group'] = $groupId;
$fieldId = CRM_Utils_Array::value('id', $params);
}
}
else {
- return civicrm_api3_create_error("there is no field for this fieldId");
+ throw new API_Exception("there is no field for this fieldId");
}
$ids['uf_field'] = $fieldId;
}
if (CRM_Core_BAO_UFField::duplicateField($params, $ids)) {
- return civicrm_api3_create_error("The field was not added. It already exists in this profile.");
+ throw new API_Exception("The field was not added. It already exists in this profile.");
}
+ //@todo why is this even optional? Surely weight should just be 'managed' ??
if (CRM_Utils_Array::value('option.autoweight', $params, TRUE)) {
$params['weight'] = CRM_Core_BAO_UFField::autoWeight($params);
}
CRM_Core_BAO_UFGroup::updateGroupTypes($groupId, $fieldsType);
_civicrm_api3_object_to_array($ufField, $ufFieldArray[$ufField->id]);
+ civicrm_api3('profile', 'getfields', array('cache_clear' => TRUE));
return civicrm_api3_create_success($ufFieldArray, $params);
}
/**
* Gets field for civicrm_uf_field create
*
+ * @param $params
+ *
* @return array fields valid for other functions
*/
function _civicrm_api3_uf_field_create_spec(&$params) {
$params['option.autoweight'] = array(
'title' => "Automatically adjust weights in UFGroup to align with UFField",
- 'type' => CRM_Utils_Type::T_BOOL
+ 'type' => CRM_Utils_Type::T_BOOLEAN,
+ 'api.default' => TRUE,
);
+ $params['created_id']['api.default'] = 'user_contact_id';
+ $params['is_active']['api.default'] = TRUE;
}
/**
/**
* Delete uf field
*
- * @param $fieldId int Valid uf_field id that to be deleted
+ * @param $params
+ *
+ * @throws API_Exception
+ * @internal param int $fieldId Valid uf_field id that to be deleted
*
* @return true on successful delete or return error
*
$ufGroupId = CRM_Core_DAO::getFieldValue('CRM_Core_DAO_UFField', $fieldId, 'uf_group_id');
if (!$ufGroupId) {
- return civicrm_api3_create_error('Invalid value for field_id.');
+ throw new API_Exception('Invalid value for field_id.');
}
$result = CRM_Core_BAO_UFField::del($fieldId);
return civicrm_api3_create_success($result, $params);
}
-/*
- * field id accepted for backward compat - unset required on id
+/**
+ * field id accepted for backward compatibility - unset required on id
*/
function _civicrm_api3_uf_field_delete_spec(&$params) {
// legacy support for field_id