ILIAS  release_5-2 Revision v5.2.25-18-g3f80b828510
class.ilECSImportedContentTableGUI.php
Go to the documentation of this file.
1 <?php
2 /*
3  +-----------------------------------------------------------------------------+
4  | ILIAS open source |
5  +-----------------------------------------------------------------------------+
6  | Copyright (c) 1998-2006 ILIAS open source, University of Cologne |
7  | |
8  | This program is free software; you can redistribute it and/or |
9  | modify it under the terms of the GNU General Public License |
10  | as published by the Free Software Foundation; either version 2 |
11  | of the License, or (at your option) any later version. |
12  | |
13  | This program is distributed in the hope that it will be useful, |
14  | but WITHOUT ANY WARRANTY; without even the implied warranty of |
15  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
16  | GNU General Public License for more details. |
17  | |
18  | You should have received a copy of the GNU General Public License |
19  | along with this program; if not, write to the Free Software |
20  | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
21  +-----------------------------------------------------------------------------+
22 */
23 
24 include_once('Services/Table/classes/class.ilTable2GUI.php');
25 
35 {
36  protected $lng;
37  protected $ctrl;
38 
46  public function __construct($a_parent_obj,$a_parent_cmd = '')
47  {
48  global $lng,$ilCtrl;
49 
50  $this->lng = $lng;
51  $this->ctrl = $ilCtrl;
52 
53  parent::__construct($a_parent_obj,$a_parent_cmd);
54  $this->addColumn($this->lng->txt('title'),'title','25%');
55  $this->addColumn($this->lng->txt('res_links_short'),'link','25%');
56  $this->addColumn($this->lng->txt('ecs_imported_from'),'from','15%');
57  $this->addColumn($this->lng->txt('ecs_meta_data'),'md','25%');
58  $this->addColumn($this->lng->txt('last_update'),'last_update','10%');
59  $this->setRowTemplate('tpl.content_row.html','Services/WebServices/ECS');
60  $this->setDefaultOrderField('title');
61  $this->setDefaultOrderDirection('asc');
62  $this->setFormAction($this->ctrl->getFormAction($a_parent_obj));
63 
64  }
65 
73  public function fillRow($a_set)
74  {
75  global $tree;
76 
77  include_once('./Services/Link/classes/class.ilLink.php');
78 
79  $this->tpl->setVariable('VAL_TITLE',$a_set['title']);
80  #$this->tpl->setVariable('VAL_LINK',ilLink::_getLink($a_set['ref_id'],'rcrs'));
81  $this->tpl->setVariable('VAL_DESC',$a_set['desc']);
82  $this->tpl->setVariable('VAL_REMOTE',$a_set['from']);
83  $this->tpl->setVariable('VAL_REMOTE_INFO',$a_set['from_info']);
84  $this->tpl->setVariable('TXT_EMAIL',$this->lng->txt('ecs_email'));
85  $this->tpl->setVariable('TXT_DNS',$this->lng->txt('ecs_dns'));
86  $this->tpl->setVariable('TXT_ABR',$this->lng->txt('ecs_abr'));
87  $this->tpl->setVariable('VAL_LAST_UPDATE',
89  );
90 
91  // Links
92  foreach(ilObject::_getAllReferences($a_set['obj_id']) as $ref_id)
93  {
94  $parent = $tree->getParentId($ref_id);
95  $p_obj_id = ilObject::_lookupObjId($parent);
96  $p_title = ilObject::_lookupTitle($p_obj_id);
97  $p_type = ilObject::_lookupType($p_obj_id);
98  $this->tpl->setCurrentBlock('link');
99  $this->tpl->setVariable('LINK_IMG',ilUtil::getTypeIconPath($p_type,$p_obj_id,'tiny'));
100  $this->tpl->setVariable('LINK_CONTAINER',$p_title);
101  $this->tpl->setVariable('LINK_LINK',ilLink::_getLink($parent,$p_type));
102  $this->tpl->parseCurrentBlock();
103  }
104 
105  $this->tpl->setVariable('TXT_TERM',$this->lng->txt('ecs_field_term'));
106  $this->tpl->setVariable('TXT_CRS_TYPE',$this->lng->txt('ecs_field_courseType'));
107  $this->tpl->setVariable('TXT_CRS_ID',$this->lng->txt('ecs_field_courseID'));
108  $this->tpl->setVariable('TXT_CREDITS',$this->lng->txt('ecs_field_credits'));
109  $this->tpl->setVariable('TXT_ROOM',$this->lng->txt('ecs_field_room'));
110  $this->tpl->setVariable('TXT_CYCLE',$this->lng->txt('ecs_field_cycle'));
111  $this->tpl->setVariable('TXT_SWS',$this->lng->txt('ecs_field_semester_hours'));
112  $this->tpl->setVariable('TXT_START',$this->lng->txt('ecs_field_begin'));
113  $this->tpl->setVariable('TXT_END',$this->lng->txt('ecs_field_end'));
114  $this->tpl->setVariable('TXT_LECTURER',$this->lng->txt('ecs_field_lecturer'));
115 
116  include_once('./Services/WebServices/ECS/classes/class.ilECSDataMappingSettings.php');
117  $settings = ilECSDataMappingSettings::getInstanceByServerId($a_set['sid']);
118 
119  include_once "Services/WebServices/ECS/classes/class.ilECSUtils.php";
120  $values = ilECSUtils::getAdvancedMDValuesForObjId($a_set['obj_id']);
121 
122  if($field = $settings->getMappingByECSName(ilECSDataMappingSetting::MAPPING_IMPORT_RCRS,'lecturer'))
123  {
124  $this->tpl->setVariable('VAL_LECTURER',isset($values[$field]) ? $values[$field] : '--');
125  }
126  if($field = $settings->getMappingByECSName(ilECSDataMappingSetting::MAPPING_IMPORT_RCRS,'term'))
127  {
128  $this->tpl->setVariable('VAL_TERM',isset($values[$field]) ? $values[$field] : '--');
129  }
130  if($field = $settings->getMappingByECSName(ilECSDataMappingSetting::MAPPING_IMPORT_RCRS,'courseID'))
131  {
132  $this->tpl->setVariable('VAL_CRS_ID',isset($values[$field]) ? $values[$field] : '--');
133  }
134  if($field = $settings->getMappingByECSName(ilECSDataMappingSetting::MAPPING_IMPORT_RCRS,'courseType'))
135  {
136  $this->tpl->setVariable('VAL_CRS_TYPE',isset($values[$field]) ? $values[$field] : '--');
137  }
138  if($field = $settings->getMappingByECSName(ilECSDataMappingSetting::MAPPING_IMPORT_RCRS,'credits'))
139  {
140  $this->tpl->setVariable('VAL_CREDITS',isset($values[$field]) ? $values[$field] : '--');
141  }
142  if($field = $settings->getMappingByECSName(ilECSDataMappingSetting::MAPPING_IMPORT_RCRS,'semester_hours'))
143  {
144  $this->tpl->setVariable('VAL_SWS',isset($values[$field]) ? $values[$field] : '--');
145  }
146  if($field = $settings->getMappingByECSName(ilECSDataMappingSetting::MAPPING_IMPORT_RCRS,'room'))
147  {
148  $this->tpl->setVariable('VAL_ROOM',isset($values[$field]) ? $values[$field] : '--');
149  }
150  if($field = $settings->getMappingByECSName(ilECSDataMappingSetting::MAPPING_IMPORT_RCRS,'cycle'))
151  {
152  $this->tpl->setVariable('VAL_CYCLE',isset($values[$field]) ? $values[$field] : '--');
153  }
154  if($field = $settings->getMappingByECSName(ilECSDataMappingSetting::MAPPING_IMPORT_RCRS,'begin'))
155  {
156  $this->tpl->setVariable('VAL_START',isset($values[$field]) ? ilDatePresentation::formatDate(new ilDateTime($values[$field],IL_CAL_UNIX)) : '--');
157  }
158  if($field = $settings->getMappingByECSName(ilECSDataMappingSetting::MAPPING_IMPORT_RCRS,'end'))
159  {
160  $this->tpl->setVariable('VAL_END',isset($values[$field]) ? ilDatePresentation::formatDate(new ilDateTime($values[$field],IL_CAL_UNIX)) : '--');
161  }
162  }
163 
171  public function parse($a_rcrs)
172  {
173  global $ilObjDataCache;
174 
175  // Preload object data
176  $ilObjDataCache->preloadReferenceCache($a_rcrs);
177 
178  // Read participants
179  include_once('./Modules/RemoteCourse/classes/class.ilObjRemoteCourse.php');
180  include_once('./Services/WebServices/ECS/classes/class.ilECSCommunityReader.php');
181  include_once './Services/WebServices/ECS/classes/class.ilECSImport.php';
182 
183  // read obj_ids
184  $obj_ids = array();
185  foreach($a_rcrs as $rcrs_ref_id)
186  {
187  $obj_id = $ilObjDataCache->lookupObjId($rcrs_ref_id);
188  $obj_ids[$obj_id] = $ilObjDataCache->lookupObjId($rcrs_ref_id);
189  }
190 
191  foreach($obj_ids as $obj_id => $obj_id)
192  {
193  $tmp_arr['obj_id'] = $obj_id;
194  $tmp_arr['sid'] = ilECSImport::lookupServerId($obj_id);
195  $tmp_arr['title'] = $ilObjDataCache->lookupTitle($obj_id);
196  $tmp_arr['desc'] = $ilObjDataCache->lookupDescription($obj_id);
197  $tmp_arr['md'] = '';
198 
199  $mid = ilObjRemoteCourse::_lookupMID($obj_id);
200 
201  if($tmp_arr['sid'])
202  {
203  try {
205  }
206  catch(ilECSConnectorException $e)
207  {
208  $reader = null;
209  }
210 
211  if($reader and ($participant = $reader->getParticipantByMID($mid)))
212  {
213  $tmp_arr['from'] = $participant->getParticipantName();
214  $tmp_arr['from_info'] = $participant->getDescription();
215  }
216  }
217  else
218  {
219  $tmp_arr['from'] = $this->lng->txt("ecs_server_deleted");
220  }
221 
222  $tmp_arr['last_update'] = $ilObjDataCache->lookupLastUpdate($obj_id);
223  $content[] = $tmp_arr;
224  }
225 
226  $this->setData($content ? $content : array());
227  }
228 }
229 ?>
static getInstanceByServerId($a_server_id)
Get singleton instance.
setDefaultOrderField($a_defaultorderfield)
Set Default order field.
const IL_CAL_DATETIME
static _lookupMID($a_obj_id)
lookup owner mid
static _lookupTitle($a_id)
lookup object title
const IL_CAL_UNIX
static getTypeIconPath($a_type, $a_obj_id, $a_size='small')
Get type icon path path Return image path for icon_xxx.pngs Or (if enabled) path to custom icon Depre...
static _getAllReferences($a_id)
get all reference ids of object
global $ilCtrl
Definition: ilias.php:18
setDefaultOrderDirection($a_defaultorderdirection)
Set Default order direction.
static getInstanceByServerId($a_server_id)
Get instance by server id.
Class ilTable2GUI.
static getAdvancedMDValuesForObjId($a_obj_id)
Get advanced metadata values for object id.
static _lookupObjId($a_id)
static formatDate(ilDateTime $date)
Format a date public.
Date and time handling
static lookupServerId($a_obj_id)
Lookup server id of imported content <type> $ilDB.
setRowTemplate($a_template, $a_template_dir="")
Set row template.
Create styles array
The data for the language used.
static _lookupType($a_id, $a_reference=false)
lookup object type
setFormAction($a_form_action, $a_multipart=false)
Set Form action parameter.
$ref_id
Definition: sahs_server.php:39
addColumn($a_text, $a_sort_field="", $a_width="", $a_is_checkbox_action_column=false, $a_class="", $a_tooltip="", $a_tooltip_with_html=false)
Add a column to the header.
__construct($a_parent_obj, $a_parent_cmd='')
constructor