mirror of
https://github.com/pixelfed/pixelfed.git
synced 2024-12-20 12:03:16 +00:00
Merge pull request #452 from pixelfed/frontend-ui-refactor
Frontend ui refactor
This commit is contained in:
commit
eb641d25b4
4 changed files with 37 additions and 3 deletions
|
@ -23,7 +23,6 @@ class DiscoverController extends Controller
|
||||||
|
|
||||||
$following = Follower::whereProfileId($pid)
|
$following = Follower::whereProfileId($pid)
|
||||||
->pluck('following_id');
|
->pluck('following_id');
|
||||||
|
|
||||||
$filtered = UserFilter::whereUserId($pid)
|
$filtered = UserFilter::whereUserId($pid)
|
||||||
->whereFilterableType('App\Profile')
|
->whereFilterableType('App\Profile')
|
||||||
->whereIn('filter_type', ['mute', 'block'])
|
->whereIn('filter_type', ['mute', 'block'])
|
||||||
|
@ -36,10 +35,12 @@ class DiscoverController extends Controller
|
||||||
|
|
||||||
$people = Profile::inRandomOrder()
|
$people = Profile::inRandomOrder()
|
||||||
->whereNotIn('id', $following)
|
->whereNotIn('id', $following)
|
||||||
|
->whereIsPrivate(false)
|
||||||
->take(3)
|
->take(3)
|
||||||
->get();
|
->get();
|
||||||
|
|
||||||
$posts = Status::whereHas('media')
|
$posts = Status::whereHas('media')
|
||||||
|
->whereVisibility('public')
|
||||||
->where('profile_id', '!=', $pid)
|
->where('profile_id', '!=', $pid)
|
||||||
->whereNotIn('profile_id', $following)
|
->whereNotIn('profile_id', $following)
|
||||||
->orderBy('created_at', 'desc')
|
->orderBy('created_at', 'desc')
|
||||||
|
|
|
@ -62,6 +62,7 @@ class ProfileController extends Controller
|
||||||
->whereHas('media')
|
->whereHas('media')
|
||||||
->whereNull('in_reply_to_id')
|
->whereNull('in_reply_to_id')
|
||||||
->whereNull('reblog_of_id')
|
->whereNull('reblog_of_id')
|
||||||
|
->whereIn('visibility', ['public', 'unlisted'])
|
||||||
->orderBy('created_at', 'desc')
|
->orderBy('created_at', 'desc')
|
||||||
->withCount(['comments', 'likes'])
|
->withCount(['comments', 'likes'])
|
||||||
->simplePaginate(21);
|
->simplePaginate(21);
|
||||||
|
@ -131,10 +132,10 @@ class ProfileController extends Controller
|
||||||
$blocked = $this->blockedProfileCheck($profile);
|
$blocked = $this->blockedProfileCheck($profile);
|
||||||
$check = $this->privateProfileCheck($profile, null);
|
$check = $this->privateProfileCheck($profile, null);
|
||||||
if($check || $blocked) {
|
if($check || $blocked) {
|
||||||
return view('profile.private', compact('user'));
|
return redirect($profile->url());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$items = $profile->statuses()->orderBy('created_at', 'desc')->take(10)->get();
|
$items = $profile->statuses()->whereIn('visibility',['public', 'unlisted'])->orderBy('created_at', 'desc')->take(10)->get();
|
||||||
return response()->view('atom.user', compact('profile', 'items'))
|
return response()->view('atom.user', compact('profile', 'items'))
|
||||||
->header('Content-Type', 'application/atom+xml');
|
->header('Content-Type', 'application/atom+xml');
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,16 @@ class StatusController extends Controller
|
||||||
->withCount(['likes', 'comments', 'media'])
|
->withCount(['likes', 'comments', 'media'])
|
||||||
->findOrFail($id);
|
->findOrFail($id);
|
||||||
|
|
||||||
|
if($status->visibility == 'private' || $user->is_private) {
|
||||||
|
if(!Auth::check()) {
|
||||||
|
abort(403);
|
||||||
|
}
|
||||||
|
$pid = Auth::user()->profile;
|
||||||
|
if($user->followedBy($pid) == false && $user->id !== $pid->id) {
|
||||||
|
abort(403);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ($request->wantsJson() && config('pixelfed.activitypub_enabled')) {
|
if ($request->wantsJson() && config('pixelfed.activitypub_enabled')) {
|
||||||
return $this->showActivityPub($request, $status);
|
return $this->showActivityPub($request, $status);
|
||||||
}
|
}
|
||||||
|
@ -80,6 +90,7 @@ class StatusController extends Controller
|
||||||
'cw' => 'nullable|string',
|
'cw' => 'nullable|string',
|
||||||
'filter_class' => 'nullable|string',
|
'filter_class' => 'nullable|string',
|
||||||
'filter_name' => 'nullable|string',
|
'filter_name' => 'nullable|string',
|
||||||
|
'visibility' => 'required|string|min:5|max:10',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
if (count($request->file('photo')) > config('pixelfed.max_album_length')) {
|
if (count($request->file('photo')) > config('pixelfed.max_album_length')) {
|
||||||
|
@ -89,11 +100,13 @@ class StatusController extends Controller
|
||||||
$monthHash = hash('sha1', date('Y').date('m'));
|
$monthHash = hash('sha1', date('Y').date('m'));
|
||||||
$userHash = hash('sha1', $user->id.(string) $user->created_at);
|
$userHash = hash('sha1', $user->id.(string) $user->created_at);
|
||||||
$profile = $user->profile;
|
$profile = $user->profile;
|
||||||
|
$visibility = $this->validateVisibility($request->visibility);
|
||||||
|
|
||||||
$status = new Status();
|
$status = new Status();
|
||||||
$status->profile_id = $profile->id;
|
$status->profile_id = $profile->id;
|
||||||
$status->caption = strip_tags($request->caption);
|
$status->caption = strip_tags($request->caption);
|
||||||
$status->is_nsfw = $cw;
|
$status->is_nsfw = $cw;
|
||||||
|
$status->visibility = $visibility;
|
||||||
|
|
||||||
$status->save();
|
$status->save();
|
||||||
|
|
||||||
|
@ -252,4 +265,10 @@ class StatusController extends Controller
|
||||||
abort(403);
|
abort(403);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function validateVisibility($visibility)
|
||||||
|
{
|
||||||
|
$allowed = ['public', 'unlisted', 'private'];
|
||||||
|
return in_array($visibility, $allowed) ? $visibility : 'public';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,6 +31,19 @@
|
||||||
</button>
|
</button>
|
||||||
<div class="collapse" id="collapsePreview">
|
<div class="collapse" id="collapsePreview">
|
||||||
<div class="form-group pt-3">
|
<div class="form-group pt-3">
|
||||||
|
<label class="font-weight-bold text-muted small">Visibility</label>
|
||||||
|
<div class="switch switch-sm">
|
||||||
|
<select class="form-control" name="visibility">
|
||||||
|
<option value="public" selected="">Public</option>
|
||||||
|
<option value="unlisted">Unlisted (hidden from public timelines)</option>
|
||||||
|
<option value="private">Followers Only</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<small class="form-text text-muted">
|
||||||
|
Set the visibility of this post.
|
||||||
|
</small>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
<label class="font-weight-bold text-muted small">CW/NSFW</label>
|
<label class="font-weight-bold text-muted small">CW/NSFW</label>
|
||||||
<div class="switch switch-sm">
|
<div class="switch switch-sm">
|
||||||
<input type="checkbox" class="switch" id="cw-switch" name="cw">
|
<input type="checkbox" class="switch" id="cw-switch" name="cw">
|
||||||
|
|
Loading…
Reference in a new issue