Jump to content

KTp/Tasks/TextUIQML: Difference between revisions

From KDE Community Wiki
D ed (talk | contribs)
Leon (talk | contribs)
 
(23 intermediate revisions by 3 users not shown)
Line 20: Line 20:
* Smoother loading/scrolling on images loading.. maybe :)
* Smoother loading/scrolling on images loading.. maybe :)


===Demo===
Demo is available here
kde:scratch/davidedmundson/ktp_text_qml
It looks like this:
[[http://static.davidedmundson.co.uk/ktp_qml.png]]


==Action Plan==
==Action Plan==
Line 32: Line 40:
===Work that needs doing===
===Work that needs doing===


* Split text-ui away from AdiumTheme*
{| class="sortable" border="1" cellpadding="5" cellspacing="0" style="border: gray solid 1px; border-collapse: collapse; text-
* Move all message handling away from ChatWidget, along with any remaining "theme" things into AdiumMessagesView (which has some sort of setTextChannel method)
{| cellspacing="0" cellpadding="5" border="1" style="border: 1px solid gray; border-collapse: collapse; text-align: left; width: 100%;" class="sortable"
* This will allow us to drop this thing out, and a new one in
|- style="background: rgb(236, 236, 236) none repeat scroll 0% 0%; -moz-background-clip: border; -moz-background-origin: padding; -moz-background-inline-policy: continuous; white-space: nowrap;"


* Once that is done, should allow fairly easy porting in a branch without conflicts
! Status
! Action
! Where
! Developer


* Work on the themes is going on with fake models at LINK HERE
{{FeatureProjectInProgress|Split current message handling out of ChatWidget into AdiumThemeView subclass/container that can be swapped out|textUI|[email protected]}}
* I personally want two themes, one like Renkoo and a group theme that matches
{{FeatureProjectTodo|Figure out how to handle notifications. I've copied code to MessageView, which won't be in the QML code. We can't move it to k-c-i because it needs knowledge of the widget to activate.|textUI|[email protected]}}
visual change won't be too large. (Though /maybe/ it's best to focus on just one thing)
{{FeatureProjectTodo|Figure out how to do Copying text|QML Demo|[email protected]}}
{{FeatureProjectTodo|Figure out how to do searching + scroll|QML Demo|[email protected]}}
{{FeatureProjectDone|Make a test-case for fixing the scrolling bug| QML Demo|[email protected]}}
{{FeatureProjectTodo|Fix autoscroll to bottom|QML Demo |[email protected]}}


* I'm not sure if we want to drop AdiumTheme support or not.
{{FeatureProjectDone|Add log loading to MessagesModel|KCI|sh.[email protected]}}
{{FeatureProjectDone|Handle MessageDeliveryReports in MessagesModel. Ideally update existing sent message with a property.|KCI|[email protected]}}
{{FeatureProjectDone|Remove TargetContact - put as title + avatar + icon in Conversation. Be group chat compliant|KCI|[email protected]}}
|}


* MessagesModel needs better delivery report handling
Plugins are another problem. We can deal with that afterwards. Dave has a plan in his brain.
* Make targetContact not suck. Take a ChannelPtr and it should handle group chat titles too
  - will have something like "QString channelName()" "QPixmap channelIcon"


* MessagesModel needs logger integration at least to load the last n messages like text-ui does
* I'm not sure if we want to drop AdiumTheme support or not.
 
==QML issues remaining==
 
* Desktop Scrollbars (see Muon Discover)
* We need "scroll to bottom" on new message
* Find (highlight and scroll to the right place)
* Text copying (not easy)
* Make arrow keys cause scroll
* Links working
* Emoticons to text
* Plugins (I want the message to have some sort of map of "what QML item to insert, and properties to pass to it"
    Custom items could then be included.
* Warnings in "take2" theme
* Sort out notification handling

Latest revision as of 07:21, 30 December 2013

Declarative TextUI

Rationale

In order to modernise we need more control.

This means doing our own thing with themes so we can change them. QML in many ways is a good choice, messages are like a list model.

We will get

  • Delivery Reports inline
  • Error messages inline
  • Better, richer plugins
  • Seperation between data + logic + view
  • Typing indicators inline
  • Contact status inline + mobile icon
  • History loaded on demand
  • Better load types (Webkit is slow, and we need avatars etc. before we can do anything)
  • User selected fonts for better desktop integration
  • Chat plasmoid will benefit from this too
  • Smoother loading/scrolling on images loading.. maybe :)

Demo

Demo is available here

kde:scratch/davidedmundson/ktp_text_qml

It looks like this: [[1]]

Action Plan

  • Plan is to kill the webkit parts
  • Replace that part with a QDeclarativeView
  • It will NOT be merged if there are regressions
  • The group chat participants list will remain the same, toolbars will remain the same, typing area will remain the same. I do _NOT_ want to change those.
  • Themes will have Conversation* object exposed as rootContextProperty. I don't think it makes any sense to use ConversationsModel
  • It needs to look like part of a desktop app, and not part of something Plasma.

Work that needs doing

Status Action Where Developer
IN PROGRESS Split current message handling out of ChatWidget into AdiumThemeView subclass/container that can be swapped out textUI <[email protected]>
TODO Figure out how to handle notifications. I've copied code to MessageView, which won't be in the QML code. We can't move it to k-c-i because it needs knowledge of the widget to activate. textUI <[email protected]>
TODO Figure out how to do Copying text QML Demo <[email protected]>
TODO Figure out how to do searching + scroll QML Demo <[email protected]>
DONE Make a test-case for fixing the scrolling bug QML Demo <[email protected]>
TODO Fix autoscroll to bottom QML Demo <[email protected]>


DONE Add log loading to MessagesModel KCI <[email protected]>
DONE Handle MessageDeliveryReports in MessagesModel. Ideally update existing sent message with a property. KCI <[email protected]>
DONE Remove TargetContact - put as title + avatar + icon in Conversation. Be group chat compliant KCI <[email protected]>

Plugins are another problem. We can deal with that afterwards. Dave has a plan in his brain.

  • I'm not sure if we want to drop AdiumTheme support or not.