mirror of
https://github.com/NicolasConstant/sengi
synced 2025-01-24 07:22:50 +01:00
fix #60
This commit is contained in:
parent
5b03f9d1d7
commit
eb552028b0
@ -1,4 +1,8 @@
|
||||
<div class="stream-toots flexcroll" #statusstream (scroll)="onScroll()">
|
||||
<div class="stream-toots__remove-cw" *ngIf="isThread && hasContentWarnings">
|
||||
<button class="stream-toots__remove-cw--button" (click)="removeCw()"
|
||||
title="remove content warnings">Remove CWs</button>
|
||||
</div>
|
||||
<div *ngIf="displayError" class="stream-toots__error">{{displayError}}</div>
|
||||
|
||||
<!-- data-simplebar -->
|
||||
|
@ -1,19 +1,48 @@
|
||||
@import "variables";
|
||||
@import "commons";
|
||||
|
||||
@import "mixins";
|
||||
.stream-toots {
|
||||
height: calc(100%);
|
||||
width: calc(100%);
|
||||
|
||||
overflow: auto;
|
||||
|
||||
&__error {
|
||||
padding: 20px 20px 0 20px;
|
||||
color: rgb(255, 113, 113);
|
||||
}
|
||||
|
||||
&__status:not(:last-child) {
|
||||
border: solid #06070b;
|
||||
border-width: 0 0 1px 0;
|
||||
}
|
||||
&__remove-cw {
|
||||
padding: 5px;
|
||||
// border: solid #06070b;
|
||||
// border-width: 0 0 1px 0;
|
||||
height: 45px;
|
||||
// width: calc(100%);
|
||||
// position: relative;
|
||||
|
||||
&--button {
|
||||
@include clearButton;
|
||||
position: absolute;
|
||||
z-index: 10;
|
||||
padding: 3px;
|
||||
text-align: center;
|
||||
border: 2px $status-secondary-color dashed;
|
||||
width: calc(80%);
|
||||
margin-left: 40%;
|
||||
transform: translateX(-40%);
|
||||
transition: all .2s;
|
||||
background-color: $color-secondary;
|
||||
|
||||
&:hover{
|
||||
$hover-color: rgb(0, 206, 27);
|
||||
$hover-color: rgb(0, 231, 231);
|
||||
$hover-color: rgb(164, 222, 255);
|
||||
// $hover-color: $status-secondary-color;
|
||||
background-color: $hover-color;
|
||||
color: black;
|
||||
border: 3px $hover-color dashed;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
@ -21,6 +21,7 @@ export class StreamStatusesComponent implements OnInit, OnDestroy {
|
||||
isLoading = true;
|
||||
isThread = false;
|
||||
displayError: string;
|
||||
hasContentWarnings = false;
|
||||
|
||||
private _streamElement: StreamElement;
|
||||
private account: AccountInfo;
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';
|
||||
import { Component, OnInit, Input, Output, EventEmitter, ViewChildren, QueryList } from '@angular/core';
|
||||
import { HttpErrorResponse } from '@angular/common/http';
|
||||
|
||||
import { MastodonService } from '../../../services/mastodon.service';
|
||||
@ -7,6 +7,7 @@ import { Results, Context, Status } from '../../../services/models/mastodon.inte
|
||||
import { NotificationService } from '../../../services/notification.service';
|
||||
import { AccountInfo } from '../../../states/accounts.state';
|
||||
import { StatusWrapper } from '../../../models/common.model';
|
||||
import { StatusComponent } from '../status/status.component';
|
||||
|
||||
@Component({
|
||||
selector: 'app-thread',
|
||||
@ -18,6 +19,7 @@ export class ThreadComponent implements OnInit {
|
||||
displayError: string;
|
||||
isLoading = true;
|
||||
isThread = true;
|
||||
hasContentWarnings = false;
|
||||
|
||||
private lastThreadEvent: OpenThreadEvent;
|
||||
|
||||
@ -33,6 +35,8 @@ export class ThreadComponent implements OnInit {
|
||||
}
|
||||
}
|
||||
|
||||
@ViewChildren(StatusComponent) statusChildren: QueryList<StatusComponent>;
|
||||
|
||||
constructor(
|
||||
private readonly notificationService: NotificationService,
|
||||
private readonly toolsService: ToolsService,
|
||||
@ -86,6 +90,8 @@ export class ThreadComponent implements OnInit {
|
||||
const wrapper = new StatusWrapper(s, currentAccount);
|
||||
this.statuses.push(wrapper);
|
||||
}
|
||||
|
||||
this.hasContentWarnings = this.statuses.filter(x => x.status.sensitive || x.status.spoiler_text).length > 1;
|
||||
});
|
||||
|
||||
})
|
||||
@ -119,4 +125,12 @@ export class ThreadComponent implements OnInit {
|
||||
browseThread(openThreadEvent: OpenThreadEvent): void {
|
||||
this.browseThreadEvent.next(openThreadEvent);
|
||||
}
|
||||
|
||||
removeCw(){
|
||||
const statuses = this.statusChildren.toArray();
|
||||
statuses.forEach(x => {
|
||||
x.removeContentWarning();
|
||||
});
|
||||
this.hasContentWarnings = false;
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user