forked from GNUsocial/gnu-social
add url to events
This commit is contained in:
parent
53e67b5ed5
commit
f00f5f20b8
@ -300,8 +300,69 @@ class EventPlugin extends MicroappPlugin
|
|||||||
|
|
||||||
function showEventNotice($notice, $out)
|
function showEventNotice($notice, $out)
|
||||||
{
|
{
|
||||||
$out->raw($notice->rendered);
|
$profile = $notice->getProfile();
|
||||||
return;
|
$event = Happening::fromNotice($notice);
|
||||||
|
|
||||||
|
assert(!empty($event));
|
||||||
|
assert(!empty($profile));
|
||||||
|
|
||||||
|
$out->elementStart('div', 'vevent');
|
||||||
|
|
||||||
|
$out->elementStart('h3');
|
||||||
|
|
||||||
|
if (!empty($event->url)) {
|
||||||
|
$out->element('a',
|
||||||
|
array('href' => $att->url,
|
||||||
|
'class' => 'event-title entry-title summary'),
|
||||||
|
$event->title);
|
||||||
|
} else {
|
||||||
|
$out->text($event->title);
|
||||||
|
}
|
||||||
|
|
||||||
|
$out->elementEnd('h3');
|
||||||
|
|
||||||
|
$out->elementStart('div', 'event-times');
|
||||||
|
$out->element('abbr', array('class' => 'dtstart',
|
||||||
|
'title' => common_date_iso8601($event->start_time)),
|
||||||
|
common_exact_date($event->start_time));
|
||||||
|
$out->text(' - ');
|
||||||
|
$out->element('span', array('class' => 'dtend',
|
||||||
|
'title' => common_date_iso8601($event->end_time)),
|
||||||
|
common_exact_date($event->end_time));
|
||||||
|
$out->elementEnd('div');
|
||||||
|
|
||||||
|
if (!empty($event->description)) {
|
||||||
|
$out->element('div', 'description', $event->description);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($event->location)) {
|
||||||
|
$out->element('div', 'location', $event->location);
|
||||||
|
}
|
||||||
|
|
||||||
|
$out->elementStart('div', array('class' => 'event-info entry-content'));
|
||||||
|
|
||||||
|
$avatar = $profile->getAvatar(AVATAR_MINI_SIZE);
|
||||||
|
|
||||||
|
$out->element('img',
|
||||||
|
array('src' => ($avatar) ?
|
||||||
|
$avatar->displayUrl() :
|
||||||
|
Avatar::defaultImage(AVATAR_MINI_SIZE),
|
||||||
|
'class' => 'avatar photo bookmark-avatar',
|
||||||
|
'width' => AVATAR_MINI_SIZE,
|
||||||
|
'height' => AVATAR_MINI_SIZE,
|
||||||
|
'alt' => $profile->getBestName()));
|
||||||
|
|
||||||
|
$out->raw(' '); // avoid for AJAX XML compatibility
|
||||||
|
|
||||||
|
$out->elementStart('span', 'vcard author'); // hack for belongsOnTimeline; JS needs to be able to find the author
|
||||||
|
$out->element('a',
|
||||||
|
array('class' => 'url',
|
||||||
|
'href' => $profile->profileurl,
|
||||||
|
'title' => $profile->getBestName()),
|
||||||
|
$profile->nickname);
|
||||||
|
$out->elementEnd('span');
|
||||||
|
|
||||||
|
$out->elementEnd('div');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -60,6 +60,7 @@ class Happening extends Managed_DataObject
|
|||||||
public $end_time; // datetime
|
public $end_time; // datetime
|
||||||
public $title; // varchar(255)
|
public $title; // varchar(255)
|
||||||
public $location; // varchar(255)
|
public $location; // varchar(255)
|
||||||
|
public $url; // varchar(255)
|
||||||
public $description; // text
|
public $description; // text
|
||||||
public $created; // datetime
|
public $created; // datetime
|
||||||
|
|
||||||
@ -92,15 +93,16 @@ class Happening extends Managed_DataObject
|
|||||||
'uri' => array('type' => 'varchar',
|
'uri' => array('type' => 'varchar',
|
||||||
'length' => 255,
|
'length' => 255,
|
||||||
'not null' => true),
|
'not null' => true),
|
||||||
'profile_id' => array('type' => 'int'),
|
'profile_id' => array('type' => 'int', 'not null' => true),
|
||||||
'start_time' => array('type' => 'datetime'),
|
'start_time' => array('type' => 'datetime', 'not null' => true),
|
||||||
'end_time' => array('type' => 'datetime'),
|
'end_time' => array('type' => 'datetime', 'not null' => true),
|
||||||
'title' => array('type' => 'varchar',
|
'title' => array('type' => 'varchar',
|
||||||
'length' => 255,
|
'length' => 255,
|
||||||
'not null' => true),
|
'not null' => true),
|
||||||
'location' => array('type' => 'varchar',
|
'location' => array('type' => 'varchar',
|
||||||
'length' => 255,
|
'length' => 255),
|
||||||
'not null' => true),
|
'url' => array('type' => 'varchar',
|
||||||
|
'length' => 255),
|
||||||
'description' => array('type' => 'text'),
|
'description' => array('type' => 'text'),
|
||||||
'created' => array('type' => 'datetime',
|
'created' => array('type' => 'datetime',
|
||||||
'not null' => true),
|
'not null' => true),
|
||||||
@ -109,10 +111,13 @@ class Happening extends Managed_DataObject
|
|||||||
'unique keys' => array(
|
'unique keys' => array(
|
||||||
'happening_uri_key' => array('uri'),
|
'happening_uri_key' => array('uri'),
|
||||||
),
|
),
|
||||||
|
'foreign keys' => array('happening_profile_id__key' => array('profile', array('profile_id' => 'id'))),
|
||||||
|
'indexes' => array('happening_created_idx' => array('created'),
|
||||||
|
'happening_start_end_idx' => array('start_time', 'end_time')),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function saveNew($profile, $start_time, $end_time, $title, $location, $description, $options=array())
|
function saveNew($profile, $start_time, $end_time, $title, $location, $description, $url, $options=array())
|
||||||
{
|
{
|
||||||
if (array_key_exists('uri', $options)) {
|
if (array_key_exists('uri', $options)) {
|
||||||
$other = Happening::staticGet('uri', $options['uri']);
|
$other = Happening::staticGet('uri', $options['uri']);
|
||||||
@ -130,6 +135,7 @@ class Happening extends Managed_DataObject
|
|||||||
$ev->title = $title;
|
$ev->title = $title;
|
||||||
$ev->location = $location;
|
$ev->location = $location;
|
||||||
$ev->description = $description;
|
$ev->description = $description;
|
||||||
|
$ev->url = $url;
|
||||||
|
|
||||||
if (array_key_exists('created', $options)) {
|
if (array_key_exists('created', $options)) {
|
||||||
$ev->created = $options['created'];
|
$ev->created = $options['created'];
|
||||||
@ -177,6 +183,10 @@ class Happening extends Managed_DataObject
|
|||||||
$options['uri'] = $ev->uri;
|
$options['uri'] = $ev->uri;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!empty($url)) {
|
||||||
|
$options['urls'] = array($url);
|
||||||
|
}
|
||||||
|
|
||||||
$saved = Notice::saveNew($profile->id,
|
$saved = Notice::saveNew($profile->id,
|
||||||
$content,
|
$content,
|
||||||
array_key_exists('source', $options) ?
|
array_key_exists('source', $options) ?
|
||||||
@ -191,7 +201,7 @@ class Happening extends Managed_DataObject
|
|||||||
return Notice::staticGet('uri', $this->uri);
|
return Notice::staticGet('uri', $this->uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
static function fromNotice()
|
static function fromNotice($notice)
|
||||||
{
|
{
|
||||||
return Happening::staticGet('uri', $notice->uri);
|
return Happening::staticGet('uri', $notice->uri);
|
||||||
}
|
}
|
||||||
|
@ -192,7 +192,7 @@ class RSVP extends Managed_DataObject
|
|||||||
return Notice::staticGet('uri', $this->uri);
|
return Notice::staticGet('uri', $this->uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
static function fromNotice()
|
static function fromNotice($notice)
|
||||||
{
|
{
|
||||||
return RSVP::staticGet('uri', $notice->uri);
|
return RSVP::staticGet('uri', $notice->uri);
|
||||||
}
|
}
|
||||||
|
@ -133,6 +133,13 @@ class EventForm extends Form
|
|||||||
_('Event location'));
|
_('Event location'));
|
||||||
$this->unli();
|
$this->unli();
|
||||||
|
|
||||||
|
$this->li();
|
||||||
|
$this->out->input('url',
|
||||||
|
_('URL'),
|
||||||
|
null,
|
||||||
|
_('URL for more information'));
|
||||||
|
$this->unli();
|
||||||
|
|
||||||
$this->li();
|
$this->li();
|
||||||
$this->out->input('description',
|
$this->out->input('description',
|
||||||
_('Description'),
|
_('Description'),
|
||||||
|
@ -91,6 +91,7 @@ class NeweventAction extends Action
|
|||||||
|
|
||||||
$this->title = $this->trimmed('title');
|
$this->title = $this->trimmed('title');
|
||||||
$this->location = $this->trimmed('location');
|
$this->location = $this->trimmed('location');
|
||||||
|
$this->url = $this->trimmed('url');
|
||||||
$this->description = $this->trimmed('description');
|
$this->description = $this->trimmed('description');
|
||||||
|
|
||||||
$start_date = $this->trimmed('start_date');
|
$start_date = $this->trimmed('start_date');
|
||||||
@ -146,12 +147,15 @@ class NeweventAction extends Action
|
|||||||
throw new ClientException(_('Event must have an end time.'));
|
throw new ClientException(_('Event must have an end time.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
$saved = Happening::saveNew($this->user->getProfile(),
|
$profile = $this->user->getProfile();
|
||||||
|
|
||||||
|
$saved = Happening::saveNew($profile,
|
||||||
$this->start_time,
|
$this->start_time,
|
||||||
$this->end_time,
|
$this->end_time,
|
||||||
$this->title,
|
$this->title,
|
||||||
$this->location,
|
$this->location,
|
||||||
$this->description);
|
$this->description,
|
||||||
|
$this->url);
|
||||||
|
|
||||||
} catch (ClientException $ce) {
|
} catch (ClientException $ce) {
|
||||||
$this->error = $ce->getMessage();
|
$this->error = $ce->getMessage();
|
||||||
|
Loading…
Reference in New Issue
Block a user