File: //proc/self/cwd/sabbry/source/App/Admin/Blog.php
<?php
namespace Source\App\Admin;
use Source\Models\Category;
use Source\Models\Gallery;
use Source\Models\Post;
use Source\Models\User;
use Source\Support\Pager;
use Source\Support\Thumb;
use Source\Support\Upload;
/**
* Class Blog
* @package Source\App\Admin
*/
class Blog extends Admin
{
/**
* Blog constructor.
*/
public function __construct($router)
{
parent::__construct();
$this->view->addData("router", $router);
}
/**
* @param array|null $data
*/
public function home(?array $data): void
{
//search redirect
if (!empty($data["s"])) {
$s = str_search($data["s"]);
echo json_encode(["redirect" => url("/admin/blog/home/{$s}/1")]);
return;
}
$search = null;
$posts = (new Post())->find();
if (!empty($data["search"]) && str_search($data["search"]) != "all") {
$search = str_search($data["search"]);
$posts = (new Post())->find("MATCH(title, subtitle) AGAINST(:s)", "s={$search}");
if (!$posts->count()) {
$this->message->info("Sua pesquisa não retornou resultados")->flash();
redirect("/admin/blog/home");
}
}
$all = ($search ?? "all");
$pager = new Pager(url("/admin/blog/home/{$all}/"));
$pager->pager($posts->count(), 12, (!empty($data["page"]) ? $data["page"] : 1));
$head = $this->seo->render(
CONF_SITE_NAME . " | Blog",
CONF_SITE_DESC,
url("/admin"),
url("/admin/assets/images/image.jpg"),
false
);
echo $this->view->render("widgets/blog/home", [
"app" => "blog/post",
"head" => $head,
"posts" => $posts->limit($pager->limit())->offset($pager->offset())->order("post_at DESC")->fetch(true),
"paginator" => $pager->render(),
"search" => $search
]);
}
/**
* @param array|null $data
* @throws \Exception
*/
public function post(?array $data): void
{
//MCE Upload
if (!empty($data["upload"]) && !empty($_FILES["image"])) {
$files = $_FILES["image"];
$upload = new Upload();
$image = $upload->image($files, "post-" . time());
if (!$image) {
$json["message"] = $upload->message()->render();
echo json_encode($json);
return;
}
$json["mce_image"] = '<img style="width: 100%;" src="' . url("/storage/{$image}") . '" alt="{title}" title="{title}">';
echo json_encode($json);
return;
}
//create
if (!empty($data["action"]) && $data["action"] == "create") {
$content = $data["content"];
$data = filter_var_array($data, FILTER_SANITIZE_STRIPPED);
$postCreate = new Post();
$postCreate->author = $data["author"];
$postCreate->category = $data["category"];
$postCreate->title = $data["title"];
$postCreate->uri = str_slug($postCreate->title);
$postCreate->subtitle = $data["subtitle"];
$postCreate->content = str_replace(["{title}"], [$postCreate->title], $content);
$postCreate->video = $data["video"];
$postCreate->status = $data["status"];
$postCreate->post_at = date_fmt_back($data["post_at"]);
$postCreate->gallery_link = gallery_id();
//upload cover
if (!empty($_FILES["cover"])) {
$files = $_FILES["cover"];
$upload = new Upload();
$image = $upload->image($files, $postCreate->title);
if (!$image) {
$json["message"] = $upload->message()->render();
echo json_encode($json);
return;
}
$postCreate->cover = $image;
}
//upload Gallery
if (!empty($_FILES["gallery"])) {
$files = $_FILES["gallery"];
$gal = new Upload();
if(!$gal->gallery($files, $postCreate->title, 1200, "posts", $postCreate->gallery_link)){
$json["message"] = $gal->message()->render();
echo json_encode($json);
return;
}
}
if (!$postCreate->save()) {
$json["message"] = $postCreate->message()->render();
echo json_encode($json);
return;
}
$this->message->success("Post publicado com sucesso...")->flash();
$json["redirect"] = url("/admin/blog/post/{$postCreate->id}");
echo json_encode($json);
return;
}
//update
if (!empty($data["action"]) && $data["action"] == "update") {
$content = $data["content"];
$data = filter_var_array($data, FILTER_SANITIZE_STRIPPED);
$postEdit = (new Post())->findById($data["post_id"]);
if (!$postEdit) {
$this->message->error("Você tentou atualizar um post que não existe ou foi removido")->flash();
echo json_encode(["redirect" => url("/admin/blog/home")]);
return;
}
$postEdit->author = $data["author"];
$postEdit->category = $data["category"];
$postEdit->title = $data["title"];
$postEdit->uri = str_slug($postEdit->title);
$postEdit->subtitle = $data["subtitle"];
$postEdit->content = str_replace(["{title}"], [$postEdit->title], $content);
$postEdit->video = $data["video"];
$postEdit->status = $data["status"];
$postEdit->post_at = date_fmt_back($data["post_at"]);
//upload cover
if (!empty($_FILES["cover"])) {
if ($postEdit->cover && file_exists(__DIR__ . "/../../../" . CONF_UPLOAD_DIR . "/{$postEdit->cover}")) {
unlink(__DIR__ . "/../../../" . CONF_UPLOAD_DIR . "/{$postEdit->cover}");
(new Thumb())->flush($postEdit->cover);
}
$files = $_FILES["cover"];
$upload = new Upload();
$image = $upload->image($files, $postEdit->title);
if (!$image) {
$json["message"] = $upload->message()->render();
echo json_encode($json);
return;
}
$postEdit->cover = $image;
}
//upload Gallery
if (!empty($_FILES["gallery"])) {
$files = $_FILES["gallery"];
$gal = new Upload();
if(!$gal->gallery($files, $postEdit->title, 1200, "posts", $postEdit->gallery_link)){
$json["message"] = $gal->message()->render();
echo json_encode($json);
return;
}
}
if (!$postEdit->save()) {
$json["message"] = $postEdit->message()->render();
echo json_encode($json);
return;
}
$this->message->success("Post atualizado com sucesso...")->flash();
echo json_encode(["redirect" => url("/admin/blog/home")]);
return;
}
//delete
if (!empty($data["action"]) && $data["action"] == "delete") {
$data = filter_var_array($data, FILTER_SANITIZE_STRIPPED);
$postDelete = (new Post())->findById($data["post_id"]);
if (!$postDelete) {
$this->message->error("Você tentou excluir um post que não existe ou já foi removido")->flash();
echo json_encode(["reload" => true]);
return;
}
if ($postDelete->cover && file_exists(__DIR__ . "/../../../" . CONF_UPLOAD_DIR . "/{$postDelete->cover}")) {
unlink(__DIR__ . "/../../../" . CONF_UPLOAD_DIR . "/{$postDelete->cover}");
(new Thumb())->flush($postDelete->cover);
}
(new Gallery())->galDelete($postDelete->gallery_link);
$postDelete->destroy();
$this->message->success("O post foi excluído com sucesso...")->flash();
echo json_encode(["reload" => true]);
return;
}
$postEdit = null;
if (!empty($data["post_id"])) {
$postId = filter_var($data["post_id"], FILTER_VALIDATE_INT);
$postEdit = (new Post())->findById($postId);
}
$head = $this->seo->render(
CONF_SITE_NAME . " | " . ($postEdit->title ?? "Novo Artigo"),
CONF_SITE_DESC,
url("/admin"),
url("/admin/assets/images/image.jpg"),
false
);
echo $this->view->render("widgets/blog/post", [
"app" => "blog/post",
"head" => $head,
"post" => $postEdit,
"categories" => (new Category())->find("type = :type", "type=post")->order("title")->fetch(true),
"gallery" => (new Gallery())->find("gallery_link IN (SELECT gallery_link FROM posts WHERE id = :id)", "id={$postEdit->id}")->fetch(true),
"authors" => (new User())->find("level >= :level", "level=5")->fetch(true)
]);
}
/**
* @param array|null $data
*/
public function categories(?array $data): void
{
$categories = (new Category())->find("type = :type", "type=post");
$pager = new Pager(url("/admin/blog/categories/"));
$pager->pager($categories->count(), 9, (!empty($data["page"]) ? $data["page"] : 1));
$head = $this->seo->render(
CONF_SITE_NAME . " | Categorias",
CONF_SITE_DESC,
url("/admin"),
url("/admin/assets/images/image.jpg"),
false
);
echo $this->view->render("widgets/blog/categories", [
"app" => "blog/categories",
"head" => $head,
"categories" => $categories->order("title")->limit($pager->limit())->offset($pager->offset())->fetch(true),
"paginator" => $pager->render()
]);
}
/**
* @param array|null $data
* @throws \Exception
*/
public function category(?array $data): void
{
//create
if (!empty($data["action"]) && $data["action"] == "create") {
$data = filter_var_array($data, FILTER_SANITIZE_STRIPPED);
$categoryCreate = new Category();
$categoryCreate->title = $data["title"];
$categoryCreate->uri = str_slug($categoryCreate->title);
$categoryCreate->description = $data["description"];
$categoryCreate->type = "post";
//upload cover
if (!empty($_FILES["cover"])) {
$files = $_FILES["cover"];
$upload = new Upload();
$image = $upload->image($files, $categoryCreate->title);
if (!$image) {
$json["message"] = $upload->message()->render();
echo json_encode($json);
return;
}
$categoryCreate->cover = $image;
}
if (!$categoryCreate->save()) {
$json["message"] = $categoryCreate->message()->render();
echo json_encode($json);
return;
}
$this->message->success("Categoria criada com sucesso...")->flash();
$json["redirect"] = url("/admin/blog/categories");
echo json_encode($json);
return;
}
//update
if (!empty($data["action"]) && $data["action"] == "update") {
$data = filter_var_array($data, FILTER_SANITIZE_STRIPPED);
$categoryEdit = (new Category())->findById($data["category_id"]);
if (!$categoryEdit) {
$this->message->error("Você tentou editar uma categoria que não existe ou foi removida")->flash();
echo json_encode(["redirect" => url("/admin/blog/categories")]);
return;
}
$categoryEdit->title = $data["title"];
$categoryEdit->uri = str_slug($categoryEdit->title);
$categoryEdit->description = $data["description"];
//upload cover
if (!empty($_FILES["cover"])) {
if ($categoryEdit->cover && file_exists(__DIR__ . "/../../../" . CONF_UPLOAD_DIR . "/{$categoryEdit->cover}")) {
unlink(__DIR__ . "/../../../" . CONF_UPLOAD_DIR . "/{$categoryEdit->cover}");
(new Thumb())->flush($categoryEdit->cover);
}
$files = $_FILES["cover"];
$upload = new Upload();
$image = $upload->image($files, $categoryEdit->title);
if (!$image) {
$json["message"] = $upload->message()->render();
echo json_encode($json);
return;
}
$categoryEdit->cover = $image;
}
if (!$categoryEdit->save()) {
$json["message"] = $categoryEdit->message()->render();
echo json_encode($json);
return;
}
$this->message->success("Categoria atualizada com sucesso...")->flash();
echo json_encode(["redirect" => url("/admin/blog/categories")]);
return;
}
//delete
if (!empty($data["action"]) && $data["action"] == "delete") {
$data = filter_var_array($data, FILTER_SANITIZE_STRIPPED);
$categoryDelete = (new Category())->findById($data["category_id"]);
if (!$categoryDelete) {
$json["message"] = $this->message->error("A categoria não existe ou já foi excluída antes")->render();
echo json_encode($json);
return;
}
if ($categoryDelete->posts()->count()) {
$json["message"] = $this->message->warning("Não é possível remover pois existem posts cadastrados")->render();
echo json_encode($json);
return;
}
if ($categoryDelete->cover && file_exists(__DIR__ . "/../../../" . CONF_UPLOAD_DIR . "/{$categoryDelete->cover}")) {
unlink(__DIR__ . "/../../../" . CONF_UPLOAD_DIR . "/{$categoryDelete->cover}");
(new Thumb())->flush($categoryDelete->cover);
}
$categoryDelete->destroy();
$this->message->success("A categoria foi excluída com sucesso...")->flash();
echo json_encode(["reload" => true]);
return;
}
$categoryEdit = null;
if (!empty($data["category_id"])) {
$categoryId = filter_var($data["category_id"], FILTER_VALIDATE_INT);
$categoryEdit = (new Category())->findById($categoryId);
}
$head = $this->seo->render(
CONF_SITE_NAME . " | Categoria",
CONF_SITE_DESC,
url("/admin"),
url("/admin/assets/images/image.jpg"),
false
);
echo $this->view->render("widgets/blog/category", [
"app" => "blog/categories",
"head" => $head,
"category" => $categoryEdit
]);
}
}