Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F2578105
EventView.qml
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Award Token
Flag For Later
Size
4 KB
Referenced Files
None
Subscribers
None
EventView.qml
View Options
/*
* This file is part of kazv.
* SPDX-FileCopyrightText: 2020-2023 tusooa <tusooa@kazv.moe>
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
import
QtQuick
2.2
import
QtQuick
.
Layouts
1.15
import
QtQuick
.
Controls
2.15
import
Qt
.
labs
.
qmlmodels
1.0
import
org
.
kde
.
kirigami
2.13
as
Kirigami
import
'event-types'
as
Types
Item
{
id: eventView
property
var
event
property
var
sender
property
var
stateKeyUser
property
var
messageType:
getMessageType
(
event
)
property
var
iconSize:
Kirigami
.
Units
.
iconSizes
.
large
property
var
inlineBadgeSize:
Kirigami
.
Units
.
iconSizes
.
smallMedium
property
var
senderNameSize:
Kirigami
.
Units
.
gridUnit
*
1.2
property
var
redactPromise:
null
property
var
minHeight:
Kirigami
.
Units
.
gridUnit
*
2
property
var
isGapped:
false
property
var
compactMode:
false
property
var
calculatedHeight:
(
gappedLabel
.
visible
?
gappedLabel.height :
0
)
+
(
loader
.
item
?
loader.item.implicitHeight :
0
)
height:
calculatedHeight
implicitHeight:
calculatedHeight
Layout.minimumHeight:
calculatedHeight
Layout.preferredHeight:
calculatedHeight
Component
{
id: textEV
Types
.
Text
{
event:
eventView
.
event
sender:
eventView
.
sender
}
}
Component
{
id: emoteEV
Types
.
Emote
{
event:
eventView
.
event
sender:
eventView
.
sender
}
}
Component
{
id: noticeEV
Types
.
Notice
{
event:
eventView
.
event
sender:
eventView
.
sender
}
}
Component
{
id: stateEV
Types
.
State
{
event:
eventView
.
event
sender:
eventView
.
sender
stateKeyUser:
eventView
.
stateKeyUser
}
}
Component
{
id: imageEV
Types
.
Image
{
event:
eventView
.
event
sender:
eventView
.
sender
}
}
Component
{
id: fileEV
Types
.
File
{
event:
eventView
.
event
sender:
eventView
.
sender
}
}
Component
{
id: videoEV
Types
.
Video
{
event:
eventView
.
event
sender:
eventView
.
sender
}
}
Component
{
id: audioEV
Types
.
Audio
{
event:
eventView
.
event
sender:
eventView
.
sender
}
}
Component
{
id: unknownEV
Label
{
text:
'unknown event'
}
}
Component
{
id: redactedEV
Types
.
Redacted
{
event:
eventView
.
event
sender:
eventView
.
sender
}
}
Component
{
id: reactionEV
Types
.
Reaction
{
event:
eventView
.
event
sender:
eventView
.
sender
}
}
Component
{
id: ignoreEV
Item
{
}
}
ToolButton
{
id: gappedLabel
visible:
eventView
.
isGapped
icon.name:
'content-loading-symbolic'
text:
l10n
.
get
(
'room-timeline-load-more-action'
)
anchors.top:
eventView
.
top
anchors.bottom:
loader
.
top
anchors.left:
eventView
.
left
anchors.right:
eventView
.
right
onClicked:
eventView
.
paginateBack
()
}
Loader
{
sourceComponent:
getSource
(
messageType
)
id: loader
anchors.left:
eventView
.
left
anchors.right:
eventView
.
right
anchors.bottom:
eventView
.
bottom
}
function
getSource
(
t
)
{
switch
(
t
)
{
case
'text'
:
return
textEV
;
case
'emote'
:
return
emoteEV
;
case
'notice'
:
return
noticeEV
;
case
'state'
:
return
stateEV
;
case
'image'
:
return
imageEV
;
case
'file'
:
return
fileEV
;
case
'video'
:
return
videoEV
;
case
'audio'
:
return
audioEV
;
case
'redacted'
:
return
redactedEV
;
case
'reaction'
:
return
reactionEV
;
case
'ignore'
:
return
ignoreEV
;
default:
return
unknownEV
;
}
}
function
getMessageType
(
e
)
{
if
(
e
.
redacted
)
{
return
'redacted'
;
}
if
(
e
.
isState
)
{
return
'state'
;
}
switch
(
e
.
type
)
{
case
'm.room.message'
:
switch
(
e
.
content
.
msgtype
)
{
case
'm.text'
:
return
'text'
;
case
'm.emote'
:
return
'emote'
;
case
'm.notice'
:
return
'notice'
;
case
'm.image'
:
return
'image'
;
case
'm.file'
:
return
'file'
;
case
'm.audio'
:
return
'audio'
;
case
'm.video'
:
return
'video'
;
case
'm.location'
:
return
'location'
;
default:
console
.
log
(
'msg type=unknown'
);
return
'unknown'
;
}
case
'm.room.redaction'
:
return
'ignore'
;
case
'm.reaction'
:
return
'reaction'
;
default:
return
'unknown'
;
}
}
function
redactSelf
(
reason
)
{
eventView
.
redactPromise
=
room
.
redactEvent
(
eventView
.
event
.
eventId
,
reason
);
}
Connections
{
target:
eventView
.
redactPromise
function
onResolved
(
success
,
data
)
{
if
(
!
success
)
{
showPassiveNotification
(
l10n
.
get
(
'event-delete-failed'
,
{
errorMsg:
data
.
error
,
errorCode:
data
.
errorCode
}));
}
eventView
.
redactPromise
=
null
;
}
}
function
paginateBack
()
{
room
.
paginateBackFrom
(
event
.
eventId
);
}
function
reactWith
(
reactionText
)
{
room
.
sendReaction
(
reactionText
,
event
.
eventId
);
}
}
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Tue, Jun 24, 8:41 PM (23 h, 10 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
235012
Default Alt Text
EventView.qml (4 KB)
Attached To
Mode
rK kazv
Attached
Detach File
Event Timeline
Log In to Comment