Review Request: Add KMessageWidget, an alternative to KMessageBox

Jarosław Staniek staniek at kde.org
Thu Apr 28 21:06:57 BST 2011


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
http://git.reviewboard.kde.org/r/101249/#review2948
-----------------------------------------------------------

Ship it!


I admit I reviewed the code extensively since I used it in Kexi already, extending by adding default action feature, callouts, and autodeletion. Good job!

Please look at these supplementary notes too - I'd like to start discussion:
There's possible problem with adding new widgets in so matured API as KDElibs 4.7: I do not know how we'll deal with the problem of supporting KDE 4.6 apps that require this new widget (without forking). As I said on kde-core-devel, ideally new widgets would land in extra library and could be backported. Also this widget has almost nothing to do with KDElibs-sepcific features and some peopel would _love_ to use it in non-KDE code too. Again, without forking.


kdeui/widgets/kmessagewidget.h
<http://git.reviewboard.kde.org/r/101249/#comment2529>

    How about having Q_Properties ?



kdeui/widgets/kmessagewidget.h
<http://git.reviewboard.kde.org/r/101249/#comment2528>

    It would be good to add ctor KMessageWidget(const QString* text, parent) ctor too for convenience, it's frequent case



kdeui/widgets/kmessagewidget.h
<http://git.reviewboard.kde.org/r/101249/#comment2527>

    setCloseButtonVisible() would be better than verb show
    
    Also isCloseButtonVisible() setter needed for completness
    
    Also it would be good to make setCloseButtonVisible() a slot since other property (wordWrap) has setter as slot
    
    
    



kdeui/widgets/kmessagewidget.cpp
<http://git.reviewboard.kde.org/r/101249/#comment2530>

    Do we need this attribute? labelText->text() has the same information.



kdeui/widgets/kmessagewidget.cpp
<http://git.reviewboard.kde.org/r/101249/#comment2533>

    I suggest adding 
     textLabel->setTextInteractionFlags(Qt::TextBrowserInteraction);
    
    we use such flag in KMessageBox too, this enables links and text selection, useful when error copying texts by users



kdeui/widgets/kmessagewidget.cpp
<http://git.reviewboard.kde.org/r/101249/#comment2531>

    Please change to SimpleAnimationEffects, since in other places this kind of animations are allowed for SimpleAnimationEffects level, e.g.: KFadeWidgetEffect.


- Jarosław


On April 28, 2011, 3:31 p.m., Aurélien Gâteau wrote:
> 
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> http://git.reviewboard.kde.org/r/101249/
> -----------------------------------------------------------
> 
> (Updated April 28, 2011, 3:31 p.m.)
> 
> 
> Review request for kdelibs.
> 
> 
> Summary
> -------
> 
> KMessageWidget is a new widget which can be considered as a less intrusive alternative for KMessageBox. It was designed during KDE UX sprint 2011 ( http://community.kde.org/Sprints/UX2011/KMessageWidget ).
> 
> The class documentation should make it clear how and when it can be used.
> 
> This widget could be used by:
> - Browsers to implement their "remember password" widgets (Konqueror, Rekonq...)
> - Forms to provide feedback on validation errors
> - Bluedevil KCM to replace its custom "No Bluetooth adapter have been found" message widget
> - Nepomuk/Strigi KCM to indicate status of their services
> - Gwenview to replace its custom save bar
> - ...
> 
> I still have a few additions in mind for the API but it is already usable and since we are freezing I think it can be merged in master in its current state. I assume it will still be possible to extend the API a bit before kdelibs 4.7 freezes for good.
> 
> I also wrote an example program in the kdeexample repository ( https://projects.kde.org/projects/kde/kdeexamples/repository/show?rev=agateau%2Fkmessagewidget ), though I am wondering whether it shouldn't be moved in kdeui/tests as it is more a manual test program than an example.
> 
> 
> Diffs
> -----
> 
>   kdeui/CMakeLists.txt d1873d1 
>   kdeui/widgets/kmessagewidget.h PRE-CREATION 
>   kdeui/widgets/kmessagewidget.cpp PRE-CREATION 
> 
> Diff: http://git.reviewboard.kde.org/r/101249/diff
> 
> 
> Testing
> -------
> 
> 
> Screenshots
> -----------
> 
> Montage from kmessagewidgetdemo
>   http://git.reviewboard.kde.org/r/101249/s/141/
> 
> 
> Thanks,
> 
> Aurélien
> 
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-core-devel/attachments/20110428/336987f5/attachment.htm>


More information about the kde-core-devel mailing list