Merge pull request #17033 from seamuslee001/5.25
[civicrm-core.git] / CRM / Core / QuickForm / NestedAdvMultiSelect.php
CommitLineData
6a488035
TO
1<?php
2/*
3 +--------------------------------------------------------------------+
fee14197 4 | CiviCRM version 5 |
6a488035
TO
5 +--------------------------------------------------------------------+
6 | Copyright U.S. PIRG Education Fund (c) 2007 |
7 | Licensed to CiviCRM under the Academic Free License version 3.0. |
8 +--------------------------------------------------------------------+
9 | This file is a part of CiviCRM. |
10 | |
11 | CiviCRM is free software; you can copy, modify, and distribute it |
12 | under the terms of the GNU Affero General Public License |
13 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | |
15 | CiviCRM is distributed in the hope that it will be useful, but |
16 | WITHOUT ANY WARRANTY; without even the implied warranty of |
17 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
18 | See the GNU Affero General Public License for more details. |
19 | |
20 | You should have received a copy of the GNU Affero General Public |
21 | License and the CiviCRM Licensing Exception along |
22 | with this program; if not, contact CiviCRM LLC |
23 | at info[AT]civicrm[DOT]org. If you have questions about the |
24 | GNU Affero General Public License or the licensing of CiviCRM, |
25 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
26 +--------------------------------------------------------------------+
d25dd0ee 27 */
6a488035
TO
28
29/**
30 *
31 * @package CRM
32 * @copyright U.S. PIRG Education Fund 2007
33 * $Id$
34 *
35 */
36
37require_once 'HTML/QuickForm/advmultiselect.php';
28518c90
EM
38
39/**
40 * Class CRM_Core_QuickForm_NestedAdvMultiSelect
41 */
6a488035 42class CRM_Core_QuickForm_NestedAdvMultiSelect extends HTML_QuickForm_advmultiselect {
518fa0ee 43
b5c2afd0 44 /**
d09edf64 45 * Loads options from different types of data sources.
b5c2afd0
EM
46 *
47 * This method overloaded parent method of select element, to allow
48 * loading options with fancy attributes.
49 *
50 * @param mixed &$options Options source currently supports assoc array or DB_result
6a0b768e
TO
51 * @param mixed $param1
52 * (optional) See function detail.
53 * @param mixed $param2
54 * (optional) See function detail.
55 * @param mixed $param3
56 * (optional) See function detail.
57 * @param mixed $param4
58 * (optional) See function detail.
b5c2afd0 59 *
b5c2afd0 60 * @since version 1.5.0 (2009-02-15)
2b37475d 61 * @return PEAR_Error|NULL on error and TRUE on success
b5c2afd0
EM
62 * @throws PEAR_Error
63 * @see loadArray()
64 */
795492f3 65 public function load(
f9f40af3 66 &$options, $param1 = NULL, $param2 = NULL,
6a488035
TO
67 $param3 = NULL, $param4 = NULL
68 ) {
69 switch (TRUE) {
70 case ($options instanceof Iterator):
be2fb01f 71 $arr = [];
6a488035
TO
72 foreach ($options as $key => $val) {
73 $arr[$key] = $val;
74 }
75 return $this->loadArray($arr, $param1);
76
77 default:
78 return parent::load($options, $param1, $param2, $param3, $param4);
79 }
80 }
96025800 81
6a488035 82}