24 include_once(
'Services/PrivacySecurity/classes/class.ilExportFieldsInfo.php');
25 include_once(
'./Services/Membership/classes/Export/class.ilMemberExport.php');
26 include_once(
'Modules/Course/classes/class.ilFSStorageCourse.php');
27 include_once(
'Modules/Group/classes/class.ilFSStorageGroup.php');
28 include_once(
'Modules/Course/classes/Export/class.ilCourseDefinedFieldDefinition.php');
29 include_once(
'Services/User/classes/class.ilUserDefinedFields.php');
30 include_once(
'Services/User/classes/class.ilUserFormSettings.php');
67 $this->lng->loadLanguageModule(
'ps');
68 $this->ref_id = $a_ref_id;
69 $this->obj_id = $ilObjDataCache->lookupObjId($this->ref_id);
85 global $ilAccess,$rbacsystem;
87 include_once(
'Services/PrivacySecurity/classes/class.ilPrivacySettings.php');
91 $this->ctrl->returnToParent($this);
94 $next_class = $this->ctrl->getNextClass($this);
95 $cmd = $this->ctrl->getCmd();
115 public function show($a_deliver_file =
false)
118 $this->tpl->addBlockFile(
'ADM_CONTENT',
'adm_content',
'tpl.member_export.html',
'Modules/Course');
119 $this->tpl->setVariable(
'FORM_ACTION',$this->ctrl->getFormAction($this));
120 $this->tpl->setVariable(
'TXT_EXPORT_SETTINGS',$this->lng->txt(
'ps_export_settings'));
121 $this->tpl->setVariable(
'TXT_USER_SELECTION',$this->lng->txt(
'ps_user_selection'));
122 $this->tpl->setVariable(
'TXT_EXPORT_ADMIN',$this->lng->txt(
'ps_export_admin'));
123 $this->tpl->setVariable(
'TXT_EXPORT_MEMBER',$this->lng->txt(
'ps_export_member'));
124 $this->tpl->setVariable(
'TXT_EXPORT_WAIT',$this->lng->txt(
'ps_export_wait'));
125 $this->tpl->setVariable(
'TXT_EXPORT_SUB',$this->lng->txt(
'ps_export_sub'));
130 $this->tpl->setVariable(
'CHECK_EXPORT_ADMIN',
ilUtil::formCheckbox($this->exportSettings->enabled(
'admin'),
'export_members[admin]',1));
131 if($this->type ==
'crs')
133 $this->tpl->setVariable(
'CHECK_EXPORT_TUTOR',
ilUtil::formCheckbox($this->exportSettings->enabled(
'tutor'),
'export_members[tutor]',1));
134 $this->tpl->setVariable(
'TXT_EXPORT_TUTOR',$this->lng->txt(
'ps_export_tutor'));
136 $this->tpl->setVariable(
'CHECK_EXPORT_MEMBER',
ilUtil::formCheckbox($this->exportSettings->enabled(
'member'),
'export_members[member]',1));
137 $this->tpl->setVariable(
'CHECK_EXPORT_SUB',
ilUtil::formCheckbox($this->exportSettings->enabled(
'subscribers'),
'export_members[subscribers]',1));
138 $this->tpl->setVariable(
'CHECK_EXPORT_WAIT',
ilUtil::formCheckbox($this->exportSettings->enabled(
'waiting_list'),
'export_members[waiting_list]',1));
140 $this->tpl->setVariable(
'TXT_EXPORT',$this->lng->txt(
'ps_perform_export'));
141 $this->tpl->setVariable(
'TXT_EXPORT_EXCEL',$this->lng->txt(
'ps_export_excel'));
144 $this->tpl->setVariable(
'TXT_USER_DATA_SELECTION',$this->lng->txt(
'ps_export_data'));
145 $this->tpl->setVariable(
'TXT_EXPORT_USER_DATA_HEADER',$this->lng->txt(
'ps_export_user_data'));
147 include_once
'./Services/Booking/classes/class.ilBookingEntry.php';
150 $this->tpl->setCurrentBlock(
'consultation');
151 $this->lng->loadLanguageModule(
'dateplaner');
152 $this->tpl->setVariable(
'TXT_CH',$this->lng->txt(
'cal_ch_field_ch'));
153 $this->tpl->setVariable(
'TXT_EXPORT_CH',$this->lng->txt(
'cal_ch_export_apps'));
154 $this->tpl->setVariable(
'CHECK_EXPORT_CH',
ilUtil::formCheckbox($this->exportSettings->enabled(
'consultation_hour'),
'export_members[consultation_hour]', 1));
155 $this->tpl->parseCurrentBlock();
158 $fields = $this->fields_info->getFieldsInfo();
159 foreach($fields as $field => $exportable)
165 $this->tpl->setCurrentBlock(
'user_data_row');
166 $this->tpl->setVariable(
'CHECK_EXPORT_USER_DATA',
ilUtil::formCheckbox($this->exportSettings->enabled($field),
'export_members['.$field.
']',1));
167 $this->tpl->setVariable(
'TXT_EXPORT_USER_DATA',$this->lng->txt($field));
168 $this->tpl->parseCurrentBlock();
172 foreach($exp = $udf->getExportableFields($this->obj_id) as $field_id => $udf_data)
174 $this->tpl->setCurrentBlock(
'user_data_row');
175 $this->tpl->setVariable(
'CHECK_EXPORT_USER_DATA',
ilUtil::formCheckbox($this->exportSettings->enabled(
'udf_'.$field_id),
176 'export_members[udf_'.$field_id.
']',1));
177 $this->tpl->setVariable(
'TXT_EXPORT_USER_DATA',$udf_data[
'field_name']);
178 $this->tpl->parseCurrentBlock();
183 foreach($cdf_fields as $field_obj)
185 $this->tpl->setCurrentBlock(
'cdf_row');
186 $this->tpl->setVariable(
'CHECK_CDF_DATA',
ilUtil::formCheckbox($this->exportSettings->enabled(
'cdf_'.$field_obj->getId()),
187 'export_members[cdf_'.$field_obj->getId().
']',
189 $this->tpl->setVariable(
'TXT_CDF_NAME',$field_obj->getName());
190 $this->tpl->parseCurrentBlock();
192 if(count($cdf_fields))
194 $this->tpl->setCurrentBlock(
'cdf_fields');
195 $this->tpl->setVariable(
'TXT_CDF_SELECTION',$this->lng->txt(
'ps_'.$this->type.
'_user_fields'));
196 $this->tpl->parseCurrentBlock();
199 if($a_deliver_file and 0)
201 $this->tpl->setCurrentBlock(
'iframe');
202 $this->tpl->setVariable(
'SOURCE',$this->ctrl->getLinkTarget($this,
'deliverData'));
215 foreach($this->fss_export->getMemberExportFiles() as
$file)
219 $content = $this->fss_export->getMemberExportFile(
$_SESSION[
'member_export_filename']);
238 if(!count($files = $this->fss_export->getMemberExportFiles()))
243 $a_tpl =
new ilTemplate(
'tpl.table.html',
true,
true);
244 $a_tpl->addBlockfile(
"TBL_CONTENT",
"tbl_content",
"tpl.member_export_file_row.html",
"Modules/Course");
245 $a_tpl->setVariable(
'FORMACTION',$this->ctrl->getFormaction($this));
247 include_once(
"./Services/Table/classes/class.ilTableGUI.php");
252 $tbl->setTitle($this->lng->txt(
"ps_export_files"));
254 $tbl->setHeaderNames(array(
"", $this->lng->txt(
"type"),
255 $this->lng->txt(
"ps_size"),
256 $this->lng->txt(
"date") ));
258 $cols = array(
"",
"type",
"size",
"date");
260 $header_params = $this->ctrl->getParameterArray($this,
'show');
261 $tbl->setHeaderVars($cols, $header_params);
262 $tbl->setColumnWidth(array(
"1%",
"9%",
"45%",
"45%"));
265 $tbl->setOrderColumn(
$_GET[
"sort_by"]);
266 $tbl->setOrderDirection(
$_GET[
"sort_order"]);
267 $tbl->setLimit($ilUser->getPref(
'hits_per_page',9999));
268 $tbl->setOffset(
$_GET[
"offset"]);
269 $tbl->setMaxCount(count($files));
270 $tbl->disable(
"sort");
271 $a_tpl->setVariable(
"COLUMN_COUNTS",4);
273 $files = array_reverse($files);
274 $files = array_slice($files,
$_GET[
"offset"],
$_GET[
"limit"]);
277 foreach($files as $exp_file)
279 $a_tpl->setCurrentBlock(
"tbl_content");
280 $a_tpl->setVariable(
"TXT_FILENAME", $exp_file[
"file"]);
283 $a_tpl->setVariable(
"CSS_ROW", $css_row);
285 $a_tpl->setVariable(
"TXT_SIZE",$exp_file[
'size']);
286 $a_tpl->setVariable(
"TXT_TYPE", strtoupper($exp_file[
"type"]));
287 $a_tpl->setVariable(
"CHECKBOX_ID",$exp_file[
"timest"]);
288 $a_tpl->setVariable(
"TXT_DATE", date(
"Y-m-d H:i",$exp_file[
'timest']));
289 $a_tpl->parseCurrentBlock();
295 $a_tpl->setCurrentBlock(
"tbl_action_btn");
296 $a_tpl->setVariable(
"BTN_NAME",
"confirmDeleteExportFile");
297 $a_tpl->setVariable(
"BTN_VALUE", $this->lng->txt(
"delete"));
298 $a_tpl->parseCurrentBlock();
300 $a_tpl->setCurrentBlock(
"tbl_action_btn");
301 $a_tpl->setVariable(
"BTN_NAME",
"downloadExportFile");
302 $a_tpl->setVariable(
"BTN_VALUE", $this->lng->txt(
"download"));
303 $a_tpl->parseCurrentBlock();
306 $tbl->setFooter(
"tblfooter",$this->lng->txt(
"previous"),$this->lng->txt(
"next"));
309 $tbl->setTemplate($a_tpl);
312 #$this->tpl->setCurrentBlock('file_list'); 313 $this->tpl->setVariable(
'FILE_LIST_TABLE',$a_tpl->get());
314 #$this->tpl->parseCurrentBlock(); 327 if(count(
$_POST[
'files']) != 1)
333 foreach($this->fss_export->getMemberExportFiles() as
$file)
339 $contents = $this->fss_export->getMemberExportFile(
$file[
'timest'].
'_participant_export_'.
340 $file[
'type'].
'_'.$this->obj_id.
'.'.
$file[
'type']);
343 switch($file[
'type'])
348 date(
'Y_m_d_H-i'.$file[
'timest']).
'_member_export_'.$this->obj_id.
'.xls',
349 'application/vnd.ms-excel' 376 if(!count(
$_POST[
'files']))
385 $this->tpl->addBlockFile(
'ADM_CONTENT',
'adm_content',
'tpl.member_export_confirm_delete.html',
'Modules/Course');
386 $this->tpl->setVariable(
'FORMACTION',$this->ctrl->getFormAction($this));
387 $this->tpl->setVariable(
'TEXT',$this->lng->txt(
'ps_delete_export_files'));
391 foreach($this->fss_export->getMemberExportFiles() as
$file)
397 $this->tpl->setCurrentBlock(
'table_row');
399 $this->tpl->setVariable(
'TEXT_TYPE',strtoupper(
$file[
'type']));
401 $this->tpl->parseCurrentBlock();
403 $this->tpl->setCurrentBlock(
'operation_btn');
404 $this->tpl->setVariable(
'BTN_NAME',
'deleteExportFile');
405 $this->tpl->setVariable(
'BTN_VALUE',$this->lng->txt(
'delete'));
406 $this->tpl->parseCurrentBlock();
408 $this->tpl->setCurrentBlock(
'operation_btn');
409 $this->tpl->setVariable(
'BTN_NAME',
'show');
410 $this->tpl->setVariable(
'BTN_VALUE',$this->lng->txt(
'cancel'));
411 $this->tpl->parseCurrentBlock();
424 if(!is_array(
$_SESSION[
'il_del_member_export']))
430 foreach($this->fss_export->getMemberExportFiles() as
$file)
436 $this->fss_export->deleteMemberExportFile(
$file[
'timest'].
'_participant_export_'.
$file[
'type'].
'_'.$this->obj_id.
'.'.
$file[
'type']);
455 $this->exportSettings->set(
$_POST[
'export_members']);
456 $this->exportSettings->store();
461 $filename = time().
'_participant_export_csv_'.$this->obj_id.
'.csv';
462 $this->fss_export->addMemberExportFile($this->
export->getCSVString(),
$filename);
472 $this->exportSettings->set(
$_POST[
'export_members']);
473 $this->exportSettings->store();
475 $filename = time().
'_participant_export_xls_'.$this->obj_id.
'.xls';
476 $this->fss_export->initMemberExportDirectory();
477 $filepath = $this->fss_export->getMemberExportDirectory().DIRECTORY_SEPARATOR.$filename;
480 $this->
export->setFilename($filepath);
496 if($this->type ==
'crs')
500 if($this->type ==
'grp')
static sendSuccess($a_info="", $a_keep=false)
Send Success Message to Screen.
static deliverData($a_data, $a_filename, $mime="application/octet-stream", $charset="")
deliver data for download via browser.
deliverData()
Deliver Data.
Class for generation of member export files.
show($a_deliver_file=false)
Show list of export files.
downloadExportFile()
Download export file.
deleteExportFile()
Delete member export files.
showFileList()
Show file list of available export files.
static hasObjectBookingEntries($a_obj_id, $a_usr_id)
Check if object has assigned consultation hour appointments.
static _getInstance()
Get instance.
export()
Export Create member export file and store it in data directory.
__construct($a_ref_id)
Constructor.
executeCommand()
Execute Command.
static _getInstanceByType($a_type)
Get Singleton Instance.
static getImagePath($img, $module_path="", $mode="output", $offline=false)
get image path (for images located in a template directory)
special template class to simplify handling of ITX/PEAR
static formatDate(ilDateTime $date)
Format a date public.
static sendQuestion($a_info="", $a_keep=false)
Send Question to Screen.
static _lookupType($a_id, $a_reference=false)
lookup object type
static sendFailure($a_info="", $a_keep=false)
Send Failure Message to Screen.
confirmDeleteExportFile()
Confirm deletion of export files.
initFileSystemStorage()
Init file object.
static switchColor($a_num, $a_css1, $a_css2)
switches style sheets for each even $a_num (used for changing colors of different result rows) ...
static _getInstance()
Get instance of ilPrivacySettings.
static formCheckbox($checked, $varname, $value, $disabled=false)
??? public
static _getFields($a_container_id, $a_sort=IL_CDF_SORT_NAME)
Get all fields of a container.