From f4dc59983b465273fcd40c3a047fe288be1fe599 Mon Sep 17 00:00:00 2001 From: Rene Gollent Date: Mon, 16 Nov 2009 01:07:40 +0000 Subject: [PATCH] Partially implement ticket #4916: - Rename "Configure Favorites..." to "Edit Favorites...". - Remove the old-style Configure Favorites dialog in favor of simply opening the favorites folder (~/config/settings/Tracker/go) in a Tracker window for the user to manipulate. - Rename the "Favorite Folders" section to simply "Favorites" as files are also allowed (i.e. to easily open a template document). - Removed completely arbitrary (and silent) 20 item limit to favorites list. - Automatic whitespace cleanup Still to do: Grab the ref filter from the file panel (if any) and run the favorites through it as well, since we want to filter out any non-folder favorites that the app is incapable of handling. Also, the setting for the favorites menu to show recent documents needs a new home, as it was previously in the no longer existing Configure Favorites window. Suggestions welcome, as I'm not currently seeing a spot in the Tracker prefs that would make good sense. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@34071 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- headers/private/tracker/FavoritesConfig.h | 275 --- src/kits/tracker/Commands.h | 1 + src/kits/tracker/FavoritesConfig.cpp | 2295 --------------------- src/kits/tracker/FavoritesMenu.cpp | 60 +- src/kits/tracker/FilePanelPriv.cpp | 252 +-- src/kits/tracker/FilePanelPriv.h | 20 +- src/kits/tracker/Jamfile | 1 - 7 files changed, 131 insertions(+), 2773 deletions(-) delete mode 100644 headers/private/tracker/FavoritesConfig.h delete mode 100644 src/kits/tracker/FavoritesConfig.cpp diff --git a/headers/private/tracker/FavoritesConfig.h b/headers/private/tracker/FavoritesConfig.h deleted file mode 100644 index 09faf0b369..0000000000 --- a/headers/private/tracker/FavoritesConfig.h +++ /dev/null @@ -1,275 +0,0 @@ -/* -Open Tracker License - -Terms and Conditions - -Copyright (c) 1991-2000, Be Incorporated. All rights reserved. - -Permission is hereby granted, free of charge, to any person obtaining a copy of -this software and associated documentation files (the "Software"), to deal in -the Software without restriction, including without limitation the rights to -use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies -of the Software, and to permit persons to whom the Software is furnished to do -so, subject to the following conditions: - -The above copyright notice and this permission notice applies to all licensees -and shall be included in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF TITLE, MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL -BE INCORPORATED BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF, OR IN CONNECTION -WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of Be Incorporated shall not be -used in advertising or otherwise to promote the sale, use or other dealings in -this Software without prior written authorization from Be Incorporated. - -Tracker(TM), Be(R), BeOS(R), and BeIA(TM) are trademarks or registered trademarks -of Be Incorporated in the United States and other countries. Other brand product -names are registered trademarks or trademarks of their respective holders. -All rights reserved. -*/ - -#ifndef FAVORITES_CONFIG_H -#define FAVORITES_CONFIG_H - -#include -#include - -#include "Model.h" - -class BBox; -class BButton; -class BCheckBox; -class BFilePanel; -class BMenuField; -class BPopUpMenu; -class BTextControl; -class BMessageRunner; - -namespace BPrivate { - -const uint32 kConfigShow = 'show'; -const uint32 kConfigClose = 'canc'; - -// -// your app will get one of these messages when -// the count has changed -// FindInt32("count", &count) -// -const uint32 kUpdateAppsCount = 'upac'; -const uint32 kUpdateDocsCount = 'updc'; -const uint32 kUpdateFolderCount = 'upfl'; - -class NameItemPanel : public BWindow { -public: - NameItemPanel(BWindow *parent, const char *initialText); - virtual ~NameItemPanel(); - - virtual void MessageReceived(BMessage *); - -private: - void AddParts(const char *initialText); - - BWindow *fParent; - BBox *fBG; - BTextControl *fNameFld; - BButton *fCancelBtn; - BButton *fDoneBtn; -}; - -class TDraggableIconButton : public BControl { -public: - TDraggableIconButton(BRect , const char *label, BMessage *, - uint32 resizemask, uint32 flags); - virtual ~TDraggableIconButton(); - - virtual void AttachedToWindow(); - virtual void DetachedFromWindow(); - virtual void Draw(BRect); - virtual void MouseDown(BPoint); - virtual void MouseUp(BPoint); - virtual void MouseMoved(BPoint , uint32 , const BMessage *); - - virtual void GetPreferredSize(float *, float *); - virtual void ResizeToPreferred(); - -private: - bool fDragging; - BRect fInitialClickRect; - BBitmap *fIcon; - BRect fIconRect; - BRect fLabelRect; -}; - -class TScrollerButton : public BControl { -public: - TScrollerButton(BRect , BMessage *, bool direction); - - virtual void AttachedToWindow(); - virtual void DetachedFromWindow(); - virtual void Draw(BRect); - virtual void MouseDown(BPoint); - virtual void MouseUp(BPoint); - virtual void MouseMoved(BPoint , uint32 , const BMessage *); - -private: - bool fDirection; - rgb_color fSelectedColor; - BRect fHiliteFrame; - BMessageRunner *fTicker; -}; - -class TContentsMenu : public BControl { -public: - TContentsMenu(BRect , BMessage *singleClick, BMessage *doubleClick, - int32 visibleItemCount, const entry_ref *startRef); - virtual ~TContentsMenu(); - - virtual void AttachedToWindow(); - virtual void DetachedFromWindow(); - virtual void Draw(BRect ); - virtual void KeyDown(const char *bytes, int32 numBytes); - virtual void MessageReceived(BMessage *); - virtual void MouseDown(BPoint ); - virtual void MouseUp(BPoint ); - virtual void MouseMoved(BPoint , uint32 , const BMessage *); - - virtual void GetPreferredSize(float *, float *); - virtual void ResizeToPreferred(); - - void StartTracking(BPoint); - void StopTracking(); - -#ifdef ITEM_EDIT - void BeginItemEdit(BPoint); - void StopItemEdit(); -#endif - - void SetStartRef(const entry_ref *); - void FillMenu(const entry_ref *); - void EmptyMenu(); - - bool ItemFrame(int32 index, BRect *iconFrame, BRect *textFrame, BRect *itemFrame) const; - void InvalidateItem(int32 index); - void InvalidateAbsoluteItem(int32 index); - int32 ItemAt(BPoint, BRect *textFrame, BRect *itemFrame, BRect *iconFrame); - const Model *ItemAt(int32) const; - - void SelectItemAt(BPoint where); - void Select(const entry_ref *); - - void OpenItem(int32); - int32 ItemCount() const; - void RemoveItem(int32); - void AddTempItem(BPoint where); - -private: - void UpdateScrollers(); - void Scroll(bool); - - BMessage *fDoubleClickMessage; - - int32 fVisibleItemCount; - entry_ref fStartRef; - - BFont *fMenuFont; - float fFontHeight; - float fItemHeight; - rgb_color fHiliteColor; - - BRect fInitialClickRect; - bigtime_t fInitialClickTime; -#ifdef ITEM_EDIT - BPoint fInitialClickLoc; - bool fEditingItem; - BTextView *fEditingFld; - int32 fItemIndex; -#endif - int32 fFirstItem; - BObjectList *fContentsList; - - BBitmap *fSmallGroupIcon; - BBitmap *fSymlinkIcon; - - TScrollerButton *fUpBtn; - TScrollerButton *fDownBtn; -}; - - -// pass -1 to max apps/docs/folders to not have it show -class TFavoritesConfigWindow : public BWindow { -public: - TFavoritesConfigWindow(BRect frame, const char *title, - bool modal, uint32 filePanelNodeFlavors, - BMessenger parent, const entry_ref *startRef, - int32 maxApps = -1, int32 maxDocs = -1, int32 maxFolders = -1); - ~TFavoritesConfigWindow(); - - void MessageReceived(BMessage *); - bool QuitRequested(); - - void AddNewGroup(); - void AddRefs(BMessage *); - -private: - void AddParts(int32 maxApps, int32 maxDocs, int32 maxFolders); - void AddBeMenuPane(int32 maxApps, int32 maxDocs, int32 maxFolders); - - void OpenGroup(const entry_ref *); - void ShowGroup(const entry_ref *); - - void PromptForAdd(); - - void UpdateButtons(); - - void UpdateFoldersCount(int32 = -1, bool notifyTracker = true); - void UpdateDocsCount(int32 = -1, bool notifyTracker = true); - void UpdateAppsCount(int32 = -1, bool notifyTracker = true); - - static void BuildCommon(BRect *frame, int32 count, const char *string, uint32 btnWhat, - uint32 fldWhat, BCheckBox **button, BTextControl **field, BBox *parent); - - static void AddNewGroup(entry_ref *, entry_ref *); - static void AddSymLink(const entry_ref *, const entry_ref *); - - uint32 fFilePanelNodeFlavors; - BMessenger fParent; - entry_ref fCurrentRef; - BFilePanel *fAddPanel; - - // Favorites Menu Config controls - BBox *fBeMenuPaneBG; - - BPopUpMenu *fGroupMenu; - BMenuField *fGroupBtn; - - BPopUpMenu *fSortMenu; - BMenuField *fSortBtn; - - TDraggableIconButton *fNewGroupBtn; - - BCheckBox *fRecentAppsBtn; - BTextControl *fRecentAppsFld; - - BCheckBox *fRecentFoldersBtn; - BTextControl *fRecentFoldersFld; - - BCheckBox *fRecentDocsBtn; - BTextControl *fRecentDocsFld; - - TContentsMenu *fMenuThing; - - BButton *fAddBtn; - BButton *fRemoveBtn; - BButton *fEditBtn; - BButton *fOpenBtn; -}; - -} // namespace BPrivate - -using namespace BPrivate; - -#endif diff --git a/src/kits/tracker/Commands.h b/src/kits/tracker/Commands.h index 6f933afaca..be2e5c5250 100644 --- a/src/kits/tracker/Commands.h +++ b/src/kits/tracker/Commands.h @@ -100,6 +100,7 @@ const uint32 kPasteAttributes = 'Tpat'; const uint32 kAttributeItem = 'Tatr'; const uint32 kMIMETypeItem = 'Tmim'; const uint32 kAddCurrentDir = 'Tadd'; +const uint32 kEditFavorites = 'Tedf'; const uint32 kSwitchDirectory = 'Tswd'; const uint32 kQuitTracker = 'Tqit'; diff --git a/src/kits/tracker/FavoritesConfig.cpp b/src/kits/tracker/FavoritesConfig.cpp deleted file mode 100644 index 88c491c9c1..0000000000 --- a/src/kits/tracker/FavoritesConfig.cpp +++ /dev/null @@ -1,2295 +0,0 @@ -/* -Open Tracker License - -Terms and Conditions - -Copyright (c) 1991-2000, Be Incorporated. All rights reserved. - -Permission is hereby granted, free of charge, to any person obtaining a copy of -this software and associated documentation files (the "Software"), to deal in -the Software without restriction, including without limitation the rights to -use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies -of the Software, and to permit persons to whom the Software is furnished to do -so, subject to the following conditions: - -The above copyright notice and this permission notice applies to all licensees -and shall be included in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF TITLE, MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL -BE INCORPORATED BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF, OR IN CONNECTION -WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of Be Incorporated shall not be -used in advertising or otherwise to promote the sale, use or other dealings in -this Software without prior written authorization from Be Incorporated. - -Tracker(TM), Be(R), BeOS(R), and BeIA(TM) are trademarks or registered trademarks -of Be Incorporated in the United States and other countries. Other brand product -names are registered trademarks or trademarks of their respective holders. -All rights reserved. -*/ - -// *************************************************************************************** -// BeMenu configuration -// -// add temp item on dnd with new group -// save window location -// selection information -// last group showing -// recents -// auto scroll of contentsmenu -// default settings -// off screen drawing -// return/cancel in editingtext for name invokes name change -// after New Folder, scroll to selection -// move of items to folders -// change parent folder btn to be a NavMenu -// -// *************************************************************************************** - -#include -#include -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -// Tracker -#include "Commands.h" -#include "IconCache.h" -#include "IconMenuItem.h" -#include "Model.h" -#include "ObjectList.h" -#include "tracker_private.h" -#include "Utilities.h" - -#include "FavoritesConfig.h" - - -enum { - kRemove = 'rmve', - kAdd, - kRecentDocs, - kRecentFolders, - kRecentApps, - kNewGroup, - kItemSelected, - kOpenItem, - kEditItem, - kDoubleClick, - kRecentDocsCount, - kRecentFoldersCount, - kRecentAppsCount, - kScrollUp, - kScrollDown, - kShowGroup, - kTraverseUp, - kNameChange -}; - -const rgb_color kAlmostWhite = {232, 232, 232, 255}; -const rgb_color kLightGray = {136, 136, 136, 255}; -const rgb_color kMediumGray = {96, 96, 96, 255}; - -const float kMinBtnWidth = 75.0f; -const float kMenuFieldPad = 30.0f; -const float kMenuFieldGap = 5.0f; -const float kCheckBoxPad = 20.0f; -const float kTextControlPad = 15.0f; - -const char *const kOpenStr = "Open"; -const char *const kRemoveStr = "Remove"; -const char *const kShowGroupStr = "Show Group"; -const char *const kSortByStr = "Sort By"; - -const char *const kNewGroupStr = "New Group"; -const char *const kRecentDocsStr = "Recent Documents"; -const char *const kRecentFoldersStr = "Recent Folders"; -const char *const kRecentAppsStr = "Recent Applications"; -const char *const kShowStr = "Show:"; - -const unsigned char kLargeNewGroupIcon [] = { - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0xfa, 0xfa, 0x00, 0x00, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0xfa, 0xf8, 0xfa, 0xfa, 0x00, 0x00, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0xfa, 0xf8, 0xf8, 0xf8, 0xfa, 0xfa, 0x00, - 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0xfa, 0xfa, 0x00, 0x00, 0xf8, 0xf8, 0xf8, 0xf8, 0xf8, 0xfa, - 0xfa, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0xfa, 0xf8, 0xfa, 0xfa, 0x00, 0x00, 0xf8, 0xf8, 0xf8, 0xf8, - 0xf8, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0xfa, 0xf8, 0xf8, 0xf8, 0xfa, 0xfa, 0x00, 0x00, 0xf8, 0xf8, - 0xf8, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0xfa, 0xf8, 0xf8, 0xf8, 0xf8, 0xf8, 0xfa, 0xfa, 0x00, 0xf8, - 0xf8, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0xf8, 0xf8, 0xf8, 0xf8, 0xf8, 0xf8, 0xf8, 0x00, 0x0e, - 0x0f, 0x1c, 0x1c, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x0f, 0x0f, 0x0f, 0xf8, 0xf8, 0xf8, 0xf8, 0x00, 0x3f, - 0x3f, 0x0e, 0x0f, 0x1c, 0x1c, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x0f, 0x3f, 0x3f, 0x0e, 0x0f, 0xf8, 0xf8, 0x00, 0x00, - 0x3f, 0x3f, 0x3f, 0x0e, 0x0f, 0x1c, 0x1c, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x0f, 0x3f, 0x3f, 0x3f, 0x3f, 0x0e, 0x0f, 0x1c, 0x1c, - 0x00, 0x00, 0x3f, 0x3f, 0x3f, 0x0e, 0x0f, 0x1a, 0x19, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x0f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x0e, 0x0f, - 0x1c, 0x1c, 0x00, 0x00, 0x3f, 0x3f, 0x3f, 0x0e, 0x1a, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x0f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, - 0x0e, 0x0f, 0x1c, 0x1c, 0x00, 0x00, 0x3f, 0x3f, 0x17, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x0f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, - 0x3f, 0x3f, 0x0e, 0x0f, 0x1a, 0x19, 0x00, 0x00, 0x17, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x0f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, - 0x3f, 0x3f, 0x3f, 0x3f, 0x0e, 0x1a, 0x19, 0x00, 0x17, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x0f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, - 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x17, 0x19, 0x00, 0x17, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x0f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, - 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x17, 0x19, 0x00, 0x17, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x0f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, - 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x17, 0x19, 0x00, 0x17, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x18, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, - 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x17, 0x19, 0x00, 0x17, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x1b, 0x1c, 0x17, 0x18, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, - 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x17, 0x19, 0x00, 0x17, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x1b, 0x1c, 0x17, 0x18, 0x3f, 0x3f, 0x3f, 0x3f, - 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x17, 0x19, 0x00, 0x17, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x19, 0x1a, 0x17, 0x17, 0x3f, 0x3f, - 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x17, 0x19, 0x00, 0x17, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x19, 0x1a, 0x17, 0x17, - 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x17, 0x19, 0x00, 0x17, 0x1a, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x19, 0x1a, - 0x17, 0x17, 0x3f, 0x3f, 0x3f, 0x17, 0x19, 0x00, 0x1a, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, - 0x19, 0x1a, 0x17, 0x17, 0x3f, 0x17, 0x19, 0x00, 0x00, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0x00, 0x00, 0x19, 0x1a, 0x17, 0x17, 0x1a, 0x00, 0xff, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0x00, 0x00, 0x19, 0x1a, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x19, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff -}; - -const unsigned char kSmallNewGroupIcon [] = { - 0xff, 0xff, 0xff, 0xff, 0x0e, 0x0e, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0x0e, 0xfa, 0xfa, 0x0e, 0x0e, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0x0e, 0x0e, 0xf8, 0xf8, 0xfa, 0xfa, 0x0e, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0x0e, 0xfa, 0xfa, 0x0e, 0xf8, 0xf8, 0x0e, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0x0e, 0xf8, 0xf8, 0xfa, 0xfa, 0x0e, 0x0e, 0x0e, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0x0e, 0x18, 0x18, 0xf8, 0xf8, 0x0e, 0x3f, 0x3f, 0x0e, 0x0e, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0x0e, 0x18, 0x3f, 0x18, 0x18, 0x0f, 0x0f, 0x3f, 0x3f, 0x0e, 0x12, 0xff, 0xff, 0xff, - 0xff, 0xff, 0x0e, 0x18, 0x3f, 0x3f, 0x3f, 0x18, 0x18, 0x0f, 0x0f, 0x0e, 0x12, 0xff, 0xff, 0xff, - 0xff, 0xff, 0x0e, 0x18, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x18, 0x18, 0x0e, 0x12, 0xff, 0xff, 0xff, - 0xff, 0xff, 0x0e, 0x18, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x1c, 0x0e, 0x12, 0xff, 0xff, 0xff, - 0xff, 0xff, 0x0e, 0x0e, 0x18, 0x1c, 0x3f, 0x3f, 0x3f, 0x3f, 0x1c, 0x0e, 0x12, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0x0e, 0x0e, 0x17, 0x1c, 0x3f, 0x3f, 0x1c, 0x0e, 0x12, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0e, 0x0e, 0x17, 0x1c, 0x1c, 0x0e, 0x12, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0e, 0x0e, 0x17, 0x0e, 0x12, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0e, 0x0e, 0xff, 0xff, 0xff, 0xff, - 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff -}; - - -void -CenterWindowOnScreen(BWindow *window) -{ - window->CenterOnScreen(); -} - - -float -FontHeight(const BFont *font, bool full) -{ - font_height finfo; - font->GetHeight(&finfo); - float height = finfo.ascent + finfo.descent; - - if (full) - height += finfo.leading; - - return height; -} - - -// #pragma mark - - - -TFavoritesConfigWindow::TFavoritesConfigWindow(BRect frame, const char *title, - bool modal, uint32 filePanelNodeFlavors, BMessenger parent, const entry_ref *startRef, - int32 maxApps, int32 maxDocs, int32 maxFolders) - : BWindow(frame, title, B_TITLED_WINDOW_LOOK, - modal ? B_MODAL_APP_WINDOW_FEEL : B_NORMAL_WINDOW_FEEL, - B_NOT_ZOOMABLE | B_NOT_RESIZABLE), - fFilePanelNodeFlavors(filePanelNodeFlavors), - fParent(parent), - fCurrentRef(*startRef), - fAddPanel(NULL) -{ - Lock(); - - // show the window offscreen - // so that the placement calculations actually work - MoveTo(-1024, -1024); - Show(); - AddParts(maxApps, maxDocs, maxFolders); - CenterOnScreen(); - Unlock(); - - AddShortcut('R', B_COMMAND_KEY, new BMessage(kRemove)); - AddShortcut('A', B_COMMAND_KEY, new BMessage(kAdd)); - AddShortcut('E', B_COMMAND_KEY, new BMessage(kEditItem)); - AddShortcut('O', B_COMMAND_KEY, new BMessage(kOpenItem)); - AddShortcut('N', B_COMMAND_KEY, new BMessage(kNewGroup)); - - AddShortcut(B_UP_ARROW, B_COMMAND_KEY, new BMessage(kTraverseUp)); - - BMessenger tracker(kTrackerSignature); - StartWatching(tracker, kFavoriteCountChanged); -} - - -TFavoritesConfigWindow::~TFavoritesConfigWindow() -{ - // node monitoring the be menu directory - stop_watching(this); - - if (fAddPanel && fAddPanel->IsShowing()) - // kill the filepanel if its still showing - fAddPanel->Hide(); - - BMessenger tracker(kTrackerSignature); - StopWatching(tracker, kFavoriteCountChanged); -} - - -void -TFavoritesConfigWindow::MessageReceived(BMessage *message) -{ - switch (message->what) { - // from menuthing selection - case kItemSelected: - UpdateButtons(); - break; - - // double click on item in menuthing - case kDoubleClick: - { - entry_ref ref; - if (message->FindRef("current", &ref) == B_OK) - OpenGroup(&ref); - } - break; - - // open button - case kOpenItem: - if (fMenuThing->Value() >= 0 && fMenuThing->Value() < fMenuThing->ItemCount()) - OpenGroup(fMenuThing->ItemAt(fMenuThing->Value())->EntryRef()); - break; - - case kEditItem: - { - int32 selection = fMenuThing->Value(); - if (selection < 0) - break; - const Model *item = fMenuThing->ItemAt(selection); - if (!item) - break; - - new NameItemPanel(this, item->Name()); - // shows itself, kills itself - } - break; - - case 'canc': - break; - - case kNameChange: - { - const char *name; - if (message->FindString("name", &name) == B_OK) { - int32 selection = fMenuThing->Value(); - if (selection < 0) - break; - const Model *item = fMenuThing->ItemAt(selection); - if (!item) - break; - - const entry_ref *ref = item->EntryRef(); - if (strcmp(ref->name, name) != 0) { - BEntry entry(ref); - if (entry.InitCheck() == B_OK && entry.Exists()) - entry.Rename(name); - } - } - } - break; - - // change of selection in directory menu - case kShowGroup: - { - entry_ref ref; - if (message->FindRef("current", &ref) == B_OK) - ShowGroup(&ref); - } - break; - - // alt-up arrow - case kTraverseUp: - { - BMenuItem *item = fGroupMenu->FindMarked(); - if (item) { - int32 index = fGroupMenu->IndexOf(item) - 1; - if (index < 0) - break; - - item = fGroupMenu->ItemAt(index); - if (item) { - BMessage *message = item->Message(); - if (message) { - entry_ref ref; - if (message->FindRef("current", &ref) == B_OK) { - ShowGroup(&ref); - } - } - } - } - } - break; - - // new group icon - case kNewGroup: - AddNewGroup(); - break; - - // Add button - case kAdd: - PromptForAdd(); - break; - - // from Add btn - FilePanel - case B_REFS_RECEIVED: - AddRefs(message); - // fall through - case B_CANCEL: - fAddPanel = NULL; - break; - - // remove btn - case kRemove: - fMenuThing->RemoveItem(fMenuThing->Value()); - break; - - // recents items - case kRecentFolders: - fRecentFoldersFld->SetEnabled(fRecentFoldersBtn->Value() != 0); - if (fRecentFoldersBtn->Value()) - UpdateFoldersCount(); - else - UpdateFoldersCount(0); - break; - - case kRecentDocs: - fRecentDocsFld->SetEnabled(fRecentDocsBtn->Value() != 0); - if (fRecentDocsBtn->Value()) - UpdateDocsCount(); - else - UpdateDocsCount(0); - break; - - case kRecentApps: - fRecentAppsFld->SetEnabled(fRecentAppsBtn->Value() != 0); - if (fRecentAppsBtn->Value()) - UpdateAppsCount(); - else - UpdateAppsCount(0); - break; - - case kRecentFoldersCount: - UpdateFoldersCount(); - break; - - case kRecentDocsCount: - UpdateDocsCount(); - break; - - case kRecentAppsCount: - UpdateAppsCount(); - break; - - case B_OBSERVER_NOTICE_CHANGE: - { - int32 observerWhat; - if (message->FindInt32("be:observe_change_what", &observerWhat) == B_OK) { - switch (observerWhat) { - case kFavoriteCountChanged: - { - int32 appCount = 10; - int32 documentCount = 10; - int32 folderCount = 10; - - if (message->FindInt32("RecentApplications", &appCount) == B_OK) { - BString appStr; - appStr << appCount; - fRecentAppsFld->SetText(appStr.String()); - UpdateAppsCount(appCount, false); - // false -> do not tell tracker - } - - if (message->FindInt32("RecentDocuments", &documentCount) == B_OK) { - BString docStr; - docStr << documentCount; - fRecentDocsFld->SetText(docStr.String()); - UpdateDocsCount(documentCount, false); - // false -> do not tell tracker - } - - if (message->FindInt32("RecentFolders", &folderCount) == B_OK) { - BString folderStr; - folderStr << folderCount; - fRecentFoldersFld->SetText(folderStr.String()); - UpdateFoldersCount(folderCount, false); - // false -> do not tell tracker - } - } - break; - } - } - } - break; - - default: - BWindow::MessageReceived(message); - break; - } -} - - -bool -TFavoritesConfigWindow::QuitRequested() -{ - // tell the app the config panel is closing - BMessage message(kConfigClose); - int32 count; - if (fRecentAppsFld) { - if (fRecentAppsFld->IsEnabled()) - count = atoi(fRecentAppsFld->Text()); - else - count = 0; - message.AddInt32("applications", count); - } - if (fRecentFoldersFld) { - if (fRecentFoldersFld->IsEnabled()) - count = atoi(fRecentFoldersFld->Text()); - else - count = 0; - message.AddInt32("folders", count); - } - if (fRecentDocsFld) { - if (fRecentDocsFld->IsEnabled()) - count = atoi(fRecentDocsFld->Text()); - else - count = 0; - message.AddInt32("documents", count); - } - - fParent.SendMessage(&message); - return true; -} - - -void -TFavoritesConfigWindow::AddParts(int32 maxApps, int32 maxDocs, int32 maxFolders) -{ - // build the interface - AddBeMenuPane(maxApps, maxDocs, maxFolders); - - // find the bg with the largest dimensions - ResizeTo(fBeMenuPaneBG->Frame().Width(), fBeMenuPaneBG->Frame().Height()); - - // enable node watching - // fill the pseudo menu - OpenGroup(&fCurrentRef); -} - - -void -TFavoritesConfigWindow::BuildCommon(BRect *frame, int32 count, const char *string, - uint32 btnWhat, uint32 fldWhat, BCheckBox **button, BTextControl **field, BBox *parent) -{ - frame->right = frame->left + be_plain_font->StringWidth(string) - + kCheckBoxPad; - - BCheckBox *newButton = new BCheckBox(*frame, "recents btn", string, - new BMessage(btnWhat), B_FOLLOW_BOTTOM | B_FOLLOW_LEFT, - B_WILL_DRAW | B_NAVIGABLE); - parent->AddChild(newButton); - newButton->SetValue(count > 0); - - float width = be_plain_font->StringWidth(kShowStr); - frame->right = frame->left + width - + (be_plain_font->StringWidth("0") * 4) + kTextControlPad; - BTextControl *newFld = new BTextControl(*frame, "recents fld", kShowStr, "", - new BMessage(fldWhat), B_FOLLOW_BOTTOM | B_FOLLOW_LEFT, - B_WILL_DRAW | B_NAVIGABLE); - parent->AddChild(newFld); - newFld->SetDivider(width + 5); - newFld->SetAlignment(B_ALIGN_RIGHT, B_ALIGN_CENTER); - newFld->SetEnabled(count>0); - - char str[32]; - sprintf(str, "%ld", count); - newFld->SetText(str); - - BTextView *textView = newFld->TextView(); - textView->SetMaxBytes(2); - - for (uint32 index = 0; index < 256; index++) - textView->DisallowChar(index); - for (uint32 index = '0'; index <= '9'; index++) - textView->AllowChar(index); - textView->AllowChar(B_BACKSPACE); - - *button = newButton; - *field = newFld; -} - - -void -TFavoritesConfigWindow::AddBeMenuPane(int32 maxApps, int32 maxDocs, int32 maxFolders) -{ - fBeMenuPaneBG = new BBox(Bounds(), "bg", B_FOLLOW_NONE, - B_WILL_DRAW, B_PLAIN_BORDER); - AddChild(fBeMenuPaneBG); - - BRect frame; - float width = 0; - - // New Group - fNewGroupBtn = new TDraggableIconButton(BRect(10, 0, 41, 31), kNewGroupStr, - new BMessage(kNewGroup), B_FOLLOW_LEFT | B_FOLLOW_BOTTOM, - B_WILL_DRAW | B_NAVIGABLE); - fBeMenuPaneBG->AddChild(fNewGroupBtn); - - // Recent Documents - frame.left = 10; - if (maxDocs > -1) { - BuildCommon(&frame, maxDocs, kRecentDocsStr, - kRecentDocs, kRecentDocsCount, &fRecentDocsBtn, &fRecentDocsFld, - fBeMenuPaneBG); - } else { - fRecentDocsBtn = NULL; - fRecentDocsFld = NULL; - } - - // Recent Applications - if (maxApps > -1) { - BuildCommon(&frame, maxApps, kRecentAppsStr, - kRecentApps, kRecentAppsCount, &fRecentAppsBtn, &fRecentAppsFld, - fBeMenuPaneBG); - } else { - fRecentAppsBtn = NULL; - fRecentAppsFld = NULL; - } - - // Recent Folders - if (maxFolders > -1) { - BuildCommon(&frame, maxFolders, kRecentFoldersStr, - kRecentFolders, kRecentFoldersCount, &fRecentFoldersBtn, &fRecentFoldersFld, - fBeMenuPaneBG); - } else { - fRecentFoldersBtn = NULL; - fRecentFoldersFld = NULL; - } - - // will place this items left edge relative to the contents list - fGroupMenu = new BPopUpMenu("Show Group"); - width = be_plain_font->StringWidth("Some Long Name For a Group") - + kMenuFieldPad; - frame.Set(0, 10, width, 11); - fGroupBtn = new BMenuField(frame, "group btn", kShowGroupStr, fGroupMenu); - fBeMenuPaneBG->AddChild(fGroupBtn); - fGroupBtn->HidePopUpMarker(); - fGroupBtn->SetDivider(0); - -#ifdef IS_SORTABLE - // not sortable now, ever (?) - fSortMenu = new BPopUpMenu("Sort By"); - fSortMenu->AddItem(new BMenuItem("Sort One", NULL)); - fSortMenu->AddItem(new BMenuItem("Sort Two", NULL)); - - frame.OffsetBy(0, fGroupBtn->Frame().Height() + kMenuFieldGap); - fSortBtn = new BMenuField(frame, "sort btn", kSortByStr, fSortMenu); - fBeMenuPaneBG->AddChild(fSortBtn); - fSortBtn->SetDivider(be_plain_font->StringWidth(kSortByStr) + 5); -#endif - - // Contents List - // placement is relative to controls in place - // may or may not have recents items - // always will have New Group button -#ifdef IS_SORTABLE - frame.top = fSortBtn->Frame().bottom + 10; -#else - frame.top = fGroupBtn->Frame().bottom + 10; -#endif - frame.bottom = frame.top + 1; - if (maxApps > -1 && fRecentAppsBtn) - frame.left = fRecentAppsBtn->Frame().right + 10; - else if (maxDocs > -1 && fRecentDocsBtn) - frame.left = fRecentDocsBtn->Frame().right + 10; - else if (maxFolders > -1 && fRecentFoldersBtn) - frame.left = fRecentFoldersBtn->Frame().right + 10; - else - frame.left = fGroupBtn->Frame().right + 10; - - frame.right = frame.left + 1; - fMenuThing = new TContentsMenu(frame, new BMessage(kItemSelected), - new BMessage(kDoubleClick), 10, &fCurrentRef); - fBeMenuPaneBG->AddChild(fMenuThing); - - width = be_plain_font->StringWidth("Edit"B_UTF8_ELLIPSIS); - frame.Set(0, 0, (kMinBtnWidth >= width) ? kMinBtnWidth : width, 1); - fEditBtn = new BButton(frame, "edit", "Edit"B_UTF8_ELLIPSIS, new BMessage(kEditItem), - B_FOLLOW_NONE, B_WILL_DRAW | B_NAVIGABLE); - fBeMenuPaneBG->AddChild(fEditBtn); - - width = be_plain_font->StringWidth(kOpenStr); - frame.Set(0, 0, (kMinBtnWidth >= width) ? kMinBtnWidth : width, 1); - fOpenBtn = new BButton(frame, "open", kOpenStr, new BMessage(kOpenItem), - B_FOLLOW_NONE, B_WILL_DRAW | B_NAVIGABLE); - fBeMenuPaneBG->AddChild(fOpenBtn); - - width = be_plain_font->StringWidth("Add"B_UTF8_ELLIPSIS); - frame.Set(0, 0, (kMinBtnWidth >= width) ? kMinBtnWidth : width, 1); - fAddBtn = new BButton(frame, "add", "Add"B_UTF8_ELLIPSIS, new BMessage(kAdd), - B_FOLLOW_NONE, B_WILL_DRAW | B_NAVIGABLE); - fBeMenuPaneBG->AddChild(fAddBtn); - - width = be_plain_font->StringWidth(kRemoveStr); - frame.Set(0, 0, (kMinBtnWidth >= width) ? kMinBtnWidth : width, 1); - fRemoveBtn = new BButton(frame, "remove", kRemoveStr, new BMessage(kRemove), - B_FOLLOW_NONE, B_WILL_DRAW | B_NAVIGABLE); - fBeMenuPaneBG->AddChild(fRemoveBtn); - - // initially disable buttons - fRemoveBtn->SetEnabled(false); - fOpenBtn->SetEnabled(false); - fEditBtn->SetEnabled(false); - - // contents list will auto resize - // resizing of parent pane will cause - // contents list and buttons to flow - fOpenBtn->MoveTo(fMenuThing->Frame().right - fOpenBtn->Frame().Width(), - fMenuThing->Frame().bottom + 10); - fEditBtn->MoveTo(fOpenBtn->Frame().left - 10 - fEditBtn->Frame().Width(), - fOpenBtn->Frame().top); - - fRemoveBtn->MoveTo(fOpenBtn->Frame().left, fOpenBtn->Frame().bottom + 5); - fAddBtn->MoveTo(fEditBtn->Frame().left, fRemoveBtn->Frame().top); - - // resize the pane so that everything is visible - fBeMenuPaneBG->ResizeTo(fMenuThing->Frame().right + 10, - fMenuThing->Frame().bottom + 10 + fOpenBtn->Frame().Height() + 5 - + fRemoveBtn->Frame().Height() + 10); - - // place the remaining controls relative to the menu thing - float bottom; - float left = 10; - BRect menuthingframe = fMenuThing->Frame(); - if (maxFolders > -1 && fRecentFoldersFld && fRecentFoldersBtn) { - bottom = menuthingframe.bottom; - fRecentFoldersFld->MoveTo( - menuthingframe.left - fRecentFoldersFld->Frame().Width() - 10, - bottom - fRecentFoldersFld->Frame().Height()); - fRecentFoldersBtn->MoveTo(10, - fRecentFoldersFld->Frame().top - fRecentFoldersBtn->Frame().Height()); - - left = fRecentFoldersBtn->Frame().right - - (fRecentFoldersBtn->Frame().Width() / 2) - (fNewGroupBtn->Frame().Width() / 2); - } - - if (maxApps > -1 && fRecentAppsFld && fRecentAppsBtn) { - if (maxFolders > -1 && fRecentFoldersFld && fRecentFoldersBtn) - bottom = fRecentFoldersBtn->Frame().top - 20; - else { - bottom = menuthingframe.bottom; - left = fRecentAppsBtn->Frame().right - - (fRecentAppsBtn->Frame().Width() / 2) - (fNewGroupBtn->Frame().Width() / 2); - } - - fRecentAppsFld->MoveTo( - menuthingframe.left - fRecentAppsFld->Frame().Width() - 10, - bottom - fRecentAppsFld->Frame().Height()); - fRecentAppsBtn->MoveTo(10, - fRecentAppsFld->Frame().top - fRecentAppsBtn->Frame().Height()); - } - - if (maxDocs > -1 && fRecentDocsFld && fRecentDocsBtn) { - if (maxApps > -1 && fRecentAppsFld && fRecentAppsBtn) - bottom = fRecentAppsBtn->Frame().top - 20; - else if (maxFolders > -1 && fRecentFoldersFld && fRecentFoldersBtn) - bottom = fRecentFoldersBtn->Frame().top - 20; - else { - bottom = menuthingframe.bottom; - left = fRecentDocsBtn->Frame().right - - (fRecentDocsBtn->Frame().Width() / 2) - (fNewGroupBtn->Frame().Width() / 2); - } - - fRecentDocsFld->MoveTo( - menuthingframe.left - fRecentDocsFld->Frame().Width() - 10, - bottom - fRecentDocsFld->Frame().Height()); - fRecentDocsBtn->MoveTo(10, - fRecentDocsFld->Frame().top - fRecentDocsBtn->Frame().Height()); - } - - // place this button relative (centered) to - // any recents items and content list - fNewGroupBtn->MoveTo(left, menuthingframe.top); - -#ifdef IS_SORTABLE - fSortBtn->MoveTo(menuthingframe.left - fSortBtn->Divider(), - fSortBtn->Frame().top); -#endif - fGroupBtn->MoveTo(menuthingframe.left - fGroupBtn->Divider(), - fGroupBtn->Frame().top); -} - - -static void -GetNextGroupName(BDirectory *dir, char *directoryName) -{ - int32 index = 1; - for (;;) { - sprintf(directoryName, "Untitled Group %li", index); - if (!dir->Contains(directoryName)) - break; - else - index++; - } -} - - -void -TFavoritesConfigWindow::AddNewGroup(entry_ref *dirRef, entry_ref *newGroup) -{ - BDirectory dir(dirRef); - - char directoryName[B_FILE_NAME_LENGTH]; - GetNextGroupName(&dir, directoryName); - - BDirectory subdir; - dir.CreateDirectory(directoryName, &subdir); - - BEntry entry; - subdir.GetEntry(&entry); - entry.GetRef(newGroup); -} - - -void -TFavoritesConfigWindow::AddSymLink(const entry_ref *dirRef, const entry_ref *target) -{ - BDirectory dir(dirRef); - BEntry entry(target); - BPath path; - entry.GetPath(&path); - BSymLink symlink; - dir.CreateSymLink(target->name, path.Path(), &symlink); -} - - -void -TFavoritesConfigWindow::AddNewGroup() -{ - // from New Group/Folder button - // add a new group/folder to this directory - entry_ref newGroup; - AddNewGroup(&fCurrentRef, &newGroup); -} - - -void -TFavoritesConfigWindow::PromptForAdd() -{ - if (fAddPanel) - fAddPanel->Show(); - // does an activate on the window - else { - BMessenger messenger(this, this); - // determine a starting point for where apps are added from - char appPath[B_PATH_NAME_LENGTH]; - - // search for an apps directory - if (find_directory(B_APPS_DIRECTORY, 0, false, appPath, B_PATH_NAME_LENGTH) == B_OK) { - entry_ref ref; - - // get reference to application directory - get_ref_for_path(appPath, &ref); - fAddPanel = new BFilePanel(B_OPEN_PANEL, &messenger, - &ref, fFilePanelNodeFlavors, true); - } else - fAddPanel = new BFilePanel(B_OPEN_PANEL, &messenger, - NULL, fFilePanelNodeFlavors, true); - - fAddPanel->SetButtonLabel(B_DEFAULT_BUTTON, "Add"); - fAddPanel->Show(); - } -} - - -void -TFavoritesConfigWindow::AddRefs(BMessage *message) -{ - // add any refs in the message to the current directory - int32 index = 0; - entry_ref ref; - while (message->FindRef("refs", index, &ref) == B_OK) { - AddSymLink(&fCurrentRef, &ref); - index++; - } -} - - -// open a new ref to show, tunnelling down - -void -TFavoritesConfigWindow::OpenGroup(const entry_ref *ref) -{ - if (!ref) - return; - - fCurrentRef = *ref; - fMenuThing->SetStartRef(&fCurrentRef); - fMenuThing->SetValue(0); - - BMessage *message = new BMessage(kShowGroup); - message->AddRef("current", &fCurrentRef); - - ModelMenuItem *item = new ModelMenuItem(new Model(&fCurrentRef), fCurrentRef.name, message); - fGroupMenu->AddItem(item); - item->SetMarked(true); - - UpdateButtons(); -} - - -// specify a new ref to show, tunnelling up - -void -TFavoritesConfigWindow::ShowGroup(const entry_ref *groupRef) -{ - if (!groupRef) - return; - - entry_ref lastRef = fCurrentRef; - - fCurrentRef = *groupRef; - fMenuThing->SetStartRef(&fCurrentRef); - fMenuThing->Select(&lastRef); - - // find the item that was selected - int32 count = fGroupMenu->CountItems() - 1; - for (int32 index = count ; index >= 0 ; index--) { - BMenuItem *item = fGroupMenu->ItemAt(index); - if (item) { - BMessage *message = item->Message(); - if (message) { - entry_ref ref; - if (message->FindRef("current", &ref) == B_OK) { - - // if we have a match - // delete all the items below this item - if (ref == fCurrentRef) { - for (int32 j = count ; j > index ; j--) - delete fGroupMenu->RemoveItem(j); - - item->SetMarked(true); - break; - } - } - } - } - } - - UpdateButtons(); -} - - -void -TFavoritesConfigWindow::UpdateButtons() -{ - // Open is enabled only if this item is an actual directory - // Edit is enabled for any selection - // Remove is selected only if there is a selection - // Add is always enabled - int32 selection = fMenuThing->Value(); - - if (selection >= 0 && selection < fMenuThing->ItemCount()) - fOpenBtn->SetEnabled(fMenuThing->ItemAt(selection)->IsDirectory()); - else - fOpenBtn->SetEnabled(false); - - fEditBtn->SetEnabled(selection >= 0); - fRemoveBtn->SetEnabled(selection >= 0); -} - - -void -TFavoritesConfigWindow::UpdateFoldersCount(int32 count, bool notifyTracker) -{ - if (count == -1) - count = atoi(fRecentFoldersFld->Text()); - - BMessage message(kUpdateFolderCount); - message.AddInt32("count", count); - fParent.SendMessage(&message); - - if (notifyTracker) { - BMessenger tracker(kTrackerSignature); - BMessage notificationMessage(kFavoriteCountChangedExternally); - notificationMessage.AddInt32("RecentFolders", count); - tracker.SendMessage(¬ificationMessage); - } -} - - -void -TFavoritesConfigWindow::UpdateDocsCount(int32 count, bool notifyTracker) -{ - if (count == -1) - count = atoi(fRecentDocsFld->Text()); - - BMessage message(kUpdateDocsCount); - message.AddInt32("count", count); - fParent.SendMessage(&message); - - if (notifyTracker) { - BMessenger tracker(kTrackerSignature); - BMessage notificationMessage(kFavoriteCountChangedExternally); - notificationMessage.AddInt32("RecentDocuments", count); - tracker.SendMessage(¬ificationMessage); - } -} - - -void -TFavoritesConfigWindow::UpdateAppsCount(int32 count, bool notifyTracker) -{ - if (count == -1) - count = atoi(fRecentAppsFld->Text()); - - BMessage message(kUpdateAppsCount); - message.AddInt32("count", count); - fParent.SendMessage(&message); - - if (notifyTracker) { - BMessenger tracker(kTrackerSignature); - BMessage notificationMessage(kFavoriteCountChangedExternally); - notificationMessage.AddInt32("RecentApplications", count); - tracker.SendMessage(¬ificationMessage); - } -} - - -// *************************************************************************************** - - -TDraggableIconButton::TDraggableIconButton(BRect frame, const char *label, - BMessage *message, uint32 resizeMask, uint32 flags) - : BControl(frame, "draggable icon", label, message, resizeMask, flags), - fIcon(NULL) -{ -} - - -TDraggableIconButton::~TDraggableIconButton() -{ -} - - -void -TDraggableIconButton::AttachedToWindow() -{ - BControl::AttachedToWindow(); - - if (Parent()) - SetViewColor(Parent()->ViewColor()); - else - SetViewColor(ui_color(B_PANEL_BACKGROUND_COLOR)); - - fIcon = new BBitmap(BRect(0, 0, 31, 31), B_CMAP8); - fIcon->SetBits(kLargeNewGroupIcon, fIcon->BitsLength(), 0, B_CMAP8); - // calculate correct frame for icon and label - // sets icon rect and label rect for drawing - ResizeToPreferred(); -} - - -void -TDraggableIconButton::DetachedFromWindow() -{ - BControl::DetachedFromWindow(); - delete fIcon; - fIcon = NULL; -} - - -void -TDraggableIconButton::Draw(BRect) -{ - PushState(); - - SetHighColor(kBlack); - SetLowColor(ViewColor()); - - if (fIcon) { - SetDrawingMode(B_OP_OVER); - DrawBitmapAsync(fIcon, fIconRect); - } - - SetDrawingMode(B_OP_COPY); - MovePenTo(fLabelRect.LeftBottom()); - DrawString(Label()); - - if (IsEnabled() && IsFocus() && Window()->IsActive()) - SetHighColor(kBlack); - else - SetHighColor(ViewColor()); - StrokeRect(Bounds()); - - PopState(); -} - - -void -TDraggableIconButton::MouseDown(BPoint where) -{ - ulong buttons; - BPoint loc; - GetMouse(&loc, &buttons); - if (!buttons) - return; - - fInitialClickRect.Set(where.x, where.y, where.x, where.y); - fInitialClickRect.InsetBy(-4, -4); - SetTracking(true); - fDragging = false; - SetMouseEventMask(B_POINTER_EVENTS, B_NO_POINTER_HISTORY | B_LOCK_WINDOW_FOCUS); - InvertRect(fIconRect); -} - - -void -TDraggableIconButton::MouseUp(BPoint where) -{ - if (IsTracking()) { - InvertRect(fIconRect); - SetTracking(false); - fDragging = false; - if (Bounds().Contains(where) && fInitialClickRect.Contains(where)) - // tell parent to add a new group - Invoke(); - - } else - BControl::MouseUp(where); -} - - -void -TDraggableIconButton::MouseMoved(BPoint where, uint32 code, - const BMessage *message) -{ - if (IsTracking()) { - if (!fDragging && fIcon) { - DragMessage(new BMessage('icon'), new BBitmap(fIcon), - B_OP_BLEND, BPoint(15, 15)); - fDragging = true; - fInitialClickRect.Set(0, 0, 0, 0); - } - } else - BControl::MouseMoved(where, code, message); -} - - -void -TDraggableIconButton::GetPreferredSize(float *width, float *height) -{ - float stringWidth = be_plain_font->StringWidth(Label()); - float fontHeight = FontHeight(be_plain_font, true); - *width = stringWidth + 10; - *height = 32 + fontHeight + 5; - - fIconRect.Set((*width / 2) - 16, 2, (*width / 2) + 15, 33); - fLabelRect.Set((*width / 2) - (stringWidth / 2), - *height - fontHeight - 5, *width, *height - 5); -} - - -void -TDraggableIconButton::ResizeToPreferred() -{ - float width, height; - GetPreferredSize(&width, &height); - ResizeTo(width, height); -} - - -const float kLeftGutter = 15.0f; -const float kHorizontalGap = 4.0f; -const float kItemGap = 4.0f; -const float kVerticalBorderSize = 2.0f; -const float kHorizontalBorderSize = 2.0f; -const int32 kMaxItemCount = 12; -const float kScrollerHeight = 16.0f; - - -TContentsMenu::TContentsMenu(BRect frame, BMessage *singleClick, BMessage *doubleClick, - int32 visibleItemCount, const entry_ref *startRef) - : BControl(frame, "contents menu", "contents menu label", - singleClick, B_FOLLOW_NONE, B_WILL_DRAW | B_NAVIGABLE), - fDoubleClickMessage(doubleClick), - fVisibleItemCount(visibleItemCount), - fStartRef(*startRef), - fItemHeight(16), -#ifdef ITEM_EDIT - fEditingItem(false), - fEditingFld(NULL), -#endif - fFirstItem(0), - fContentsList(NULL), - fUpBtn(NULL), - fDownBtn(NULL) -{ -} - - -TContentsMenu::~TContentsMenu() -{ - delete fDoubleClickMessage; -} - - -void -TContentsMenu::AttachedToWindow() -{ - BControl::AttachedToWindow(); - - menu_info minfo; - get_menu_info(&minfo); - - // cache the menu font for drawing later on -#ifdef USE_MENU_FONT - // !! this should change when the menu font is used - fMenuFont = new BFont(); - fMenuFont->SetFamilyAndStyle(minfo.f_family, minfo.f_style); - fMenuFont->SetSize(minfo.font_size); -#else - fMenuFont = new BFont(be_plain_font); -#endif - // cache the item height, greater of font height and icon height - fFontHeight = FontHeight(fMenuFont, true); - fItemHeight = (fFontHeight>fItemHeight) ? fFontHeight : fItemHeight; - fItemHeight += 3; // add a gutter - - // mimicing a menu - SetViewColor(minfo.background_color); -#ifdef SNAKE - fHiliteColor = ui_color(B_MENU_SELECTION_BACKGROUND_COLOR); -#else - fHiliteColor = tint_color(minfo.background_color, B_DARKEN_2_TINT); -#endif - // add the buttons - // cache item frame, sub of frame - buttons - fContentsList = new BObjectList(kMaxItemCount); - - SetValue(-1); // no item selected - - ResizeToPreferred(); - - BRect frame(2, 2, Bounds().Width() - 2, 2 + kScrollerHeight); - fUpBtn = new TScrollerButton(frame, new BMessage(kScrollDown), true); - AddChild(fUpBtn); - fUpBtn->SetTarget(this, Window()); - - frame.bottom = Bounds().Height()-2; - frame.top = frame.bottom - kScrollerHeight; - fDownBtn = new TScrollerButton(frame, new BMessage(kScrollUp), false); - AddChild(fDownBtn); - fDownBtn->SetTarget(this, Window()); - - // cache the new group icon - fSmallGroupIcon = new BBitmap(BRect(0, 0, 15, 15), B_CMAP8); - fSmallGroupIcon->SetBits(kSmallNewGroupIcon, fSmallGroupIcon->BitsLength(), - 0, B_CMAP8); - - // cache the symlink icon - BMimeType symlink("application/x-vnd.Be-symlink"); - if (symlink.InitCheck() == B_OK) { - fSymlinkIcon = new BBitmap(BRect(0, 0, 15, 15), B_CMAP8); - if (symlink.GetIcon(fSymlinkIcon, B_MINI_ICON) != B_OK) - fSymlinkIcon = NULL; - } else - fSymlinkIcon = NULL; - - // set up node watch etc - SetStartRef(&fStartRef); -} - - -void -TContentsMenu::DetachedFromWindow() -{ - EmptyMenu(); - delete fContentsList; - fContentsList = NULL; - delete fMenuFont; - fMenuFont = NULL; - delete fSmallGroupIcon; - fSmallGroupIcon = NULL; - delete fSymlinkIcon; - fSymlinkIcon = NULL; - BControl::DetachedFromWindow(); -} - - -const char *kUntitledItemStr = ""; - -void -TContentsMenu::Draw(BRect updateRect) -{ - PushState(); - - // draw frame - SetLowColor(ViewColor()); - - BRect frame(Bounds()); - // main border - -#ifdef SNAKE - SetHighColor(kBlack); - StrokeRoundRect(frame, 3.0, 3.0); -#else - // exterior border - SetHighColor(100, 100, 100); - StrokeRect(frame); - - // interior white - SetHighColor(233, 233, 233); - // top - StrokeLine(frame.LeftTop() + BPoint(1, 1), frame.RightTop() + BPoint(-1, 1)); - // left - StrokeLine(frame.LeftTop() + BPoint(1, 1), frame.LeftBottom() + BPoint(1, -1)); - - // interior gray - SetHighColor(141, 141, 141); - // right - StrokeLine(frame.RightTop() + BPoint(-1, -1), frame.RightBottom() + BPoint(-1, -1)); - // bottom - StrokeLine(frame.LeftBottom() + BPoint(1, -1), frame.RightBottom() + BPoint(-1, -1)); - -#endif - - SetDrawingMode(B_OP_OVER); - - BRect iconFrame, textFrame, itemFrame; - - int32 max = fContentsList->CountItems() - fFirstItem; - int32 count = (max > kMaxItemCount) ? kMaxItemCount : max; - count += fFirstItem; - - for (int32 index = fFirstItem ; index < count ; index++) { - Model *item = fContentsList->ItemAt(index); - if (!item) - continue; - - if (!ItemFrame(index - fFirstItem, &iconFrame, &textFrame, &itemFrame)) - continue; - - if (!itemFrame.Intersects(updateRect)) - continue; - - // see if an item is selected - if (Value() == index) { - SetHighColor(fHiliteColor); - SetLowColor(fHiliteColor); -#ifdef SNAKE - FillRoundRect(itemFrame, 3.0, 3.0); - - // main frame - SetHighColor(kBlack); - StrokeRoundRect(itemFrame, 3.0, 3.0); -#else - FillRect(itemFrame); -#endif - } else { - SetHighColor(ViewColor()); - SetLowColor(ViewColor()); - FillRect(itemFrame); - } - - Model resolvedItem; - if (item->IsSymLink()) { - // if this item is a symlink - // see if it points to anything - // if it doesn't draw the broken symlink icon - BEntry entry(item->EntryRef(), true); - resolvedItem.SetTo(&entry); - if (entry.Exists()) { - // draw the real item icon - IconCache::sIconCache->Draw(&resolvedItem, this, iconFrame.LeftTop(), - kNormalIcon, B_MINI_ICON); - } else if (fSymlinkIcon){ - - SetDrawingMode(B_OP_OVER); - DrawBitmapAsync(fSymlinkIcon, iconFrame); - // this item doesn't exist - // get the name that the symlink has - resolvedItem.SetTo(item->EntryRef()); - } else { - // shouldn't ever get here - TRESPASS(); - entry_ref ref; - ref.set_name(""); - resolvedItem.SetTo(&ref); - } - } else { - if (item->IsDirectory() && fSmallGroupIcon) { - SetDrawingMode(B_OP_OVER); - DrawBitmapAsync(fSmallGroupIcon, iconFrame); - } else - IconCache::sIconCache->Draw(item, this, iconFrame.LeftTop(), - kNormalIcon, B_MINI_ICON); - - resolvedItem.SetTo(item->EntryRef()); - } - - // get the name of the resolved ref - // if this item points to /boot - // will retrieve the user name instead - const char *name = NULL; - if (resolvedItem.IsVolume()) { - BVolume volume(resolvedItem.NodeRef()->device); - char volumeName[B_FILE_NAME_LENGTH]; - volume.GetName(volumeName); - - name = volumeName; - } else if (item->IsSymLink()) { - // use the items symlink name - name = item->EntryRef()->name; - } else if (resolvedItem.Name() && resolvedItem.Name()[0] != '\0') - // use the items actual name - name = resolvedItem.Name(); - else - name = kUntitledItemStr; - - // truncate to fit appropriately - BString truncatedString(name); - fMenuFont->TruncateString(&truncatedString, B_TRUNCATE_END, textFrame.Width()); - - SetHighColor(kBlack); - SetFont(fMenuFont); - MovePenTo(textFrame.LeftBottom()); - DrawString(truncatedString.String()); - } - - PopState(); -} - - -void -TContentsMenu::InvalidateItem(int32 index) -{ - BRect dummy, itemrect; - if (ItemFrame(index, &dummy, &dummy, &itemrect)) - Invalidate(itemrect); -} - - -void -TContentsMenu::InvalidateAbsoluteItem(int32 index) -{ - index -= fFirstItem; - if (index >= 0 && index < kMaxItemCount) - InvalidateItem(index); -} - - -void -TContentsMenu::KeyDown(const char *bytes, int32 numBytes) -{ - if (IsEnabled() && IsFocus() && Window()->IsActive()) { - switch (bytes[0]) { - case B_DOWN_ARROW: - case B_LEFT_ARROW: - { -#ifdef ITEM_EDIT - StopItemEdit(); -#endif - int32 selection = Value() + 1; - if (selection < fContentsList->CountItems()) { - SetValueNoUpdate(selection); - InvalidateAbsoluteItem(selection - 1); - InvalidateAbsoluteItem(selection); - Invoke(); - } - // - // if the selection is the last item - // scroll the list down - // bottom item will be the selection - // - if (Value() - fFirstItem == kMaxItemCount) - Scroll(true); - } - break; - case B_UP_ARROW: - case B_RIGHT_ARROW: - { -#ifdef ITEM_EDIT - StopItemEdit(); -#endif - int32 selection = Value()-1; - if (selection >= 0) { - SetValueNoUpdate(selection); - InvalidateAbsoluteItem(selection + 1); - InvalidateAbsoluteItem(selection); - Invoke(); - } - - if (Value() - fFirstItem < 0) - Scroll(false); - } - break; - case B_ENTER: - case B_SPACE: - OpenItem(Value()); - break; - default: - BControl::KeyDown(bytes, numBytes); - break; - } - } -} - - -void -TContentsMenu::MessageReceived(BMessage *message) -{ - if (message->WasDropped()) { - if (message->what == 'icon') { - BPoint where; - if (message->FindPoint("_drop_point_", &where) != B_OK) { - where.x = -1; - where.y = -1; - } - AddTempItem(where); - } else { - TFavoritesConfigWindow *window = dynamic_cast(Window()); - if (window) - window->AddRefs(message); - } - } - - switch (message->what) { - // node monitor of be menu directory - case B_NODE_MONITOR: - { - // stash the entry_ref to the selected item - // use it after FillMenu to reselect the item - const entry_ref *oldref = ItemAt(Value())->EntryRef(); - entry_ref ref; - if (!oldref) - ref.set_name(""); - else - ref = *oldref; - - EmptyMenu(); - FillMenu(&fStartRef); - Select(&ref); - // checks for invalid ref - Invalidate(); - - // ask the window to update the buttons - Window()->PostMessage(kItemSelected); - } - break; - - // down button - case kScrollUp: -#ifdef ITEM_EDIT - StopItemEdit(); -#endif - Scroll(true); - break; - - // up button - case kScrollDown: -#ifdef ITEM_EDIT - StopItemEdit(); -#endif - Scroll(false); - break; - - default: - BControl::MessageReceived(message); - break; - } -} - - -void -TContentsMenu::MouseDown(BPoint where) -{ -#ifdef ITEM_EDIT - StopItemEdit(); -#endif - - bigtime_t clicktime; - get_click_speed(&clicktime); - - bigtime_t diff = system_time() - fInitialClickTime; - if (diff < clicktime && fInitialClickRect.Contains(where)) { - OpenItem(Value()); - return; - } - - fInitialClickRect.Set(where.x, where.y, where.x, where.y); - fInitialClickRect.InsetBy(-2, -2); - fInitialClickTime = system_time(); - - StartTracking(where); - MakeFocus(true); - SetMouseEventMask(B_POINTER_EVENTS); -} - - -void -TContentsMenu::StartTracking(BPoint where) -{ - SelectItemAt(where); - SetTracking(true); -} - - -void -TContentsMenu::StopTracking() -{ - if (IsTracking()) - SetTracking(false); -} - - -void -TContentsMenu::MouseUp(BPoint where) -{ - StopTracking(); -#ifdef ITEM_EDIT - BeginItemEdit(where); -#endif - BControl::MouseUp(where); -} - - -#ifdef ITEM_EDIT -void -TContentsMenu::BeginItemEdit(BPoint where) -{ - bigtime_t clicktime; - get_click_speed(&clicktime); - - bigtime_t diff = system_time() - fInitialClickTime; - - if (where == fInitialClickLoc && (diff > clicktime)) { - BRect iconFrame, textFrame, itemFrame; - - // !! get textFrame instead - // set viewcolor to menucolor - fItemIndex = ItemAt(where, &iconFrame, &textFrame, &itemFrame) + fFirstItem; - if (fItemIndex >= 0) { - // find the item - // add a textview - fEditingItem = true; - - delete fEditingFld; - - BRect trect(textFrame); - trect.OffsetTo(0, 0); - fEditingFld = new BTextView(textFrame, "edit", trect, B_FOLLOW_NONE); - AddChild(fEditingFld); - fEditingFld->SetViewColor(fHiliteColor); - - fEditingFld->SetText(ItemAt(fItemIndex)->EntryRef()->name); - fEditingFld->SelectAll(); - } - } else - fEditingItem = false; -} -#endif - - -#ifdef ITEM_EDIT -void -TContentsMenu::StopItemEdit() -{ - if (fEditingItem && fEditingFld) { - if (fItemIndex > -1) { - const char *name = fEditingFld->Text(); - const entry_ref *ref = ItemAt(fItemIndex)->EntryRef(); - if (strcmp(ref->name, name) != 0) { - BEntry entry(ref); - if (entry.InitCheck() == B_OK && entry.Exists()) - entry.Rename(name); - } - } - - // dispose the textview - if (fEditingFld) { - fEditingFld->RemoveSelf(); - delete fEditingFld; - fEditingFld = NULL; - fEditingItem = false; - fItemIndex = -1; - } - } -} -#endif - - -void -TContentsMenu::MouseMoved(BPoint where, uint32 code, const BMessage *message) -{ - switch (code) { - case B_ENTERED_VIEW: - - // if there is a message incoming - // then track with it for attempt at - // placement drop - // !! disabled for now -#if 0 - if (message) { - SelectItemAt(where); - SetTracking(true); - } -#endif - break; - - case B_INSIDE_VIEW: - if (IsTracking()) - SelectItemAt(where); - break; - - case B_EXITED_VIEW: - break; - - } - BControl::MouseMoved(where, code, message); -} - - -void -TContentsMenu::GetPreferredSize(float *width, float *height) -{ - // width should accomodate border, left gap, icon, separation, text, border - // height should acccomodate 14 itemheights + borders - - *width = kLeftGutter + B_MINI_ICON + kItemGap - + (fMenuFont->StringWidth("O") * 15) - + (2 * kVerticalBorderSize); - - *height = (2 * kScrollerHeight) // buttons - + (kMaxItemCount * fItemHeight) // items - + (2 * kHorizontalBorderSize) + 1; // border -} - - -void -TContentsMenu::ResizeToPreferred() -{ - float width, height; - GetPreferredSize(&width, &height); - ResizeTo(width, height); -} - - -void -TContentsMenu::SetStartRef(const entry_ref *ref) -{ - node_ref nref; - BEntry entry(&fStartRef); - if (entry.InitCheck() == B_OK) { - entry.GetNodeRef(&nref); - watch_node(&nref, B_STOP_WATCHING, this, Window()); - } - - fStartRef = *ref; - entry.SetTo(&fStartRef); - entry.GetNodeRef(&nref); - watch_node(&nref, B_WATCH_DIRECTORY, this, Window()); - - EmptyMenu(); - FillMenu(&fStartRef); - Invalidate(); -} - - -void -TContentsMenu::UpdateScrollers() -{ - int32 count = fContentsList->CountItems(); - if (count <= kMaxItemCount) { - fUpBtn->SetEnabled(false); - fDownBtn->SetEnabled(false); - } else { - fUpBtn->SetEnabled(fFirstItem != 0); - fDownBtn->SetEnabled(count-fFirstItem > kMaxItemCount); - } -} - - -void -TContentsMenu::Scroll(bool direction) -{ - int32 count = fContentsList->CountItems(); - if (count <= kMaxItemCount) - return; - - bool needtoupdate = false; - if (direction && fDownBtn->IsEnabled()) { // down - if ((count - fFirstItem) > kMaxItemCount) { - fFirstItem++; - needtoupdate = true; - } - } else if (!direction && fUpBtn->IsEnabled()) { // up - if (fFirstItem >= 1) { - fFirstItem--; - needtoupdate = true; - } - } - - if (needtoupdate) { - UpdateScrollers(); - BRect dummy, highrect; - ItemFrame(0, &dummy, &dummy, &highrect); - highrect.bottom = highrect.bottom + fItemHeight * (kMaxItemCount - 2); - BRect lowrect = highrect.OffsetByCopy(0, fItemHeight); - if (direction) { - CopyBits(lowrect, highrect); - InvalidateItem(kMaxItemCount - 1); - } else { - CopyBits(highrect, lowrect); - InvalidateItem(0); - } - } -} - - -static int -CompareOne(const Model *model1, const Model *model2) -{ - return strcasecmp(model1->Name(), model2->Name()); -} - - -void -TContentsMenu::FillMenu(const entry_ref *ref) -{ - if (!fContentsList) - fContentsList = new BObjectList(kMaxItemCount); - - BEntry entry(ref); - if (entry.InitCheck() == B_OK && entry.Exists()) { - BDirectory dir(ref); - BEntry nextEntry; - while (dir.GetNextEntry(&nextEntry) == B_OK) { - - // create a model for the actual item in the be folder - Model *model = new Model(&nextEntry); - fContentsList->AddItem(model); - } - - fContentsList->SortItems(CompareOne); - } - - int32 count = fContentsList->CountItems(); - if (count <= kMaxItemCount) - fFirstItem = 0; - else if (count - fFirstItem < kMaxItemCount) - fFirstItem = count - kMaxItemCount; - - UpdateScrollers(); -} - - -void -TContentsMenu::EmptyMenu() -{ - if (!fContentsList) - return; - - int32 count = fContentsList->CountItems()-1; - for (int32 index = count ; index >= 0 ; index--) { - Model *item = fContentsList->ItemAt(index); - if (item) { - fContentsList->RemoveItem(item); - delete item; - } - } -} - - -/** returns frames for visible items */ - -bool -TContentsMenu::ItemFrame(int32 index, BRect *iconFrame, BRect *textFrame, - BRect *itemFrame) const -{ - if (index >= kMaxItemCount || index < 0) - return false; - - float halfheight = fItemHeight / 2; - float halficon = B_MINI_ICON / 2; - float halffont = fFontHeight / 2; - BPoint loc; - loc.x = kLeftGutter; - loc.y = fUpBtn->Frame().bottom + 1 + halfheight; - - loc.y += index * fItemHeight; - - iconFrame->Set(loc.x, loc.y - halficon, loc.x + B_MINI_ICON, loc.y + halficon); - - textFrame->Set(loc.x + B_MINI_ICON + kItemGap, loc.y - halffont, - Bounds().right - 2, loc.y + halffont); - - itemFrame->Set(2, loc.y - halfheight, Bounds().Width() - 2, loc.y + halfheight - 1); - - return true; -} - - -/** returns index of visible item at location */ - -int32 -TContentsMenu::ItemAt(BPoint where, BRect *iconFrame, BRect *textFrame, - BRect *itemFrame) -{ - int32 count = fContentsList->CountItems(); - count = (count < kMaxItemCount) ? count : kMaxItemCount; - for (int32 index = 0 ; index < count ; index++) - if (ItemFrame(index, iconFrame, textFrame, itemFrame) - && itemFrame->Contains(where)) - return index; - - return -1; -} - - -/** returns entry_ref for item at absolute index */ - -const Model* -TContentsMenu::ItemAt(int32 index) const -{ - return fContentsList->ItemAt(index); -} - - -void -TContentsMenu::SelectItemAt(BPoint where) -{ - BRect iconFrame, textFrame, itemFrame; - - int32 previousvalue = Value(); - // get visible item - int32 index = ItemAt(where, &iconFrame, &textFrame, &itemFrame); - if (index <= -1) { - SetValueNoUpdate(-1); - Invoke(); - } else { - // get offset to actual item selected - index += fFirstItem; - if (index != Value()) { - SetValueNoUpdate(index); - Invoke(); - } - } - int32 newvalue = Value(); - if (previousvalue != newvalue) { - InvalidateAbsoluteItem(previousvalue); - InvalidateAbsoluteItem(newvalue); - } -} - - -void -TContentsMenu::Select(const entry_ref *ref) -{ - int32 select = -1; - if (ref && ref->name && ref->name[0] != '\0') { - int32 count = fContentsList->CountItems(); - for (int32 index = 0 ; index < count ; index++) { - Model *item = fContentsList->ItemAt(index); - if (item) { - if (*ref == *(item->EntryRef())) { - select = index; - break; - } - } - } - } - SetValue(select); - Invoke(); -} - - -void -TContentsMenu::OpenItem(int32 index) -{ - if (Value() >= 0 && index >= 0 && index < fContentsList->CountItems()) { - Model *item = fContentsList->ItemAt(index); - // see if we have an item - // only actual directories can be traversed - // and only if their hierarchy lives in the Be folder - - if (item && item->IsDirectory()) { - // if we have a double click message - // pass the new directory ref to the window - if (fDoubleClickMessage) { - if (fDoubleClickMessage->HasRef("current")) - fDoubleClickMessage->ReplaceRef("current", item->EntryRef()); - else - fDoubleClickMessage->AddRef("current", item->EntryRef()); - - Invoke(fDoubleClickMessage); - } - } - } -} - - -int32 -TContentsMenu::ItemCount() const -{ - return fContentsList->CountItems(); -} - - -static void -RemoveEntries(const entry_ref *ref) -{ - // should this delete on DB created items? - - BEntry entry(ref); - if (entry.InitCheck() == B_OK && entry.Exists()) { - // if its a directory - // check for contents and delete as necessary - if (entry.IsDirectory()) { - BDirectory dir(&entry); - BEntry nextEntry; - while (dir.GetNextEntry(&nextEntry) == B_OK) { - if (nextEntry.IsDirectory()) { - entry_ref nextref; - nextEntry.GetRef(&nextref); - RemoveEntries(&nextref); - } else - nextEntry.Remove(); - } - } - entry.Remove(); - } -} - - -void -TContentsMenu::RemoveItem(int32 index) -{ - int32 count = ItemCount() - 1; - - // index out of bounds - if (index < 0 || index > count) - return; - - RemoveEntries(ItemAt(index)->EntryRef()); - - // index was last item - if (index == count) { - SetValue(index - 1); - Invoke(); - } -} - - -void -TContentsMenu::AddTempItem(BPoint) -{ - // !! need to make a fake item for editing - // defaults, now, to simply adding a folder - TFavoritesConfigWindow *window = dynamic_cast(Window()); - if (window) - window->AddNewGroup(); -} - - -// *************************************************************************************** -// #pragma mark - - - -TScrollerButton::TScrollerButton(BRect frame, BMessage *message, bool direction) - : BControl(frame, "scroller", "scroller label", message, - B_FOLLOW_NONE, B_WILL_DRAW), - fDirection(direction), - fTicker(NULL) -{ -} - - -void -TScrollerButton::AttachedToWindow() -{ - BControl::AttachedToWindow(); - - menu_info minfo; - get_menu_info(&minfo); - fSelectedColor = tint_color(minfo.background_color, B_DARKEN_2_TINT); - - SetViewColor(minfo.background_color); - - fHiliteFrame = Bounds(); - if (fDirection) - fHiliteFrame.bottom -= 6; - else - fHiliteFrame.top += 4; -} - - -void -TScrollerButton::DetachedFromWindow() -{ - delete fTicker; - BControl::DetachedFromWindow(); -} - - -void -TScrollerButton::Draw(BRect) -{ - - PushState(); - - if (Value() == 0 || !IsEnabled()) { - SetLowColor(ViewColor()); - SetHighColor(ViewColor()); - } else { - SetLowColor(fSelectedColor); - SetHighColor(fSelectedColor); - } - - FillRect(fHiliteFrame); - - // add the triangle - if (IsEnabled()) - SetHighColor(kMediumGray); - else - SetHighColor(tint_color(kMediumGray, B_LIGHTEN_1_TINT)); - - float width = Bounds().Width(); - int32 linecount = Bounds().IntegerHeight() - 9; - - BPoint start(width / 2, fDirection ? 2 : Bounds().Height()-2); - BPoint finish(start); - - for (int32 index = 0 ; index < linecount ; index++) { - StrokeLine(start, finish); - --start.x; - ++finish.x; - if (fDirection) { - ++start.y; - ++finish.y; - } else { - --start.y; - --finish.y; - } - } - - // add the top/bottom delimiter - SetHighColor(kLightGray); - float y = fDirection ? start.y + 2 : start.y - 3; - StrokeLine(BPoint(0, y), BPoint(width, y)); - SetHighColor(kAlmostWhite); - y = fDirection ? start.y + 3 : start.y - 2; - StrokeLine(BPoint(0, y), BPoint(width, y)); - - PopState(); -} - - -void -TScrollerButton::MouseDown(BPoint where) -{ - if (IsEnabled() && fHiliteFrame.Contains(where)) { - SetValue(1); - Invoke(); - SetTracking(true); - SetMouseEventMask(B_POINTER_EVENTS); - fTicker = new BMessageRunner(BMessenger(Target()), Message(), 120000); - } -} - - -void -TScrollerButton::MouseUp(BPoint) -{ - SetValue(0); - delete fTicker; - fTicker = NULL; - if (IsTracking()) - SetTracking(false); -} - - -void -TScrollerButton::MouseMoved(BPoint where, uint32 code, const BMessage *message) -{ - switch (code) { - case B_EXITED_VIEW: - delete fTicker; - fTicker = NULL; - SetValue(0); - break; - - case B_ENTERED_VIEW: - if (IsEnabled() && IsTracking()) { - SetValue(1); - Invoke(); - fTicker = new BMessageRunner(BMessenger(Target()), Message(), 120000); - } - break; - - default: - break; - } - BControl::MouseMoved(where, code, message); -} - - -// *************************************************************************************** - -const char *kNewItemNameLabel = "New item name:"; - -const int32 kPanelWidth = 260; -const int32 kPanelHeight = 77; - -NameItemPanel::NameItemPanel(BWindow *parent, const char *initialtext) - : BWindow(BRect(0, 0, kPanelWidth, kPanelHeight), "", B_MODAL_WINDOW, - B_NOT_RESIZABLE | B_NOT_ZOOMABLE | B_NOT_CLOSABLE), - fParent(parent) -{ - MoveTo(-1024, -1024); - Show(); - Lock(); - AddParts(initialtext); - ResizeTo(Bounds().Width(), fCancelBtn->Frame().bottom + 10); - Unlock(); - CenterOnScreen(); -} - - -NameItemPanel::~NameItemPanel() -{ -} - - -void -NameItemPanel::MessageReceived(BMessage *message) -{ - switch (message->what){ - case 'done': - { - const char *text = fNameFld->Text(); - if (!text || text[0] == '\0'){ - BAlert *alert = new BAlert("", - "The new name is empty, please " - "enter a name", "Cancel", "OK", NULL, - B_WIDTH_AS_USUAL); - alert->SetShortcut(0, B_ESCAPE); - if (alert->Go() == 0) - return; - } - BMessage nameChangeMessage(kNameChange); - nameChangeMessage.AddString("name", text); - fParent->PostMessage(&nameChangeMessage); - PostMessage(B_QUIT_REQUESTED); - } - break; - - case 'canc': - fParent->PostMessage('canc'); - PostMessage(B_QUIT_REQUESTED); - break; - - default: - BWindow::MessageReceived(message); - break; - } -} - - -void -NameItemPanel::AddParts(const char *initialtext) -{ - fBG = new BBox(Bounds(), "bg", B_FOLLOW_ALL, B_WILL_DRAW, B_NO_BORDER); - AddChild(fBG); - - BRect rect(10, 10, Bounds().Width()-10, 11); - fNameFld = new BTextControl(rect, "", kNewItemNameLabel, "", NULL); - fBG->AddChild(fNameFld); - fNameFld->SetDivider(be_plain_font->StringWidth(kNewItemNameLabel) + 10); - fNameFld->SetAlignment(B_ALIGN_RIGHT, B_ALIGN_LEFT); - if (initialtext && strlen(initialtext) > 0) - fNameFld->SetText(initialtext); - fNameFld->MakeFocus(true); - - BTextView *textView = fNameFld->TextView(); - if (textView) - textView->SetMaxBytes(32); - - rect.right = Bounds().Width() - 10; - rect.left = rect.right - 75; - rect.top = fNameFld->Frame().bottom + 10; - rect.bottom = rect.top + 1; - fDoneBtn = new BButton(rect, "", "Change", new BMessage('done'), - B_FOLLOW_TOP | B_FOLLOW_RIGHT); - - rect.right = rect.left - 10; - rect.left = rect.right - 75; - fCancelBtn = new BButton(rect, "", "Cancel", new BMessage('canc'), - B_FOLLOW_TOP | B_FOLLOW_RIGHT); - fBG->AddChild(fCancelBtn); - - fBG->AddChild(fDoneBtn); - SetDefaultButton(fDoneBtn); -} - diff --git a/src/kits/tracker/FavoritesMenu.cpp b/src/kits/tracker/FavoritesMenu.cpp index 8a0f4fa60a..63c69eda59 100644 --- a/src/kits/tracker/FavoritesMenu.cpp +++ b/src/kits/tracker/FavoritesMenu.cpp @@ -74,18 +74,18 @@ FavoritesMenu::~FavoritesMenu() } -bool +bool FavoritesMenu::StartBuildingItemList() { // initialize the menu building state - + if (!fInitialItemCount) fInitialItemCount = CountItems(); else { // strip the old items so we can add new fresh ones int32 count = CountItems() - fInitialItemCount; // keep the items that were added by the FavoritesMenu creator - while (count--) + while (count--) delete RemoveItem(fInitialItemCount); } @@ -95,11 +95,11 @@ FavoritesMenu::StartBuildingItemList() } -bool +bool FavoritesMenu::AddNextItem() { // run the next chunk of code for a given item adding state - + if (fState == kStart) { fState = kAddingFavorites; fSectionItemCount = 0; @@ -118,13 +118,13 @@ FavoritesMenu::AddNextItem() if (!startModel.IsContainer()) throw B_ERROR; - - if (startModel.IsQuery()) + + if (startModel.IsQuery()) fContainer = new QueryEntryListCollection(&startModel); else fContainer = new DirectoryEntryList(*dynamic_cast (startModel.Node())); - + ThrowOnInitCheckError(fContainer); ThrowOnError( fContainer->Rewind() ); @@ -133,13 +133,11 @@ FavoritesMenu::AddNextItem() fContainer = NULL; } } - - if (fState == kAddingFavorites) { + + if (fState == kAddingFavorites) { entry_ref ref; - // limit nav menus to 20 items only if (fContainer - && fSectionItemCount < 20 && fContainer->GetNextRef(&ref) == B_OK) { Model model(&ref, true); if (model.InitCheck() != B_OK) @@ -153,19 +151,19 @@ FavoritesMenu::AddNextItem() if (!fAddedSeparatorForSection) { fAddedSeparatorForSection = true; - AddItem(new TitledSeparatorItem("Favorite Folders")); + AddItem(new TitledSeparatorItem("Favorites")); } fUniqueRefCheck.push_back(*model.EntryRef()); AddItem(item); fSectionItemCount++; return true; } - + // done with favorites, set up for adding recent files fState = kAddingFiles; - + fAddedSeparatorForSection = false; - + app_info info; be_app->GetAppInfo(&info); fItems.MakeEmpty(); @@ -177,7 +175,7 @@ FavoritesMenu::AddNextItem() fIndex = 0; fSectionItemCount = 0; } - + if (fState == kAddingFiles) { // if this is a Save panel, not an Open panel // then don't add the recent documents @@ -189,7 +187,7 @@ FavoritesMenu::AddNextItem() Model model(&ref, true); if (model.InitCheck() != B_OK) return true; - + BMenuItem *item = BNavMenu::NewModelItem(&model, fOpenFileMessage, fTarget); if (item) { if (!fAddedSeparatorForSection) { @@ -202,10 +200,10 @@ FavoritesMenu::AddNextItem() } } } - + // done with recent files, set up for adding recent folders fState = kAddingFolders; - + fAddedSeparatorForSection = false; app_info info; @@ -218,16 +216,16 @@ FavoritesMenu::AddNextItem() BRoster().GetRecentFolders(&fItems, folders, info.signature); fIndex = 0; } - + if (fState == kAddingFolders) { for (;;) { entry_ref ref; if (fItems.FindRef("refs", fIndex++, &ref) != B_OK) break; - + // don't add folders that are already in the GoTo section if (find_if(fUniqueRefCheck.begin(), fUniqueRefCheck.end(), - bind2nd(std::equal_to(), ref)) != fUniqueRefCheck.end()) + bind2nd(std::equal_to(), ref)) != fUniqueRefCheck.end()) continue; Model model(&ref, true); @@ -253,14 +251,14 @@ FavoritesMenu::AddNextItem() } -void +void FavoritesMenu::DoneBuildingItemList() { SetTargetForItems(fTarget); } -void +void FavoritesMenu::ClearMenuBuildingState() { delete fContainer; @@ -300,12 +298,12 @@ RecentsMenu::DetachedFromWindow() { // // BNavMenu::DetachedFromWindow sets the TypesList to NULL - // + // BMenu::DetachedFromWindow(); } -bool +bool RecentsMenu::StartBuildingItemList() { int32 count = CountItems()-1; @@ -327,7 +325,7 @@ RecentsMenu::StartBuildingItemList() } -bool +bool RecentsMenu::AddNextItem() { if (fRecentsCount > 0 && AddRecents(fRecentsCount)) @@ -344,7 +342,7 @@ RecentsMenu::AddRecents(int32 count) if (fItemIndex == 0) { fRecentList.MakeEmpty(); BRoster roster; - + switch(fWhich) { case 0: roster.GetRecentDocuments(&fRecentList, count); @@ -388,7 +386,7 @@ RecentsMenu::AddRecents(int32 count) } -void +void RecentsMenu::DoneBuildingItemList() { // @@ -407,7 +405,7 @@ RecentsMenu::DoneBuildingItemList() } -void +void RecentsMenu::ClearMenuBuildingState() { fMenuBuilt = false; diff --git a/src/kits/tracker/FilePanelPriv.cpp b/src/kits/tracker/FilePanelPriv.cpp index 3dd5334584..48ed1be2c2 100644 --- a/src/kits/tracker/FilePanelPriv.cpp +++ b/src/kits/tracker/FilePanelPriv.cpp @@ -39,7 +39,6 @@ All rights reserved. #include "Commands.h" #include "DesktopPoseView.h" #include "DirMenu.h" -#include "FavoritesConfig.h" #include "FavoritesMenu.h" #include "FilePanelPriv.h" #include "FSUtils.h" @@ -90,7 +89,7 @@ GetLinkFlavor(const Model *model, bool resolve = true) } if (!model) return 0; - + if (model->IsDirectory()) return B_DIRECTORY_NODE; @@ -146,8 +145,7 @@ TFilePanel::TFilePanel(file_panel_mode mode, BMessenger *target, fSelectionIterator(0), fMessage(NULL), fHideWhenDone(hideWhenDone), - fIsTrackingMenu(false), - fConfigWindow(NULL) + fIsTrackingMenu(false) { InitIconPreloader(); @@ -176,7 +174,7 @@ TFilePanel::TFilePanel(file_panel_mode mode, BMessenger *target, bool useRoot = true; if (startDir) { - if (model->SetTo(startDir) == B_OK && model->IsDirectory()) + if (model->SetTo(startDir) == B_OK && model->IsDirectory()) useRoot = false; else { delete model; @@ -199,7 +197,7 @@ TFilePanel::TFilePanel(file_panel_mode mode, BMessenger *target, BVolumeRoster volumeRoster; volumeRoster.GetBootVolume(&volume); volume.GetRootDirectory(&root); - + BEntry entry; root.GetEntry(&entry); model->SetTo(&entry); @@ -229,16 +227,6 @@ TFilePanel::TFilePanel(file_panel_mode mode, BMessenger *target, TFilePanel::~TFilePanel() { - // regardless of the hide/close method - // always get rid of the config window - if (fConfigWindow) { - // moved from QuitRequested to ensure that - // if the config window is showing that - // it gets closed as well - fConfigWindow->Lock(); - fConfigWindow->Quit(); - } - BMessenger tracker(kTrackerSignature); BHandler::StopWatching(tracker, kDesktopFilePanelRootChanged); @@ -302,7 +290,7 @@ TFilePanel::MessageDropFilter(BMessage *message, BHandler **, BMessageFilter *fi panel->fTaskLoop->RunLater(NewMemberFunctionObjectWithResult (&TFilePanel::SelectChildInParent, panel, const_cast(&ref), - const_cast(&child)), + const_cast(&child)), ref == *panel->TargetModel()->EntryRef() ? 0 : 100000, 200000, 5000000); // if the target directory is already current, we won't // delay the initial selection try @@ -327,7 +315,7 @@ TFilePanel::FSFilter(BMessage *message, BHandler **, BMessageFilter *filter) node_ref itemNode; node_ref dirNode; TFilePanel *panel = dynamic_cast(filter->Looper()); - + message->FindInt32("device", &dirNode.device); itemNode.device = dirNode.device; message->FindInt64("to directory", (int64 *)&dirNode.node); @@ -335,8 +323,8 @@ TFilePanel::FSFilter(BMessage *message, BHandler **, BMessageFilter *filter) const char *name; if (message->FindString("name", &name) != B_OK) break; - - // if current directory moved, update entry ref and menu + + // if current directory moved, update entry ref and menu // but not wind title if (*(panel->TargetModel()->NodeRef()) == itemNode) { panel->TargetModel()->UpdateEntryRef(&dirNode, name); @@ -351,7 +339,7 @@ TFilePanel::FSFilter(BMessage *message, BHandler **, BMessageFilter *filter) TFilePanel *panel = dynamic_cast(filter->Looper()); message->FindInt32("device", &itemNode.device); message->FindInt64("node", (int64 *)&itemNode.node); - + // if folder we're watching is deleted, switch to root // or Desktop if (*(panel->TargetModel()->NodeRef()) == itemNode) { @@ -438,7 +426,7 @@ TFilePanel::SetTarget(BMessenger target) void TFilePanel::SetMessage(BMessage *message) -{ +{ delete fMessage; fMessage = new BMessage(*message); } @@ -449,7 +437,7 @@ TFilePanel::SetRefFilter(BRefFilter *filter) { if (!filter) return; - + fPoseView->SetRefFilter(filter); fPoseView->CommitActivePose(); fPoseView->Refresh(); @@ -542,7 +530,7 @@ TFilePanel::AdjustButton() // selection mode then we don't disable button ever if ((modelFlavor == B_DIRECTORY_NODE || linkFlavor == B_DIRECTORY_NODE) - && count == 1) + && count == 1) break; if ((fNodeFlavors & modelFlavor) == 0 @@ -554,7 +542,7 @@ TFilePanel::AdjustButton() } } - button->SetLabel(buttonText); + button->SetLabel(buttonText); button->SetEnabled(enabled); } @@ -576,7 +564,7 @@ TFilePanel::GetNextEntryRef(entry_ref *ref) return B_ERROR; BPose *pose = fPoseView->SelectionList()->ItemAt(fSelectionIterator++); - if (!pose) + if (!pose) return B_ERROR; *ref = *pose->TargetModel()->EntryRef(); @@ -610,9 +598,9 @@ TFilePanel::Init(const BMessage *) BMessenger(this), IsSavePanel()); favorites->AddItem(new BMenuItem("Add Current Folder", new BMessage(kAddCurrentDir))); - favorites->AddItem(new BMenuItem("Configure Favorites"B_UTF8_ELLIPSIS, - new BMessage(kConfigShow))); - + favorites->AddItem(new BMenuItem("Edit Favorites"B_UTF8_ELLIPSIS, + new BMessage(kEditFavorites))); + fMenuBar->AddItem(favorites); // configure menus @@ -695,7 +683,7 @@ TFilePanel::Init(const BMessage *) B_FOLLOW_LEFT | B_FOLLOW_BOTTOM); DisallowMetaKeys(fTextControl->TextView()); DisallowFilenameKeys(fTextControl->TextView()); - fBackView->AddChild(fTextControl); + fBackView->AddChild(fTextControl); fTextControl->SetDivider(0.0f); fTextControl->TextView()->SetMaxBytes(B_FILE_NAME_LENGTH - 1); @@ -743,24 +731,24 @@ TFilePanel::Init(const BMessage *) rect.right -= 25; float default_width = be_plain_font->StringWidth(fButtonText.String()) + 20; rect.left = (default_width > 75) ? (rect.right - default_width) : (rect.right - 75); - + BButton *default_button = new BButton(rect, "default button", fButtonText.String(), new BMessage(kDefaultButton), B_FOLLOW_RIGHT + B_FOLLOW_BOTTOM); fBackView->AddChild(default_button); - + rect.right = rect.left -= 10; float cancel_width = be_plain_font->StringWidth("Cancel") + 20; rect.left = (cancel_width > 75) ? (rect.right - cancel_width) : (rect.right - 75); - + BButton *cancel_button = new BButton(rect, "cancel button", "Cancel", new BMessage(kCancelButton), B_FOLLOW_RIGHT + B_FOLLOW_BOTTOM); fBackView->AddChild(cancel_button); - + if (!fIsSavePanel) default_button->SetEnabled(false); - + default_button->MakeDefault(true); - + RestoreState(); PoseView()->ScrollTo(B_ORIGIN); @@ -768,16 +756,16 @@ TFilePanel::Init(const BMessage *) PoseView()->ScrollTo(B_ORIGIN); if (fTextControl) { - fTextControl->MakeFocus(); + fTextControl->MakeFocus(); fTextControl->TextView()->SelectAll(); } else PoseView()->MakeFocus(); - app_info info; + app_info info; BString title; if (be_app->GetAppInfo(&info) == B_OK) title << info.ref.name << ": "; - + title << fButtonText; // Open or Save SetTitle(title.String()); @@ -786,7 +774,7 @@ TFilePanel::Init(const BMessage *) } -void +void TFilePanel::RestoreState() { BNode defaultingNode; @@ -801,7 +789,7 @@ TFilePanel::RestoreState() } -void +void TFilePanel::SaveState(bool) { BNode defaultingNode; @@ -817,21 +805,21 @@ TFilePanel::SaveState(bool) void TFilePanel::SaveState(BMessage &message) const { - _inherited::SaveState(message); + _inherited::SaveState(message); } -void +void TFilePanel::RestoreWindowState(AttributeStreamNode *node) { SetSizeLimits(360, 10000, 200, 10000); if (!node) return; - const char *rectAttributeName = kAttrWindowFrame; + const char *rectAttributeName = kAttrWindowFrame; BRect frame(Frame()); if (node->Read(rectAttributeName, 0, B_RECT_TYPE, sizeof(BRect), &frame) - == sizeof(BRect)) { + == sizeof(BRect)) { MoveTo(frame.LeftTop()); ResizeTo(frame.Width(), frame.Height()); } @@ -841,18 +829,18 @@ TFilePanel::RestoreWindowState(AttributeStreamNode *node) void TFilePanel::RestoreState(const BMessage &message) { - _inherited::RestoreState(message); + _inherited::RestoreState(message); } void TFilePanel::RestoreWindowState(const BMessage &message) { - _inherited::RestoreWindowState(message); + _inherited::RestoreWindowState(message); } -void +void TFilePanel::AddFileContextMenus(BMenu *menu) { menu->AddItem(new BMenuItem("Get Info", new BMessage(kGetInfo), 'I')); @@ -869,9 +857,9 @@ TFilePanel::AddFileContextMenus(BMenu *menu) } -void +void TFilePanel::AddVolumeContextMenus(BMenu *menu) -{ +{ menu->AddItem(new BMenuItem("Open", new BMessage(kOpenSelection), 'O')); menu->AddItem(new BMenuItem("Get Info", new BMessage(kGetInfo), 'I')); menu->AddItem(new BMenuItem("Edit Name", new BMessage(kEditItem), 'E')); @@ -916,7 +904,7 @@ TFilePanel::AddWindowContextMenus(BMenu *menu) } -void +void TFilePanel::AddDropContextMenus(BMenu *) { } @@ -940,7 +928,7 @@ TFilePanel::MenusBeginning() } -void +void TFilePanel::MenusEnded() { fIsTrackingMenu = false; @@ -974,7 +962,7 @@ TFilePanel::SetButtonLabel(file_panel_button selector, const char *text) BButton *button = dynamic_cast(FindView("cancel button")); if (!button) break; - + float old_width = button->StringWidth(button->Label()); button->SetLabel(text); float delta = old_width - button->StringWidth(text); @@ -999,7 +987,7 @@ TFilePanel::SetButtonLabel(file_panel_button selector, const char *text) button->ResizeBy(-delta, 0); } } - + // now must move cancel button button = dynamic_cast(FindView("cancel button")); if (button) @@ -1045,7 +1033,7 @@ TFilePanel::MessageReceived(BMessage *message) PoseView()->SwitchDir(&ref); SwitchDirMenuTo(&ref); } else { - // Otherwise, we have a file or a link to a file. + // Otherwise, we have a file or a link to a file. // AdjustButton has already tested the flavor; // all we have to do is see if the button is enabled. BButton *button = dynamic_cast(FindView("default button")); @@ -1056,7 +1044,7 @@ TFilePanel::MessageReceived(BMessage *message) int32 count = 0; type_code type; message->GetInfo("refs", &type, &count); - + // Don't allow saves of multiple files if (count > 1) { ShowCenteredAlert("Sorry, saving of more than one item is not allowed.", @@ -1074,15 +1062,15 @@ TFilePanel::MessageReceived(BMessage *message) HandleSaveButton(); } break; - } + } // send handler a message and close BMessage openMessage(*fMessage); for (int32 index = 0; ; index++) { if (message->FindRef("refs", index, &ref) != B_OK) break; - openMessage.AddRef("refs", &ref); - } + openMessage.AddRef("refs", &ref); + } OpenSelectionCommon(&openMessage); } } @@ -1108,7 +1096,7 @@ TFilePanel::MessageReceived(BMessage *message) if (find_directory(B_USER_DIRECTORY, &homePath) != B_OK || get_ref_for_path(homePath.Path(), &ref) != B_OK) break; - + SetTo(&ref); break; } @@ -1132,77 +1120,21 @@ TFilePanel::MessageReceived(BMessage *message) break; } - case kConfigShow: + case kEditFavorites: { - if (fConfigWindow) { - fConfigWindow->Activate(); - break; - } - BPath path; if (find_directory (B_USER_SETTINGS_DIRECTORY, &path, true) != B_OK) break; path.Append(kGoDirectory); - BDirectory goDirectory(path.Path()); - - if (goDirectory.InitCheck() == B_OK) { - entry_ref startref; - BEntry entry; - goDirectory.GetEntry(&entry); - entry.GetRef(&startref); - - int32 apps, docs, folders; - TrackerSettings().RecentCounts(&apps, &docs, &folders); - - // if this is a save panel - // then don't show recent docs controls - if (fIsSavePanel) - docs = -1; - - fConfigWindow = new TFavoritesConfigWindow(BRect(0, 0, 320, 24), - "Configure Favorites", Feel() == B_MODAL_APP_WINDOW_FEEL, - B_DIRECTORY_NODE, BMessenger(this), &startref, -1, docs, folders); - } - break; - } - - case kConfigClose: - { - int32 count = 0; - TrackerSettings settings; - - // save off whatever was last in the fields - // do this just in case someone didn't tab out - if (message->FindInt32("applications", &count) == B_OK) - settings.SetRecentApplicationsCount(count); - if (message->FindInt32("folders", &count) == B_OK) - settings.SetRecentFoldersCount(count); - if (message->FindInt32("documents", &count) == B_OK) - settings.SetRecentDocumentsCount(count); - - settings.SaveSettings(false); - - fConfigWindow = NULL; - break; - } - - case kUpdateAppsCount: - case kUpdateDocsCount: - case kUpdateFolderCount: - { - // messages sent when the user changes the count - int32 count; - TrackerSettings settings; - - if (message->FindInt32("count", &count) == B_OK) { - if (message->what == kUpdateAppsCount) - settings.SetRecentApplicationsCount(count); - else if (message->what == kUpdateDocsCount) - settings.SetRecentDocumentsCount(count); - else if (message->what == kUpdateFolderCount) - settings.SetRecentFoldersCount(count); - settings.SaveSettings(false); + BMessenger msgr(kTrackerSignature); + if (msgr.IsValid()) { + BMessage message(B_REFS_RECEIVED); + entry_ref ref; + if (get_ref_for_path(path.Path(), &ref) == B_OK) { + message.AddRef("refs", &ref); + msgr.SendMessage(&message); + } } break; } @@ -1250,7 +1182,7 @@ TFilePanel::MessageReceived(BMessage *message) break; } } - } + } break; } @@ -1260,7 +1192,7 @@ TFilePanel::MessageReceived(BMessage *message) } -void +void TFilePanel::OpenDirectory() { BObjectList *list = PoseView()->SelectionList(); @@ -1276,7 +1208,7 @@ TFilePanel::OpenDirectory() } -void +void TFilePanel::OpenParent() { if (!CanOpenParent()) @@ -1287,15 +1219,15 @@ TFilePanel::OpenParent() Model oldModel(*PoseView()->TargetModel()); BEntry entry(oldModel.EntryRef()); - + if (entry.InitCheck() == B_OK && entry.GetParent(&dir) == B_OK && dir.GetEntry(&parentEntry) == B_OK && entry != parentEntry) { - + entry_ref ref; parentEntry.GetRef(&ref); - + PoseView()->SetIsDesktop(SwitchDirToDesktopIfNeeded(ref)); PoseView()->SwitchDir(&ref); SwitchDirMenuTo(&ref); @@ -1310,7 +1242,7 @@ TFilePanel::OpenParent() } -bool +bool TFilePanel::CanOpenParent() const { if (TrackerSettings().DesktopFilePanelRoot()) { @@ -1318,7 +1250,7 @@ TFilePanel::CanOpenParent() const BEntry entry(TargetModel()->EntryRef()); if (FSIsDeskDir(&entry, TargetModel()->NodeRef()->device)) return false; - } + } // block on "/" BEntry root("/"); @@ -1329,7 +1261,7 @@ TFilePanel::CanOpenParent() const } -bool +bool TFilePanel::SwitchDirToDesktopIfNeeded(entry_ref &ref) { // support showing Desktop as root of everything @@ -1339,7 +1271,7 @@ TFilePanel::SwitchDirToDesktopIfNeeded(entry_ref &ref) if (!settings.DesktopFilePanelRoot()) // Tracker isn't set up that way, just let Disks show return false; - + BEntry entry(&ref); BEntry root("/"); @@ -1361,7 +1293,7 @@ TFilePanel::SwitchDirToDesktopIfNeeded(entry_ref &ref) } -bool +bool TFilePanel::SelectChildInParent(const entry_ref *, const node_ref *child) { AutoLock lock(this); @@ -1371,7 +1303,7 @@ TFilePanel::SelectChildInParent(const entry_ref *, const node_ref *child) int32 index; BPose *pose = PoseView()->FindPose(child, &index); - if (!pose) + if (!pose) return false; PoseView()->UpdateScrollRange(); @@ -1396,7 +1328,7 @@ TFilePanel::ShowCenteredAlert(const char *text, const char *button1, else if (button2 != NULL && !strncmp(button2, "Cancel", 7)) alert->SetShortcut(1, B_ESCAPE); else if (button3 != NULL && !strncmp(button3, "Cancel", 7)) - alert->SetShortcut(2, B_ESCAPE); + alert->SetShortcut(2, B_ESCAPE); #endif return alert->Go(); @@ -1450,7 +1382,7 @@ TFilePanel::HandleSaveButton() // user selected "Replace" - let app deal with it } } - + BMessage message(*fMessage); message.AddRef("directory", TargetModel()->EntryRef()); message.AddString("name", fTextControl->Text()); @@ -1485,9 +1417,9 @@ TFilePanel::OpenSelectionCommon(BMessage *openMessage) BRoster().AddToRecentDocuments(&ref); } } - + BRoster().AddToRecentFolders(TargetModel()->EntryRef()); - + if (fClientObject) fClientObject->SendMessage(&fTarget, openMessage); else @@ -1513,7 +1445,7 @@ TFilePanel::HandleOpenButton() if (model->IsDirectory() || (model->IsSymLink() && !(fNodeFlavors & B_SYMLINK_NODE) && model->ResolveIfLink()->IsDirectory())) { - + BMessage message(B_REFS_RECEIVED); message.AddRef("refs", model->EntryRef()); PostMessage(&message); @@ -1524,11 +1456,11 @@ TFilePanel::HandleOpenButton() // don't do anything unless there are items selected // message->fMessage->message from here to end if (selection->CountItems()) { - BMessage message(*fMessage); + BMessage message(*fMessage); // go through selection and add appropriate items for (int32 index = 0; index < selection->CountItems(); index++) { Model *model = selection->ItemAt(index)->TargetModel(); - + if (((fNodeFlavors & B_DIRECTORY_NODE) != 0 && model->ResolveIfLink()->IsDirectory()) || ((fNodeFlavors & B_SYMLINK_NODE) != 0 && model->IsSymLink()) @@ -1558,11 +1490,11 @@ TFilePanel::SwitchDirMenuTo(const entry_ref *ref) } -void +void TFilePanel::WindowActivated(bool active) { // force focus to update properly - fBackView->Invalidate(); + fBackView->Invalidate(); _inherited::WindowActivated(active); } @@ -1579,7 +1511,7 @@ BFilePanelPoseView::BFilePanelPoseView(Model *model, BRect frame, uint32 resizeM } -void +void BFilePanelPoseView::StartWatching() { TTracker::WatchNode(0, B_WATCH_MOUNT, this); @@ -1591,7 +1523,7 @@ BFilePanelPoseView::StartWatching() } -void +void BFilePanelPoseView::StopWatching() { stop_watching(this); @@ -1639,7 +1571,7 @@ BFilePanelPoseView::FSNotification(const BMessage *message) && otherDesktop.GetEntry(&entry) == B_OK) { // place desktop items from the mounted volume onto the desktop Model model(&entry); - if (model.InitCheck() == B_OK) + if (model.InitCheck() == B_OK) AddPoses(&model); } } @@ -1650,7 +1582,7 @@ BFilePanelPoseView::FSNotification(const BMessage *message) } -void +void BFilePanelPoseView::RestoreState(AttributeStreamNode *node) { _inherited::RestoreState(node); @@ -1658,14 +1590,14 @@ BFilePanelPoseView::RestoreState(AttributeStreamNode *node) } -void +void BFilePanelPoseView::RestoreState(const BMessage &message) { _inherited::RestoreState(message); } -void +void BFilePanelPoseView::SavePoseLocations(BRect *) { } @@ -1674,14 +1606,14 @@ BFilePanelPoseView::SavePoseLocations(BRect *) EntryListBase * BFilePanelPoseView::InitDirentIterator(const entry_ref *ref) { - if (IsDesktopView()) + if (IsDesktopView()) return DesktopPoseView::InitDesktopDirentIterator(this, ref); return _inherited::InitDirentIterator(ref); } -bool +bool BFilePanelPoseView::ShouldShowPose(const Model *model, const PoseInfo *poseInfo) { if (IsDesktopView() && !ShouldShowDesktopPose(TargetModel()->NodeRef()->device, @@ -1699,7 +1631,7 @@ BFilePanelPoseView::SetIsDesktop(bool on) } -bool +bool BFilePanelPoseView::IsDesktopView() const { return fIsDesktop; @@ -1713,10 +1645,10 @@ BFilePanelPoseView::ShowVolumes(bool visible, bool showShared) if (!visible) RemoveRootPoses(); else - AddRootPoses(true, showShared); + AddRootPoses(true, showShared); } - - + + TFilePanel *filepanel = dynamic_cast(Window()); if (filepanel) filepanel->SetTo(TargetModel()->EntryRef()); @@ -1739,7 +1671,7 @@ BFilePanelPoseView::AdaptToVolumeChange(BMessage *message) if (model.InitCheck() == B_OK) { BMessage monitorMsg; monitorMsg.what = B_NODE_MONITOR; - + if (showDisksIcon) monitorMsg.AddInt32("opcode", B_ENTRY_CREATED); else @@ -1753,7 +1685,7 @@ BFilePanelPoseView::AdaptToVolumeChange(BMessage *message) if (Window()) Window()->PostMessage(&monitorMsg, this); } - + ShowVolumes(mountVolumesOnDesktop, mountSharedVolumesOntoDesktop); } diff --git a/src/kits/tracker/FilePanelPriv.h b/src/kits/tracker/FilePanelPriv.h index 5a427451b9..1c64ac2f64 100644 --- a/src/kits/tracker/FilePanelPriv.h +++ b/src/kits/tracker/FilePanelPriv.h @@ -53,7 +53,6 @@ class BackgroundView; class BDirMenu; class AttributeStreamNode; class BFilePanelPoseView; -class TFavoritesConfigWindow; class TFilePanel : public BContainerWindow { public: @@ -67,7 +66,7 @@ public: bool hideWhenDone = true); virtual ~TFilePanel(); - + BFilePanelPoseView *PoseView() const; virtual bool QuitRequested(); @@ -89,13 +88,13 @@ public: void Refresh(); const BMessenger *Target() const; BRefFilter *Filter() const; - + void SetTarget(BMessenger); void SetMessage(BMessage *message); - + virtual status_t GetNextEntryRef(entry_ref *); virtual void MessageReceived(BMessage *); - + void SetHideWhenDone(bool); bool HidesWhenDone(void); @@ -125,8 +124,8 @@ protected: static filter_result MessageDropFilter(BMessage *, BHandler **, BMessageFilter *); int32 ShowCenteredAlert(const char *text, const char *button1, const char *button2 = NULL, const char *button3 = NULL); - - + + private: bool SwitchDirToDesktopIfNeeded(entry_ref &ref); bool CanOpenParent() const; @@ -145,11 +144,10 @@ private: BMessenger fTarget; BFilePanel *fClientObject; int32 fSelectionIterator; - BMessage *fMessage; + BMessage *fMessage; BString fButtonText; bool fHideWhenDone; bool fIsTrackingMenu; - TFavoritesConfigWindow *fConfigWindow; typedef BContainerWindow _inherited; @@ -163,7 +161,7 @@ public: virtual bool IsFilePanel() const; virtual bool FSNotification(const BMessage *); - + void SetIsDesktop(bool); protected: @@ -189,7 +187,7 @@ private: // this flags makes the distinction between the Desktop as the Root of // the world and "/boot/home/Desktop" to which we might have navigated // from the home dir - + typedef BPoseView _inherited; }; diff --git a/src/kits/tracker/Jamfile b/src/kits/tracker/Jamfile index 55344fd685..c23846746a 100644 --- a/src/kits/tracker/Jamfile +++ b/src/kits/tracker/Jamfile @@ -38,7 +38,6 @@ SharedLibrary libtracker.so : FSClipboard.cpp FSUndoRedo.cpp FSUtils.cpp - FavoritesConfig.cpp FavoritesMenu.cpp FilePanel.cpp FilePanelPriv.cpp