Restricted Profiles (#1581)
* Added ReadingList age rating from all series and started on some unit tests for the new flows. * Wrote more unit tests for Reading Lists * Added ability to restrict user accounts to a given age rating via admin edit user modal and invite user. This commit contains all basic code, but no query modifications. * When updating a reading list's title via UI, explicitly check if there is an existing RL with the same title. * Refactored Reading List calculation to work properly in the flows it's invoked from. * Cleaned up an unused method * Promoted Collections no longer show tags where a Series exists within them that is above the user's age rating. * Collection search now respects age restrictions * Series Detail page now checks if the user has explicit access (as a user might bypass with direct url access) * Hooked up age restriction for dashboard activity streams. * Refactored some methods from Series Controller and Library Controller to a new Search Controller to keep things organized * Updated Search to respect age restrictions * Refactored all the Age Restriction queries to extensions * Related Series no longer show up if they are out of the age restriction * Fixed a bad mapping for the update age restriction api * Fixed a UI state change after updating age restriction * Fixed unit test * Added a migration for reading lists * Code cleanup
This commit is contained in:
parent
0ad1638ec0
commit
442af965c6
63 changed files with 4638 additions and 262 deletions
|
|
@ -0,0 +1,19 @@
|
|||
<ng-container *ngIf="restrictionForm">
|
||||
<ng-container *ngIf="showContext">
|
||||
<h4>Age Rating Restriction</h4>
|
||||
<p>When selected, all series and reading lists that have at least one item that is greater than the selected restriction will be pruned from results.
|
||||
<ng-container *ngIf="isAdmin">This is not applicable for admins.</ng-container>
|
||||
</p>
|
||||
</ng-container>
|
||||
<form [formGroup]="restrictionForm">
|
||||
<div class="mb-3">
|
||||
<label for="age-rating" class="form-label visually-hidden">Age Rating</label>
|
||||
<div class="input-group">
|
||||
<select class="form-select"id="age-rating" formControlName="ageRating">
|
||||
<option value="-1">No Restriction</option>
|
||||
<option *ngFor="let opt of ageRatings" [value]="opt.value">{{opt.title | titlecase}}</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</ng-container>
|
||||
Loading…
Add table
Add a link
Reference in a new issue