Review Request 110429: Patch that implements resource categorizing via tags.

Boudewijn Rempt boud at valdyas.org
Sat May 18 09:17:06 BST 2013


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

Ship it!


I think it's time to push this to master.

- Boudewijn Rempt


On May 17, 2013, 11:32 p.m., Sascha Suelzer wrote:
> 
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> http://git.reviewboard.kde.org/r/110429/
> -----------------------------------------------------------
> 
> (Updated May 17, 2013, 11:32 p.m.)
> 
> 
> Review request for Calligra.
> 
> 
> Description
> -------
> 
> Hi. :)
> 
> I've attached a patch that improves the way the user can organize
> resources into named sets that can be added, deleted and chosen from a
> drop down menu that I've added to KoResourceItemChooser. This made the
> changes available to the paintoppreset choosers, the gradient choosers
> and the pattern choosers.
> 
> Usage right now is:
> 
> Mostly mouse based version:
> Right clicking any resource can assign it to or remove it from any tag.
> There is an option to create a new tag for the resource as well.
> It's fairly intuitive.
> -----------------------------------------------------------------------
> 
> Mostly keyboard based version:
> Resource dockers and popups start with an unfiltered view, in this view
> the tag search bar at the bottom is disabled.
> 
> To add a tag category, press the plus button and enter a name for the tag.
> 
> This creates an empty view and enables the search text box at the bottom.
> 
> Terms in double quotes "like this" will be matched to the resource name
> exactly.
> 
> Entering terms without quotes will partial matching, good for filtering
> many resources. filtering eraser would remove all resources with eraser in
> their name.
> 
> Putting an exclamation mark in front of a term will exclude the term from
> the set.
> 
> Pressing enter saves the set and will clear the search box, so we don't end
> up with something like erase,sketch,fur,!paint,smudge_1,smudge_2,... etc
> 
> Once a set is defined, it can be used as a search term as well.
> For example:
> We've created a set that contains all erasers and is called 'erasers'.
> If we switch to a different set and type [erasers] in the search box then
> all the items of that set will be added to the current set, exclusions work
> the same way.
> 
> ============================================================================
> Remarks about the patch:
> 
> Currently only adding and deleting categories is supported, renaming them
> is in the code but lacks an UI feature, which I was unable to implement.
> (I wanted the unfiltered view to be immutable and tried dis and enabling
> the editable state of the drop down box based on which index was active,
> but that introduced a segfault.)
> All in all the UI parts I've written aren't exactly amazing, maybe
> someone more experienced can take care of that? I can do it but it'd be
> slow since I have very little experience with that. 
> 
> I have removed the `show all' checkbox in the paintop preset docker and
> all references to that functionality since it made filtering a bit more
> complicated as well as just not making too much sense with the
> improvements to the tagging system.
> 
> I have also removed the proxy adapter in KisPresetChooser since it
> didn't do anything useful after these changes, yet required attention
> since it overloaded some now improved functions.
> 
> Current shortcomings of the system, most of them are UI related:
> 
> - Since I used the already existing KoResourceTagging class to handle all
>  the tagging bits, and ultimately save tags to disk, in alphabetical
>  order, restarting Krita, and thus repopulating the combo boxes also
>  fills them in alphabetical order and not in the order they might have
>  been defined by the user.
> 
> - Adding a new tag in a pop-up chooser closes the popup since I used an 
>  input dialog after failing to implement it with combobox editing.
> 
> - Combo boxes aren't updated for all item choosers of the same kind.
>  For example adding a few categories in the preset docker does not update
>  the combo box in the preset chooser popup that can be found in the toolbar.
> 
> I also had a crash at one point in time where some brush presets got
> changed around in master and clicking some resources in the brush preset
> box crashed the program, but I was not able to reproduce that after a
> clean rebuild of my local workspace and changing presets around
> externally, so it might not be an issue, but I'm including it for
> completeness sake.
> 
> 
> Diffs
> -----
> 
>   krita/plugins/extensions/dockers/dockerplugintemplate/presetdocker_dock.h 43fe4e3 
>   krita/plugins/extensions/dockers/dockerplugintemplate/presetdocker_dock.cpp 08466cf 
>   krita/plugins/extensions/dockers/presetdocker/presetdocker_dock.h 2a92777 
>   krita/plugins/extensions/dockers/presetdocker/presetdocker_dock.cpp 097ebd3 
>   krita/ui/forms/wdgpaintoppresets.ui c2560a5 
>   krita/ui/kis_config.h aaa1b3d 
>   krita/ui/kis_config.cc ae51c5c 
>   krita/ui/kis_paintop_box.cc 17cf40b 
>   krita/ui/kis_palette_manager.cpp 326590d 
>   krita/ui/widgets/kis_paintop_presets_chooser_popup.h 69880ee 
>   krita/ui/widgets/kis_paintop_presets_chooser_popup.cpp 9f5a7f8 
>   krita/ui/widgets/kis_preset_chooser.h 0433173 
>   krita/ui/widgets/kis_preset_chooser.cpp 01f1b7b 
>   krita/ui/widgets/kis_preset_selector_strip.cpp 068c745 
>   libs/widgets/CMakeLists.txt 4e6e362 
>   libs/widgets/KoResourceFiltering.h PRE-CREATION 
>   libs/widgets/KoResourceFiltering.cpp PRE-CREATION 
>   libs/widgets/KoResourceItemChooser.h 3bd790a 
>   libs/widgets/KoResourceItemChooser.cpp 61273fe 
>   libs/widgets/KoResourceItemView.h 63906cd 
>   libs/widgets/KoResourceItemView.cpp dfa2ba9 
>   libs/widgets/KoResourceModel.h d63d32a 
>   libs/widgets/KoResourceModel.cpp c25be97 
>   libs/widgets/KoResourceServer.h b363684 
>   libs/widgets/KoResourceServerAdapter.h bb5c414 
> 
> Diff: http://git.reviewboard.kde.org/r/110429/diff/
> 
> 
> Testing
> -------
> 
> I have only tested for Krita.
> Apart from any bugs the new functionality might have it seems to not introduce any regression for any other components.
> 
> 
> Thanks,
> 
> Sascha Suelzer
> 
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/calligra-devel/attachments/20130518/506dc5eb/attachment.htm>


More information about the calligra-devel mailing list