Merge pull request #234 from pangeachat/show-rich-text-fixes

Show rich text fixes
pull/1183/head
ggurdin 2 years ago committed by GitHub
commit a1fa4a2d0b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -38,6 +38,7 @@ class MessageContent extends StatelessWidget {
//further down in the chain is also using pangeaController so its not constant //further down in the chain is also using pangeaController so its not constant
final bool immersionMode; final bool immersionMode;
final ToolbarDisplayController? toolbarController; final ToolbarDisplayController? toolbarController;
final bool isOverlay;
// Pangea# // Pangea#
const MessageContent( const MessageContent(
@ -50,6 +51,7 @@ class MessageContent extends StatelessWidget {
this.pangeaMessageEvent, this.pangeaMessageEvent,
required this.immersionMode, required this.immersionMode,
required this.toolbarController, required this.toolbarController,
this.isOverlay = false,
// Pangea# // Pangea#
required this.borderRadius, required this.borderRadius,
}); });
@ -203,7 +205,8 @@ class MessageContent extends StatelessWidget {
&& &&
!(pangeaMessageEvent?.showRichText( !(pangeaMessageEvent?.showRichText(
selected, selected,
toolbarController?.highlighted ?? false, isOverlay: isOverlay,
highlighted: toolbarController?.highlighted ?? false,
) ?? ) ??
false) false)
// Pangea# // Pangea#
@ -305,7 +308,8 @@ class MessageContent extends StatelessWidget {
); );
if (pangeaMessageEvent?.showRichText( if (pangeaMessageEvent?.showRichText(
selected, selected,
toolbarController?.highlighted ?? false, isOverlay: isOverlay,
highlighted: toolbarController?.highlighted ?? false,
) ?? ) ??
false) { false) {
return PangeaRichText( return PangeaRichText(

@ -80,18 +80,26 @@ class PangeaMessageEvent {
return _latestEdit; return _latestEdit;
} }
bool showRichText(bool selected, bool highlighted) { bool showRichText(
bool selected, {
bool highlighted = false,
bool isOverlay = false,
}) {
if (!_isValidPangeaMessageEvent) { if (!_isValidPangeaMessageEvent) {
return false; return false;
} }
// if (URLFinder.getMatches(event.body).isNotEmpty) {
// return false;
// }
if ([EventStatus.error, EventStatus.sending].contains(_event.status)) { if ([EventStatus.error, EventStatus.sending].contains(_event.status)) {
return false; return false;
} }
if (ownMessage && !selected && !highlighted) return false;
if (isOverlay) return true;
// if ownMessage, don't show rich text if not selected or highlighted
// and don't show is the message is not an overlay
if (ownMessage && ((!selected && !highlighted) || !isOverlay)) {
return false;
}
return true; return true;
} }

@ -134,8 +134,11 @@ class ToolbarDisplayController {
}); });
} }
bool get highlighted => bool get highlighted {
MatrixState.pAnyState.overlay.hashCode.toString() == overlayId; if (overlayId == null) return false;
if (MatrixState.pAnyState.overlay == null) overlayId = null;
return MatrixState.pAnyState.overlay.hashCode.toString() == overlayId;
}
} }
class MessageToolbar extends StatefulWidget { class MessageToolbar extends StatefulWidget {

@ -141,6 +141,7 @@ class OverlayMessage extends StatelessWidget {
pangeaMessageEvent: pangeaMessageEvent, pangeaMessageEvent: pangeaMessageEvent,
immersionMode: immersionMode, immersionMode: immersionMode,
toolbarController: toolbarController, toolbarController: toolbarController,
isOverlay: true,
), ),
if (event.hasAggregatedEvents( if (event.hasAggregatedEvents(
timeline, timeline,

@ -48,28 +48,33 @@ class PangeaRichTextState extends State<PangeaRichText> {
@override @override
void initState() { void initState() {
super.initState(); super.initState();
updateTextSpan(); setTextSpan();
}
void updateTextSpan() {
setState(() {
textSpan = getTextSpan();
});
} }
@override @override
void didUpdateWidget(PangeaRichText oldWidget) { void didUpdateWidget(PangeaRichText oldWidget) {
super.didUpdateWidget(oldWidget); super.didUpdateWidget(oldWidget);
updateTextSpan(); setTextSpan();
}
void _setTextSpan(String newTextSpan) {
widget.toolbarController?.toolbar?.textSelection.setMessageText(
newTextSpan,
);
setState(() {
textSpan = newTextSpan;
});
} }
String getTextSpan() { void setTextSpan() {
if (_fetchingRepresentation == true) { if (_fetchingRepresentation == true) {
return widget.pangeaMessageEvent.body; _setTextSpan(textSpan = widget.pangeaMessageEvent.body);
return;
} }
if (repEvent != null) { if (repEvent != null) {
return repEvent!.text; _setTextSpan(repEvent!.text);
return;
} }
if (widget.pangeaMessageEvent.eventId.contains("webdebug")) { if (widget.pangeaMessageEvent.eventId.contains("webdebug")) {
@ -84,7 +89,6 @@ class PangeaRichTextState extends State<PangeaRichText> {
if (repEvent == null) { if (repEvent == null) {
setState(() => _fetchingRepresentation = true); setState(() => _fetchingRepresentation = true);
widget.pangeaMessageEvent widget.pangeaMessageEvent
.representationByLanguageGlobal( .representationByLanguageGlobal(
langCode: widget.pangeaMessageEvent.messageDisplayLangCode, langCode: widget.pangeaMessageEvent.messageDisplayLangCode,
@ -95,23 +99,17 @@ class PangeaRichTextState extends State<PangeaRichText> {
) )
.then((event) { .then((event) {
repEvent = event; repEvent = event;
widget.toolbarController?.toolbar?.textSelection.setMessageText( _setTextSpan(repEvent?.text ?? widget.pangeaMessageEvent.body);
repEvent?.text ?? widget.pangeaMessageEvent.body,
);
}).whenComplete(() { }).whenComplete(() {
if (mounted) { if (mounted) {
setState(() => _fetchingRepresentation = false); setState(() => _fetchingRepresentation = false);
} }
}); });
return widget.pangeaMessageEvent.body;
_setTextSpan(widget.pangeaMessageEvent.body);
} else { } else {
widget.toolbarController?.toolbar?.textSelection.setMessageText( _setTextSpan(repEvent!.text);
repEvent!.text,
);
setState(() {});
} }
return repEvent!.text;
} }
@override @override
@ -190,7 +188,10 @@ class PangeaRichTextState extends State<PangeaRichText> {
return blur > 0 return blur > 0
? ImageFiltered( ? ImageFiltered(
imageFilter: ImageFilter.blur(sigmaX: blur, sigmaY: blur), imageFilter: ImageFilter.blur(
sigmaX: blur,
sigmaY: blur,
),
child: richText, child: richText,
) )
: richText; : richText;

Loading…
Cancel
Save