View source
<?php
namespace Drupal\photos\Controller;
use Drupal\Component\Utility\Html;
use Drupal\Core\Access\AccessResult;
use Drupal\Core\Asset\LibraryDiscoveryInterface;
use Drupal\Core\Controller\ControllerBase;
use Drupal\Core\Database\Connection;
use Drupal\Core\Entity\EntityTypeManagerInterface;
use Drupal\Core\Link;
use Drupal\Core\Routing\RouteMatchInterface;
use Drupal\Core\Session\AccountInterface;
use Drupal\Core\Url;
use Drupal\photos\PhotosImage;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
class PhotosImageController extends ControllerBase {
protected $connection;
protected $entityTypeManager;
protected $libraryDiscovery;
protected $routeMatch;
public function __construct(Connection $connection, EntityTypeManagerInterface $entity_manager, LibraryDiscoveryInterface $library_discovery, RouteMatchInterface $route_match) {
$this->connection = $connection;
$this->entityTypeManager = $entity_manager;
$this->libraryDiscovery = $library_discovery;
$this->routeMatch = $route_match;
}
public static function create(ContainerInterface $container) {
return new static($container
->get('database'), $container
->get('entity_type.manager'), $container
->get('library.discovery'), $container
->get('current_route_match'));
}
public function getTitle() {
$fid = $this->routeMatch
->getParameter('file');
$title = $this->connection
->query("SELECT title FROM {photos_image} WHERE fid = :fid", [
':fid' => $fid,
])
->fetchField();
return $title;
}
public function access(AccountInterface $account) {
$fid = $this->routeMatch
->getParameter('file');
if (_photos_access('imageView', $fid)) {
return AccessResult::allowed();
}
else {
return AccessResult::forbidden();
}
}
public function contentOverview() {
$fid = $this->routeMatch
->getParameter('file');
$config = $this
->config('photos.settings');
if (!is_numeric($fid)) {
throw new NotFoundHttpException();
}
$photos_image = new PhotosImage($fid);
$image = $photos_image
->load();
if (!$image) {
throw new NotFoundHttpException();
}
$node = $this->entityTypeManager
->getStorage('node')
->load($image->pid);
if (_photos_access('imageEdit', $node)) {
$image->ajax['edit_url'] = Url::fromUri('base:photos/image/' . $image->fid . '/update')
->toString();
$image->links['cover'] = Link::createFromRoute($this
->t('Set to Cover'), 'photos.album.update.cover', [
'node' => $image->pid,
'file' => $fid,
], [
'query' => $this
->getDestinationArray(),
]);
}
$image->class = [
'title_class' => '',
'des_class' => '',
];
$image->id = [
'des_edit' => '',
'title_edit' => '',
];
$edit = _photos_access('imageEdit', $node);
if ($edit) {
$url = Url::fromUri('base:photos/image/' . $image->fid . '/edit', [
'query' => [
'destination' => 'photos/image/' . $image->fid,
],
'attributes' => [
'class' => [
'colorbox-load',
'photos-edit-edit',
],
],
]);
$image->ajax['edit_link'] = Link::fromTextAndUrl($this
->t('Edit'), $url);
$image->class = [
'title_class' => ' jQueryeditable_edit_title',
'des_class' => ' jQueryeditable_edit_des',
];
$image->id = [
'des_edit' => ' id="photos-image-edit-des-' . $image->fid . '"',
'title_edit' => ' id="photos-image-edit-title-' . $image->fid . '"',
];
$jeditable_library = $this->libraryDiscovery
->getLibraryByName('photos', 'photos.jeditable');
}
if (_photos_access('imageDelete', $node)) {
$url = Url::fromUri('base:photos/image/' . $image->fid . '/delete', [
'query' => [
'destination' => 'node/' . $image->pid,
],
'attributes' => [
'class' => [
'colorbox-load',
'photos-edit-delete',
],
],
]);
$image->ajax['del_link'] = Link::fromTextAndUrl($this
->t('Delete'), $url);
}
if ($config
->get('photos_comment')) {
$render_comment = [
'#theme' => 'photos_comment_count',
'#comcount' => $image->comcount,
];
$image->links['comment'] = $render_comment;
}
$pager_type = 'pid';
$pager_id = $image->pid;
$data = isset($image->data) ? unserialize($image->data) : [];
$style_name = isset($data['view_imagesize']) ? $data['view_imagesize'] : $config
->get('photos_display_view_imagesize');
$image->links['pager'] = $photos_image
->pager($pager_id, $pager_type);
$image->view = [
'#theme' => 'photos_image_html',
'#style_name' => $style_name,
'#image' => $image,
'#cache' => [
'tags' => [
'photos:image:' . $fid,
],
],
];
$image->comment['view'] = $photos_image
->comments($image->comcount, $node);
$photos_image_count = $config
->get('photos_image_count');
$image->disable_photos_image_count = $photos_image_count;
if (!$photos_image_count) {
$count = 1;
$this->connection
->update('photos_image')
->fields([
'count' => $count,
])
->expression('count', 'count + :count', [
':count' => $count,
])
->condition('fid', $fid)
->execute();
}
$image->title = Html::escape($image->title);
$image->des = Html::escape($image->des);
$GLOBALS['photos'][$image->fid . '_pid'] = $image->pid;
$image_view = [
'#theme' => 'photos_image_view',
'#image' => $image,
'#display_type' => 'view',
'#cache' => [
'tags' => [
'photos:image:' . $fid,
],
],
];
if ($edit && isset($jeditable_library['js']) && file_exists($jeditable_library['js'][0]['data'])) {
$image_view['#attached']['library'][] = 'photos/photos.jeditable';
}
return $image_view;
}
}