finish memos cover
This commit is contained in:
57
app/Http/Controllers/ImageController.php
Normal file
57
app/Http/Controllers/ImageController.php
Normal file
@@ -0,0 +1,57 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Http\Resources\Image as ImageResource;
|
||||
use App\Models\Memo;
|
||||
use App\User;
|
||||
use Illuminate\Http\Request;
|
||||
use Intervention\Image\Facades\Image;
|
||||
|
||||
class ImageController extends Controller
|
||||
{
|
||||
public function users(User $user)
|
||||
{
|
||||
$data = $this->storeImage();
|
||||
|
||||
$newImage = auth()->user()->images()->create([
|
||||
'path' => $data['path'],
|
||||
'width' => $data['width'],
|
||||
'height' => $data['height'],
|
||||
'location' => $data['location'],
|
||||
]);
|
||||
|
||||
return new ImageResource($newImage);
|
||||
}
|
||||
|
||||
public function memos(Memo $memo)
|
||||
{
|
||||
$data = $this->storeImage();
|
||||
|
||||
$newImage = $memo->images()->create([
|
||||
'path' => $data['path'],
|
||||
'width' => $data['width'],
|
||||
'height' => $data['height'],
|
||||
'location' => $data['location'],
|
||||
]);
|
||||
|
||||
return new ImageResource($newImage);
|
||||
}
|
||||
|
||||
private function storeImage() {
|
||||
$data = request()->validate([
|
||||
'image' => 'required',
|
||||
'width' => 'required',
|
||||
'height' => 'required',
|
||||
'location' => 'required',
|
||||
]);
|
||||
|
||||
$data['path'] = $data['image']->store('images', 'public');
|
||||
|
||||
Image::make($data['image'])
|
||||
->fit($data['width'], $data['height'])
|
||||
->save(storage_path('app/public/images/'.$data['image']->hashName()));
|
||||
|
||||
return $data;
|
||||
}
|
||||
}
|
||||
@@ -30,6 +30,11 @@ class UserController extends Controller
|
||||
->setStatusCode(Response::HTTP_CREATED);
|
||||
}
|
||||
|
||||
public function show(User $user)
|
||||
{
|
||||
return New UserResource($user);
|
||||
}
|
||||
|
||||
private function validateData()
|
||||
{
|
||||
return request()->validate([
|
||||
|
||||
33
app/Http/Resources/Image.php
Normal file
33
app/Http/Resources/Image.php
Normal file
@@ -0,0 +1,33 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Resources;
|
||||
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
|
||||
class Image extends JsonResource
|
||||
{
|
||||
/**
|
||||
* Transform the resource into an array.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return array
|
||||
*/
|
||||
public function toArray($request)
|
||||
{
|
||||
return [
|
||||
'data' => [
|
||||
'type' => 'images',
|
||||
'image_id' => $this->id,
|
||||
'attributes' => [
|
||||
'path' => url('storage/'.$this->path),
|
||||
'width' => $this->width,
|
||||
'height' => $this->height,
|
||||
'location' => $this->location,
|
||||
]
|
||||
],
|
||||
'links' => [
|
||||
'self' => url('/images/'.$this->id),
|
||||
]
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -2,6 +2,8 @@
|
||||
|
||||
namespace App\Http\Resources;
|
||||
|
||||
use App\Http\Resources\Image as ImageResource;
|
||||
use App\Http\Resources\User as UserResource;
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
|
||||
class Memo extends JsonResource
|
||||
@@ -16,10 +18,15 @@ class Memo extends JsonResource
|
||||
{
|
||||
return [
|
||||
'data' => [
|
||||
'type' => 'memos',
|
||||
'memo_id' => $this->id,
|
||||
'name' => $this->name,
|
||||
'memo' => $this->memo,
|
||||
'last_updated' => $this->updated_at->diffForHumans(),
|
||||
'attributes' => [
|
||||
'posted_by' => new UserResource($this->user),
|
||||
'cover_image' => new ImageResource($this->coverImage),
|
||||
]
|
||||
//'tags' => TagResource::collection($this->tags),
|
||||
],
|
||||
'links' => [
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
namespace App\Http\Resources;
|
||||
|
||||
use App\Http\Resources\Image as ImageResource;
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
|
||||
class User extends JsonResource
|
||||
@@ -21,6 +22,8 @@ class User extends JsonResource
|
||||
'attributes' => [
|
||||
'name' => $this->name,
|
||||
'email' => $this->email,
|
||||
'profile_image' => new ImageResource($this->profileImage),
|
||||
'cover_image' => new ImageResource($this->coverImage),
|
||||
'last_login' => optional($this->login_at)->diffForHumans(),
|
||||
'is_admin' => $this->isAdmin(),
|
||||
],
|
||||
|
||||
Reference in New Issue
Block a user