Symfony2 — CalendarBundle — Как получить информацию о пользователе из базы данных для отображения в календаре

Итак, я новичок в Symfony и пытаюсь создать функциональное приложение на основе календаря с событиями, отображаемыми из базы данных с использованием календарь-расслоение.

Передавая документацию, я смог установить связь между пользователями и событиями, отображаемыми в календаре, но я застрял, передавая определенные данные, точнее, имя пользователя.

Ниже показано EventEntity, который отвечает за детали события календаря.

<?php
namespace ADesigns\CalendarBundle\Entity;

/**
* Class for holding a calendar event's details.
*
* @author Mike Yudin <mikeyudin@gmail.com>
*/

class EventEntity
{
/**
* @var mixed Unique identifier of this event (optional).
*/
protected $id;

/**
* @var string Title/label of the calendar event.
*/
protected $title;

/**
* @var string URL Relative to current path.
*/
protected $url;

/**
* @var string HTML color code for the bg color of the event label.
*/
protected $bgColor;

/**
* @var string HTML color code for the foregorund color of the event label.
*/
protected $fgColor;

/**
* @var string css class for the event label
*/
protected $cssClass;

/**
* @var \DateTime DateTime object of the event start date/time.
*/
protected $startDatetime;

/**
* @var \DateTime DateTime object of the event end date/time.
*/
protected $endDatetime;

/**
* @var boolean Is this an all day event?
*/
protected $allDay = false;

/**
* @var array Non-standard fields
*/
protected $otherFields = array();

public function __construct($title, \DateTime $startDatetime, \DateTime $endDatetime = null, $allDay = false)
{
$this->title = $title;
$this->startDatetime = $startDatetime;
$this->setAllDay($allDay);

if ($endDatetime === null && $this->allDay === false) {
throw new \InvalidArgumentException("Must specify an event End DateTime if not an all day event.");
}

$this->endDatetime = $endDatetime;
}

/**
* Convert calendar event details to an array
*
* @return array $event
*/
public function toArray()
{
$event = array();

if ($this->id !== null) {
$event['id'] = $this->id;
}

$event['title'] = $this->title;
$event['start'] = $this->startDatetime->format("Y-m-d\TH:i:sP");

if ($this->url !== null) {
$event['url'] = $this->url;
}

if ($this->bgColor !== null) {
$event['backgroundColor'] = $this->bgColor;
$event['borderColor'] = $this->bgColor;
}

if ($this->fgColor !== null) {
$event['textColor'] = $this->fgColor;
}

if ($this->cssClass !== null) {
$event['className'] = $this->cssClass;
}

if ($this->endDatetime !== null) {
$event['end'] = $this->endDatetime->format("Y-m-d\TH:i:sP");
}

$event['allDay'] = $this->allDay;

foreach ($this->otherFields as $field => $value) {
$event[$field] = $value;
}

return $event;
}

public function setId($id)
{
$this->id = $id;
}

public function getId()
{
return $this->id;
}

public function setTitle($title)
{
$this->title = $title;
}

public function getTitle()
{
return $this->title;
}

public function setUrl($url)
{
$this->url = $url;
}

public function getUrl()
{
return $this->url;
}

public function setBgColor($color)
{
$this->bgColor = $color;
}

public function getBgColor()
{
return $this->bgColor;
}

public function setFgColor($color)
{
$this->fgColor = $color;
}

public function getFgColor()
{
return $this->fgColor;
}

public function setCssClass($class)
{
$this->cssClass = $class;
}

public function getCssClass()
{
return $this->cssClass;
}

public function setStartDatetime(\DateTime $start)
{
$this->startDatetime = $start;
}

public function getStartDatetime()
{
return $this->startDatetime;
}

public function setEndDatetime(\DateTime $end)
{
$this->endDatetime = $end;
}

public function getEndDatetime()
{
return $this->endDatetime;
}

public function setAllDay($allDay = false)
{
$this->allDay = (boolean) $allDay;
}

public function getAllDay()
{
return $this->allDay;
}

/**
* @param string $name
* @param string $value
*/
public function addField($name, $value)
{
$this->otherFields[$name] = $value;
}

/**
* @param string $name
*/
public function removeField($name)
{
if (!array_key_exists($name, $this->otherFields)) {
return;
}

unset($this->otherFields[$name]);
}
}

Помимо этого у меня есть CalendarEventListener.php, который отвечает за данные, отправляемые для отображения в календаре:

<?php

namespace AppBundle\EventListener;

use ADesigns\CalendarBundle\Event\CalendarEvent;
use ADesigns\CalendarBundle\Entity\EventEntity;
use Doctrine\ORM\EntityManager;

class CalendarEventListener
{
private $entityManager;

public function __construct(EntityManager $entityManager)
{
$this->entityManager = $entityManager;
}

public function loadEvents(CalendarEvent $calendarEvent)
{
$startDate = $calendarEvent->getStartEventDate();
$endDate = $calendarEvent->getEndEventDate();

// The original request so you can get filters from the calendar
// Use the filter in your query for example

$request = $calendarEvent->getRequest();
$filter = $request->get('filter');// load events using your custom logic here,
// for instance, retrieving events from a repository

$companyEvents = $this->entityManager->getRepository('AppBundle:companyEvents')
->createQueryBuilder('companyEvents')
->where('companyEvents.startEventDate BETWEEN :startEventDate and :endEventDate')
->setParameter('startEventDate', $startDate->format('Y-m-d H:i:s'))
->setParameter('endEventDate', $endDate->format('Y-m-d H:i:s'))
->getQuery()->getResult();

// $companyEvents and $companyEvent in this example
// represent entities from your database, NOT instances of EventEntity
// within this bundle.
//
// Create EventEntity instances and populate it's properties with data
// from your own entities/database values.

foreach($companyEvents as $companyEvent) {$eventEntity = new EventEntity($companyEvent->getEventName(),
//
$companyEvent->getStartEventDate(),
$companyEvent->getEndEventDate()
,null, true);
//optional calendar event settings
$eventEntity->setAllDay(true); // default is false, set to true if this is an all day event
$eventEntity->setBgColor('#3366ff'); //set the background color of the event's label
$eventEntity->setFgColor('#FFFFFF'); //set the foreground color of the event's label
$eventEntity->setUrl('http://www.google.com'); // url to send user to when event label is clicked
$eventEntity->setCssClass('my-custom-class'); // a custom class you may want to apply to event labels

//finally, add the event to the CalendarEvent for displaying on the calendar
$calendarEvent->addEvent($eventEntity);

}
}
}

И компания companyEvents для структурирования событий:

<?php

namespace AppBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Security\Core\User\UserInterface;
use Doctrine\Common\Collections\ArrayCollection;

/**
* @ORM\Entity
* @ORM\Table(name="companyEvents")
*/
class companyEvents
{
/**
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;

/**
* events are created by users
* @ORM\ManyToOne(targetEntity="User", inversedBy="events")
* @ORM\JoinColumn(name="user_id", referencedColumnName="id")
*/
private $user;

/**
* @ORM\Column(name="event_name")
*/
private $eventName;

/**
* @ORM\Column(name="event_date", type="datetime")
*/
private $eventDate;

/**
* @ORM\Column(name="startEventDate", type="datetime")
*/
private $startEventDate;

/**
* @ORM\Column(name="endEventDate", type="datetime")
*/
private $endEventDate;

/**
* Set eventName
*
* @param string $eventName
*
* @return companyEvents
*/
public function setEventName($eventName)
{
$this->eventName = $eventName;

return $this;
}

/**
* Get eventName
*
* @return string
*/
public function getEventName()
{
return $this->eventName;
}

/**
* Set eventDate
*
* @param string $eventDate
*
* @return CompanyEvents
*/
public function setEventDate($eventDate)
{
$this->eventDate = $eventDate;

return $this;
}

/**
* Get eventDate
*
* @return string
*/
public function getEventDate()
{
return $this->eventDate;
}

/**
* Set start event date
* @param string $startEventDate
*
* @return companyEvents
*/
public function setStartEventDate($startEventDate)
{
$this->startEventDate = $startEventDate;

return $this;
}

/**
*Get start event date
* @return string
*/
public function getStartEventDate()
{
return $this->startEventDate;
}

/**
* Set start event date
* @param string $endEventDate
*
* @return companyEvents
*/
public function setEndEventDate($endEventDate)
{
$this->endEventDate = $endEventDate;

return $this;
}

/**
*Get start event date
* @return string
*/
public function getEndEventDate()
{
return $this->endEventDate;
}

/**
* set user relationship
* @param string $user_id
*
* @return companyEvents
*/
public function setUser($user)
{
$this->user = $user;
return $this;
}
/**
* @return string
*/
public function getUser()
{
return $this->user;
}/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}

}

Итак, моя проблема в том, что вместо getEventName передается здесь:

$eventEntity = new EventEntity($companyEvent->getEventName(),
$companyEvent->getStartEventDate(),
$companyEvent->getEndEventDate()
,null, true);

я хочу передать конкретное имя пользователя, которое принадлежит конкретному событию, но когда я изменяю getEventName () (который отображает название события) с помощью любой другой функции (я пытался передать даже user_id из объекта), больше ничего не отображается в календаре без сброса ошибок.

Любые намеки на решение этой проблемы вряд ли будут оценены :)!

0

Решение

Если вы хотите отобразить имя пользователя в заголовке события, вы можете изменить getEventName способ вернуть имя пользователя:

public function getEventName()
{
return $this->user->getUsername();
}

Таким образом, вам не придется менять CalendarEventListener код.

Не забудьте удалить eventName свойство и его метод сеттера из companyEventsюридическое лицо. Вы должны также назвать сущность CamelCased и в единственном числе, как это CompanyEvent,

0

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector