mirror of
https://github.com/Karaka-Management/oms-EventManagement.git
synced 2026-02-04 12:08:40 +00:00
fix #30
This commit is contained in:
parent
cf4e2baede
commit
6884241c44
|
|
@ -68,6 +68,23 @@ class Installer extends InstallerAbstract
|
|||
ADD CONSTRAINT `' . $dbPool->get()->prefix . 'eventmanagement_event_ibfk_2` FOREIGN KEY (`eventmanagement_event_created_by`) REFERENCES `' . $dbPool->get()->prefix . 'account` (`account_id`);'
|
||||
)->execute();
|
||||
|
||||
$dbPool->get()->con->prepare(
|
||||
'CREATE TABLE if NOT EXISTS `' . $dbPool->get()->prefix . 'eventmanagement_event_media` (
|
||||
`eventmanagement_event_media_id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`eventmanagement_event_media_src` int(11) NULL,
|
||||
`eventmanagement_event_media_dst` int(11) NULL,
|
||||
PRIMARY KEY (`eventmanagement_event_media_id`),
|
||||
KEY `eventmanagement_event_media_src` (`eventmanagement_event_media_src`),
|
||||
KEY `eventmanagement_event_media_dst` (`eventmanagement_event_media_dst`)
|
||||
)ENGINE=InnoDB DEFAULT CHARSET=utf8;'
|
||||
)->execute();
|
||||
|
||||
$dbPool->get()->con->prepare(
|
||||
'ALTER TABLE `' . $dbPool->get()->prefix . 'eventmanagement_event_media`
|
||||
ADD CONSTRAINT `' . $dbPool->get()->prefix . 'eventmanagement_event_media_ibfk_1` FOREIGN KEY (`eventmanagement_event_media_src`) REFERENCES `' . $dbPool->get()->prefix . 'eventmanagement_event` (`eventmanagement_event_id`),
|
||||
ADD CONSTRAINT `' . $dbPool->get()->prefix . 'eventmanagement_event_media_ibfk_2` FOREIGN KEY (`eventmanagement_event_media_dst`) REFERENCES `' . $dbPool->get()->prefix . 'media` (`media_id`);'
|
||||
)->execute();
|
||||
|
||||
$dbPool->get()->con->prepare(
|
||||
'CREATE TABLE if NOT EXISTS `' . $dbPool->get()->prefix . 'eventmanagement_task_relation` (
|
||||
`eventmanagement_task_relation_id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
|
|
|
|||
|
|
@ -21,6 +21,7 @@ use phpOMS\Module\WebInterface;
|
|||
use phpOMS\Views\View;
|
||||
use Modules\EventManagement\Models\EventMapper;
|
||||
use Modules\EventManagement\Models\Event;
|
||||
use phpOMS\Asset\AssetType;
|
||||
|
||||
/**
|
||||
* Event Management controller class.
|
||||
|
|
@ -133,6 +134,10 @@ class Controller extends ModuleAbstract implements WebInterface
|
|||
*/
|
||||
public function viewEventManagementProfile(RequestAbstract $request, ResponseAbstract $response, $data = null) : \Serializable
|
||||
{
|
||||
/** @var Head $head */
|
||||
$head = $response->get('Content')->getData('head');
|
||||
$head->addAsset(AssetType::CSS, $request->getUri()->getBase() . 'Modules/Calendar/Theme/Backend/css/styles.css');
|
||||
|
||||
$view = new View($this->app, $request, $response);
|
||||
$view->setTemplate('/Modules/EventManagement/Theme/Backend/eventmanagement-profile');
|
||||
$view->addData('nav', $this->app->moduleManager->get('Navigation')->createNavigationMid(1004201001, $request, $response));
|
||||
|
|
|
|||
|
|
@ -59,6 +59,8 @@ class Event
|
|||
|
||||
private $tasks = [];
|
||||
|
||||
private $media = [];
|
||||
|
||||
private $progress = 0;
|
||||
|
||||
private $progressType = ProgressType::MANUAL;
|
||||
|
|
@ -92,6 +94,16 @@ class Event
|
|||
$this->setName($name);
|
||||
}
|
||||
|
||||
public function getMedia() : array
|
||||
{
|
||||
return $this->media;
|
||||
}
|
||||
|
||||
public function addMedia($media) /* : void */
|
||||
{
|
||||
$this->media[] = $media;
|
||||
}
|
||||
|
||||
public function getStart() : \DateTime
|
||||
{
|
||||
return $this->start;
|
||||
|
|
|
|||
|
|
@ -19,6 +19,7 @@ use phpOMS\DataStorage\Database\Query\Builder;
|
|||
use phpOMS\DataStorage\Database\Query\Column;
|
||||
use phpOMS\DataStorage\Database\RelationType;
|
||||
use Modules\Tasks\Models\TaskMapper;
|
||||
use Modules\Media\Models\MediaMapper;
|
||||
|
||||
/**
|
||||
* Mapper class.
|
||||
|
|
@ -68,6 +69,12 @@ class EventMapper extends DataMapperAbstract
|
|||
'dst' => 'eventmanagement_task_relation_dst',
|
||||
'src' => 'eventmanagement_task_relation_src',
|
||||
],
|
||||
'media' => [ // todo: maybe make this a has one and then link to collection instead of single media files!
|
||||
'mapper' => MediaMapper::class,
|
||||
'table' => 'eventmanagement_event_media',
|
||||
'dst' => 'eventmanagement_event_media_src',
|
||||
'src' => 'eventmanagement_event_media_dst',
|
||||
],
|
||||
];
|
||||
|
||||
/**
|
||||
|
|
|
|||
|
|
@ -82,16 +82,99 @@ echo $this->getData('nav')->render(); ?>
|
|||
</div>
|
||||
|
||||
<div class="row">
|
||||
<div class="col-xs-12 col-md-6">
|
||||
<section class="box wf-100">
|
||||
<header><h1>Calendar</h1></header>
|
||||
</section>
|
||||
</div>
|
||||
<div id="calendar" class="m-calendar m-calendar-mini col-xs-12 col-md-6" draggable="true" data-action='[
|
||||
{
|
||||
"listener": "click", "selector": "#calendar span.tag", "action": [
|
||||
{"key": 1, "type": "dom.popup", "tpl": "calendar-event-popup-tpl", "aniIn": "fadeIn"}
|
||||
]
|
||||
}
|
||||
]'>
|
||||
<div class="box wf-100">
|
||||
<ul class="weekdays green">
|
||||
<li><?= $this->getHtml('Sunday', 'Calendar'); ?>
|
||||
<li><?= $this->getHtml('Monday', 'Calendar'); ?>
|
||||
<li><?= $this->getHtml('Tuesday', 'Calendar'); ?>
|
||||
<li><?= $this->getHtml('Wednesday', 'Calendar'); ?>
|
||||
<li><?= $this->getHtml('Thursday', 'Calendar'); ?>
|
||||
<li><?= $this->getHtml('Friday', 'Calendar'); ?>
|
||||
<li><?= $this->getHtml('Saturday', 'Calendar'); ?>
|
||||
</ul>
|
||||
<?php $current = $event->getCalendar()->getDate()->getMonthCalendar(0); $isActiveMonth = false;
|
||||
for($i = 0; $i < 6; $i++) : ?>
|
||||
<ul class="days">
|
||||
<?php for($j = 0; $j < 7; $j++) :
|
||||
$isActiveMonth = ((int) $current[$i*7+$j]->format('d') === 1) ? !$isActiveMonth : $isActiveMonth;
|
||||
?>
|
||||
<?php if($isActiveMonth) :?>
|
||||
<li class="day<?= $event->getCalendar()->hasEventOnDate($current[$i*7+$j]) ? ' has-event' : '';?>">
|
||||
<div class="date"><?= $current[$i*7+$j]->format('d'); ?></div>
|
||||
<?php else: ?>
|
||||
<li class="day other-month<?= $event->getCalendar()->hasEventOnDate($current[$i*7+$j]) ? ' has-event' : '';?>">
|
||||
<div class="date"><?= $current[$i*7+$j]->format('d'); ?></div>
|
||||
<?php endif; ?>
|
||||
<?php endfor; ?>
|
||||
</li>
|
||||
</ul>
|
||||
<?php endfor;?>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="col-xs-12 col-md-6">
|
||||
<section class="box wf-100">
|
||||
<header><h1>Media</h1></header>
|
||||
</section>
|
||||
<div class="box wf-100">
|
||||
<table class="table blue">
|
||||
<caption><?= $this->getHtml('Media', 'Media') ?></caption>
|
||||
<thead>
|
||||
<td>
|
||||
<td class="wf-100"><?= $this->getHtml('Name', 'Media') ?>
|
||||
<td><?= $this->getHtml('Type', 'Media') ?>
|
||||
<td><?= $this->getHtml('Size', 'Media') ?>
|
||||
<td><?= $this->getHtml('Creator', 'Media') ?>
|
||||
<td><?= $this->getHtml('Created', 'Media') ?>
|
||||
<tfoot>
|
||||
<tbody>
|
||||
<?php $count = 0; $media = $event->getMedia(); foreach($media as $key => $value) : $count++;
|
||||
$url = \phpOMS\Uri\UriFactory::build('{/base}/{/lang}/backend/media/single?{?}&id=' . $value->getId());
|
||||
|
||||
$icon = '';
|
||||
$extensionType = \phpOMS\System\File\FileUtils::getExtensionType($value->getExtension());
|
||||
|
||||
if($extensionType === \phpOMS\System\File\ExtensionType::CODE) {
|
||||
$icon = 'file-code-o';
|
||||
} elseif($extensionType === \phpOMS\System\File\ExtensionType::TEXT) {
|
||||
$icon = 'file-text-o';
|
||||
} elseif($extensionType === \phpOMS\System\File\ExtensionType::PRESENTATION) {
|
||||
$icon = 'file-powerpoint-o';
|
||||
} elseif($extensionType === \phpOMS\System\File\ExtensionType::PDF) {
|
||||
$icon = 'file-pdf-o';
|
||||
} elseif($extensionType === \phpOMS\System\File\ExtensionType::ARCHIVE) {
|
||||
$icon = 'file-zip-o';
|
||||
} elseif($extensionType === \phpOMS\System\File\ExtensionType::AUDIO) {
|
||||
$icon = 'file-audio-o';
|
||||
} elseif($extensionType === \phpOMS\System\File\ExtensionType::VIDEO) {
|
||||
$icon = 'file-video-o';
|
||||
} elseif($extensionType === \phpOMS\System\File\ExtensionType::IMAGE) {
|
||||
$icon = 'file-image-o';
|
||||
} elseif($extensionType === \phpOMS\System\File\ExtensionType::SPREADSHEET) {
|
||||
$icon = 'file-excel-o';
|
||||
} elseif($value->getExtension() === 'collection') {
|
||||
$icon = 'folder-open-o';
|
||||
} else {
|
||||
$icon = 'file-o';
|
||||
}
|
||||
?>
|
||||
<tr data-href="<?= $url; ?>">
|
||||
<td><a href="<?= $url; ?>"><i class="fa fa-<?= $this->printHtml($icon); ?>"></i></a>
|
||||
<td><a href="<?= $url; ?>"><?= $this->printHtml($value->getName()); ?></a>
|
||||
<td><a href="<?= $url; ?>"><?= $this->printHtml($value->getExtension()); ?></a>
|
||||
<td><a href="<?= $url; ?>"><?= $this->printHtml($value->getSize()); ?></a>
|
||||
<td><a href="<?= $url; ?>"><?= $this->printHtml($value->getCreatedBy()->getName1()); ?></a>
|
||||
<td><a href="<?= $url; ?>"><?= $this->printHtml($value->getCreatedAt()->format('Y-m-d H:i:s')); ?></a>
|
||||
<?php endforeach; ?>
|
||||
<?php if($count === 0) : ?>
|
||||
<tr><td colspan="5" class="empty"><?= $this->getHtml('Empty', 0, 0); ?>
|
||||
<?php endif; ?>
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user