Merge pull request #2596 from eileenmcnaughton/CRM-14299
[civicrm-core.git] / templates / CRM / Campaign / Form / Search / Campaign.tpl
1 {*
2 +--------------------------------------------------------------------+
3 | CiviCRM version 4.4 |
4 +--------------------------------------------------------------------+
5 | Copyright CiviCRM LLC (c) 2004-2013 |
6 +--------------------------------------------------------------------+
7 | This file is a part of CiviCRM. |
8 | |
9 | CiviCRM is free software; you can copy, modify, and distribute it |
10 | under the terms of the GNU Affero General Public License |
11 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
12 | |
13 | CiviCRM is distributed in the hope that it will be useful, but |
14 | WITHOUT ANY WARRANTY; without even the implied warranty of |
15 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
16 | See the GNU Affero General Public License for more details. |
17 | |
18 | You should have received a copy of the GNU Affero General Public |
19 | License and the CiviCRM Licensing Exception along |
20 | with this program; if not, contact CiviCRM LLC |
21 | at info[AT]civicrm[DOT]org. If you have questions about the |
22 | GNU Affero General Public License or the licensing of CiviCRM, |
23 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
24 +--------------------------------------------------------------------+
25 *}
26
27 {if !$hasCampaigns}
28 <div class="messages status no-popup">
29 <div class="icon inform-icon"></div>
30 &nbsp;
31 {ts}No campaigns found.{/ts}
32 </div>
33 <div class="action-link">
34 <a href="{crmURL p='civicrm/campaign/add' q='reset=1' h=0 }" class="button"><span><div
35 class="icon add-icon"></div>{ts}Add Campaign{/ts}</span></a>
36 </div>
37 {elseif $buildSelector}
38
39 {* load campaign selector *}
40
41 {include file="CRM/common/enableDisableApi.tpl"}
42 {include file="CRM/common/crmeditable.tpl"}
43
44 {literal}
45 <script type="text/javascript">
46 cj(function () {
47 loadCampaignList();
48 });
49 </script>
50 {/literal}
51 <table id="campaigns">
52 <thead>
53 <tr class="columnheader">
54 <th class="hiddenElement">{ts}Campaign ID{/ts}</th>
55 <th class="hiddenElement">{ts}Campaign Name{/ts}</th>
56 <th>{ts}Title{/ts}</th>
57 <th>{ts}Description{/ts}</th>
58 <th>{ts}Start Date{/ts}</th>
59 <th>{ts}End Date{/ts}</th>
60 <th class="hiddenElement">{ts}Type ID{/ts}</th>
61 <th>{ts}Type{/ts}</th>
62 <th class="hiddenElement">{ts}Status ID{/ts}</th>
63 <th>{ts}Status{/ts}</th>
64 <th class="hiddenElement">{ts}Is Active?{/ts}</th>
65 <th>{ts}Active?{/ts}</th>
66 <th></th>
67 </tr>
68 </thead>
69 <tbody></tbody>
70 </table>
71 {else}
72 <div class="action-link">
73 <a href="{crmURL p='civicrm/campaign/add' q='reset=1' h=0 }" class="button"><span><div
74 class="icon add-icon"></div>{ts}Add Campaign{/ts}</span></a>
75 </div>
76 {* build search form here *}
77
78 {* Search form and results for campaigns *}
79 <div class="crm-block crm-form-block crm-search-form-block">
80
81 {assign var='searchForm' value="search_form_$searchFor"}
82
83 <div id="{$searchForm}"
84 class="crm-accordion-wrapper crm-campaign_search_form-accordion {if $force and !$buildSelector}collapsed{/if}">
85 <div class="crm-accordion-header">
86 {ts}Search Campaigns{/ts}
87 </div>
88 <!-- /.crm-accordion-header -->
89
90 <div class="crm-accordion-body">
91 {strip}
92 <table class="form-layout-compressed">
93 <tr>
94 <td>{$form.campaign_title.label}<br/>
95 {$form.campaign_title.html} &nbsp;
96 </td>
97 <td>
98 {$form.description.label}<br/>
99 {$form.description.html|crmAddClass:huge}
100 </td>
101 </tr>
102
103 <tr>
104 <td>{$form.start_date.label}<br/>
105 {include file="CRM/common/jcalendar.tpl" elementName=start_date}
106 </td>
107 <td>{$form.end_date.label}<br/>
108 {include file="CRM/common/jcalendar.tpl" elementName=end_date}
109 </td>
110 </tr>
111
112 <tr>
113 <td>{$form.campaign_type_id.label}<br/>
114 {$form.campaign_type_id.html}
115 </td>
116 <td>{$form.status_id.label}<br/>
117 {$form.status_id.html}
118 </td>
119 </tr>
120
121 <tr>
122 <td colspan="2">
123 {if $context eq 'search'}
124 {$form.buttons.html}
125 {else}
126 <a class="searchCampaign button" style="float:left;" href="#" title="{ts}Search{/ts}"
127 onClick="searchCampaigns( '{$qfKey}' );return false;">{ts}Search{/ts}</a>
128 {/if}
129 </td>
130 </tr>
131 </table>
132 {/strip}
133 </div>
134 </div>
135 </div>
136 {* search form ends here *}
137 <div id='campaignList'></div>
138 {/if} {* end of search form build *}
139
140
141 {literal}
142 <script type="text/javascript">
143
144 cj(function () {
145 cj().crmAccordions();
146 });
147
148 {/literal}
149 {* load selector when force *}
150 {if $force and !$buildSelector}
151 {literal}
152 cj(function () {
153 searchCampaigns({/literal}'{$qfKey}'{literal});
154 });
155
156 {/literal}
157 {/if}
158 {literal}
159
160 function searchCampaigns(qfKey) {
161 var dataUrl = {/literal}"{crmURL h=0 q='search=1&snippet=4&type=campaign'}"{literal};
162
163 //lets carry qfKey to retain form session.
164 if (qfKey) {
165 dataUrl = dataUrl + '&qfKey=' + qfKey;
166 }
167
168 cj.get(dataUrl, null, function (campaignList) {
169 cj('#campaignList').html(campaignList).trigger('crmLoad');
170
171 //collapse the search form.
172 var searchFormName = '#search_form_' + {/literal}'{$searchFor}'{literal};
173 cj(searchFormName + '.crm-accordion-wrapper:not(.collapsed)').crmAccordionToggle();
174 }, 'html');
175 }
176
177 function loadCampaignList() {
178 var sourceUrl = {/literal}"{crmURL p='civicrm/ajax/rest' h=0 q='snippet=4&className=CRM_Campaign_Page_AJAX&fnName=campaignList' }"{literal};
179
180 //build the search qill.
181 //get the search criteria.
182 var searchParams = {/literal}{$searchParams}{literal};
183 var campaignTypes = {/literal}{$campaignTypes}{literal};
184 var campaignStatus = {/literal}{$campaignStatus}{literal};
185 var noRecordFoundMsg = '{/literal}{ts escape='js'}No matches found for:{/ts}{literal}';
186 noRecordFoundMsg += '<div class="qill">';
187
188 var count = 0;
189 var searchQill = new Array();
190 for (param in searchParams) {
191 if (val = cj('#' + param).val()) {
192 if (param == 'status_id') {
193 val = campaignStatus[val];
194 }
195 if (param == 'campaign_type_id') {
196 val = campaignTypes[val];
197 }
198 searchQill[count++] = searchParams[param] + ' : ' + val;
199 }
200 }
201 noRecordFoundMsg += searchQill.join('<span class="font-italic"> ...AND... </span></div><div class="qill">');
202
203 cj('#campaigns').dataTable({
204 "bFilter": false,
205 "bAutoWidth": false,
206 "bProcessing": false,
207 "bLengthChange": false,
208 "aaSorting": [],
209 "aoColumns": [
210 {sClass: 'crm-campaign-id hiddenElement' },
211 {sClass: 'crm-campaign-name hiddenElement' },
212 {sClass: 'crm-campaign-title' },
213 {sClass: 'crm-campaign-description' },
214 {sClass: 'crm-campaign-start_date' },
215 {sClass: 'crm-campaign-end_date' },
216 {sClass: 'crm-campaign-campaign-type_id hiddenElement' },
217 {sClass: 'crm-campaign-campaign-type' },
218 {sClass: 'crm-campaign-campaign-status_id hiddenElement' },
219 {sClass: 'crm-campaign-campaign-status' },
220 {sClass: 'crm-campaign-campaign-is_active hiddenElement' },
221 {sClass: 'crm-campaign-campaign-isAactive' },
222 {sClass: 'crm-campaign-action', bSortable: false}
223 ],
224 "sPaginationType": "full_numbers",
225 "sDom": 'rt<"crm-datatable-pager-bottom"ip>',
226 "bServerSide": true,
227 "bJQueryUI": true,
228 "sAjaxSource": sourceUrl,
229 "asStripClasses": ["odd-row", "even-row"],
230 "oLanguage": {"sEmptyTable": noRecordFoundMsg,
231 "sZeroRecords": noRecordFoundMsg },
232 "fnDrawCallback": function () {
233 cj().crmtooltip();
234 },
235 "fnRowCallback": function (nRow, aData, iDisplayIndex) {
236 //insert the id for each row for enable/disable.
237 var rowId = 'campaign_row_' + aData[0];
238 cj(nRow).attr('id', rowId);
239 //handled disabled rows.
240 var isActive = Boolean(Number(aData[10]));
241 if (!isActive) {
242 cj(nRow).addClass('disabled');
243 }
244
245 //add id for yes/no column.
246 cj(nRow).children().eq(11).attr('id', rowId + '_status');
247
248 return nRow;
249 },
250
251 "fnServerData": function (sSource, aoData, fnCallback) {
252 var dataLength = aoData.length;
253
254 var count = 1;
255 var searchCriteria = new Array();
256
257 //get the search criteria.
258 var searchParams = {/literal}{$searchParams}{literal};
259 for (param in searchParams) {
260 fldName = param;
261 if (param == 'campaign_title') {
262 fldName = 'title';
263 }
264 if (val = cj('#' + param).val()) {
265 aoData[dataLength++] = {name: fldName, value: val};
266 }
267 searchCriteria[count++] = fldName;
268 }
269
270 //do search for campaigns.
271 aoData[dataLength++] = {name: 'search_for', value: 'campaign'};
272
273 //lets transfer search criteria.
274 aoData[dataLength++] = {name: 'searchCriteria', value: searchCriteria.join(',')};
275
276 cj.ajax({
277 "dataType": 'json',
278 "type": "POST",
279 "url": sSource,
280 "data": aoData,
281 "success": fnCallback
282 });
283 }
284 });
285 }
286
287 </script>
288 {/literal}