Item: new methods get|set_template

This commit is contained in:
Domovoy 2012-08-11 16:56:10 +02:00
parent d817117f6e
commit 56cae53e50
2 changed files with 25 additions and 11 deletions

View file

@ -50,13 +50,13 @@ class Conversation extends BaseObject {
* _ The data requested on success * _ The data requested on success
* _ false on failure * _ false on failure
*/ */
public function get_template_data($cmnt_tpl) { public function get_template_data($cmnt_tpl, $alike, $dlike) {
$result = array(); $result = array();
foreach($this->threads as $item) { foreach($this->threads as $item) {
if($item->get_network() === NETWORK_MAIL && local_user() != $item->get_uid()) if($item->get_network() === NETWORK_MAIL && local_user() != $item->get_uid())
continue; continue;
$item_data = $item->get_template_data($cmnt_tpl, $this->mode); $item_data = $item->get_template_data($cmnt_tpl, $this->mode, $alike, $dlike);
if(!$item_data) { if(!$item_data) {
logger('[ERROR] Conversation::get_template_data : Failed to get item template data ('. $item->get_id() .').', LOGGER_DEBUG); logger('[ERROR] Conversation::get_template_data : Failed to get item template data ('. $item->get_id() .').', LOGGER_DEBUG);
return false; return false;

View file

@ -4,6 +4,7 @@ if(class_exists('Item'))
require_once('object/BaseObject.php'); require_once('object/BaseObject.php');
require_once('include/text.php'); require_once('include/text.php');
require_once('boot.php');
/** /**
* An item * An item
@ -21,7 +22,7 @@ class Item extends BaseObject {
public function __construct($data) { public function __construct($data) {
$this->data = $data; $this->data = $data;
$this->template = $this->available_templates['wall']; $this->set_template('wall');
} }
/** /**
@ -31,7 +32,7 @@ class Item extends BaseObject {
* _ The data requested on success * _ The data requested on success
* _ false on failure * _ false on failure
*/ */
public function get_template_data($cmnt_tpl, $mode) { public function get_template_data($cmnt_tpl, $mode, $alike, $dlike) {
$result = array(); $result = array();
$a = $this->get_app(); $a = $this->get_app();
@ -40,9 +41,6 @@ class Item extends BaseObject {
$item = $this->get_data(); $item = $this->get_data();
$alike = array();
$dlike = array();
$template = $this->available_templates['wall'];
$comment = ''; $comment = '';
$commentww = ''; $commentww = '';
$sparkle = ''; $sparkle = '';
@ -130,7 +128,7 @@ class Item extends BaseObject {
$owner_url = zrl($a->page_contact['url']); $owner_url = zrl($a->page_contact['url']);
$owner_photo = $a->page_contact['thumb']; $owner_photo = $a->page_contact['thumb'];
$owner_name = $a->page_contact['name']; $owner_name = $a->page_contact['name'];
$template = $this->available_templates['wall2wall']; $this->set_template('wall2wall');
$commentww = 'ww'; $commentww = 'ww';
} }
} }
@ -154,7 +152,7 @@ class Item extends BaseObject {
$owner_url = $item['owner-link']; $owner_url = $item['owner-link'];
$owner_photo = $item['owner-avatar']; $owner_photo = $item['owner-avatar'];
$owner_name = $item['owner-name']; $owner_name = $item['owner-name'];
$template = $this->available_templates['wall2wall']; $this->set_template('wall2wall');
$commentww = 'ww'; $commentww = 'ww';
// If it is our contact, use a friendly redirect link // If it is our contact, use a friendly redirect link
if((link_compare($item['owner-link'],$item['url'])) if((link_compare($item['owner-link'],$item['url']))
@ -252,7 +250,7 @@ class Item extends BaseObject {
'comment_firstcollapsed' => $firstcollapsed, 'comment_firstcollapsed' => $firstcollapsed,
'comment_lastcollapsed' => $lastcollapsed, 'comment_lastcollapsed' => $lastcollapsed,
// template to use to render item (wall, walltowall, search) // template to use to render item (wall, walltowall, search)
'template' => $template, 'template' => $this->get_template(),
'type' => implode("",array_slice(explode("/",$item['verb']),-1)), 'type' => implode("",array_slice(explode("/",$item['verb']),-1)),
'tags' => $tags, 'tags' => $tags,
@ -303,7 +301,7 @@ class Item extends BaseObject {
$item_result['children'] = array(); $item_result['children'] = array();
if(count($item['children'])) { if(count($item['children'])) {
$item_result['children'] = prepare_threads_body($a, $item['children'], $cmnt_tpl, $this->is_page_writeable(), $this->get_mode(), $this->get_profile_owner(), ($thread_level + 1)); $item_result['children'] = prepare_threads_body($a, $item['children'], $cmnt_tpl, $this->is_page_writeable(), $this->get_mode(), $this->get_profile_owner(), $alike, $dlike, ($thread_level + 1));
} }
$item_result['private'] = $item['private']; $item_result['private'] = $item['private'];
$item_result['toplevel'] = ($toplevelpost ? 'toplevel_item' : ''); $item_result['toplevel'] = ($toplevelpost ? 'toplevel_item' : '');
@ -410,5 +408,21 @@ class Item extends BaseObject {
private function is_page_writeable() { private function is_page_writeable() {
return $this->page_writeable; return $this->page_writeable;
} }
/**
* Set template
*/
private function set_template($name) {
if(!x($this->available_templates, $name))
return false;
$this->template = $this->available_templates[$name];
}
/**
* Get template
*/
private function get_template() {
return $this->template;
}
} }
?> ?>