Move the folders back into main view

Got lots more tests passing
This commit is contained in:
Lars Brubaker 2017-08-29 18:13:45 -07:00
parent aa55fe230b
commit 02a9baf464
13 changed files with 129 additions and 245 deletions

View file

@ -1,168 +0,0 @@
/*
Copyright (c) 2017, Lars Brubaker, John Lewin
All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
1. Redistributions of source code must retain the above copyright notice, this
list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
The views and conclusions contained in the software and documentation are those
of the authors and should not be interpreted as representing official policies,
either expressed or implied, of the FreeBSD Project.
*/
using MatterHackers.Agg;
using MatterHackers.Agg.Platform;
using MatterHackers.Agg.UI;
using MatterHackers.Localizations;
using MatterHackers.MatterControl.CustomWidgets;
using MatterHackers.MatterControl.Library;
namespace MatterHackers.MatterControl.PrintLibrary
{
public class ListContainerBrowser : FlowLayoutWidget, IIgnoredPopupChild
{
private FolderBreadCrumbWidget breadCrumbWidget;
private GuiWidget searchInput;
private ILibraryContainer searchContainer;
private ILibraryContext libraryContext;
public ListContainerBrowser(ListView libraryView, ILibraryContext libraryContext)
: base(FlowDirection.TopToBottom)
{
this.libraryContext = libraryContext;
var navBar = new FlowLayoutWidget()
{
HAnchor = HAnchor.Stretch
};
this.AddChild(navBar);
breadCrumbWidget = new FolderBreadCrumbWidget(libraryView);
navBar.AddChild(breadCrumbWidget);
var icon = AggContext.StaticData.LoadIcon("icon_search_24x24.png", 16, 16);
var buttonFactory = ApplicationController.Instance.Theme.SmallMarginButtonFactory;
var searchPanel = new SearchInputBox()
{
Visible = false,
Margin = new BorderDouble(10, 0, 5, 0)
};
searchPanel.searchInput.ActualTextEditWidget.EnterPressed += (s, e) =>
{
this.PerformSearch();
};
searchPanel.resetButton.Click += (s, e) =>
{
breadCrumbWidget.Visible = true;
searchPanel.Visible = false;
searchPanel.searchInput.Text = "";
this.ClearSearch();
};
// Store a reference to the input field
this.searchInput = searchPanel.searchInput;
navBar.AddChild(searchPanel);
Button searchButton = buttonFactory.Generate("", icon);
searchButton.ToolTipText = "Search".Localize();
searchButton.Name = "Search Library Button";
searchButton.Margin = 0;
searchButton.Click += (s, e) =>
{
if (searchPanel.Visible)
{
PerformSearch();
}
else
{
searchContainer = libraryContext.ActiveContainer;
breadCrumbWidget.Visible = false;
searchPanel.Visible = true;
searchInput.Focus();
}
};
navBar.AddChild(searchButton);
var libraryContainerView = new ListView(libraryContext)
{
HAnchor = HAnchor.Stretch,
};
this.AddChild(libraryContainerView);
}
private void PerformSearch()
{
UiThread.RunOnIdle(() =>
{
libraryContext.ActiveContainer.KeywordFilter = searchInput.Text.Trim();
});
}
private void ClearSearch()
{
UiThread.RunOnIdle(() =>
{
searchContainer.KeywordFilter = "";
// Restore the original ActiveContainer before search started - some containers may change context
ApplicationController.Instance.Library.ActiveContainer = searchContainer;
searchContainer = null;
});
}
private class SearchInputBox : GuiWidget
{
internal MHTextEditWidget searchInput;
internal Button resetButton;
public SearchInputBox()
{
this.VAnchor = VAnchor.Center | VAnchor.Fit;
this.HAnchor = HAnchor.Stretch;
searchInput = new MHTextEditWidget(messageWhenEmptyAndNotSelected: "Search Library".Localize())
{
Name = "Search Library Edit",
HAnchor = HAnchor.Stretch,
VAnchor = VAnchor.Center
};
this.AddChild(searchInput);
resetButton = ApplicationController.Instance.Theme.CreateSmallResetButton();
resetButton.HAnchor = HAnchor.Right | HAnchor.Fit;
resetButton.VAnchor = VAnchor.Center | VAnchor.Fit;
resetButton.Name = "Close Search";
resetButton.ToolTipText = "Clear".Localize();
this.AddChild(resetButton);
}
}
}
}

View file

@ -127,6 +127,11 @@ namespace MatterHackers.MatterControl.CustomWidgets
DisplayContainerContent(activeContainer);
}
public void Reload()
{
DisplayContainerContent(ActiveContainer);
}
private void ActiveContainer_Reloaded(object sender, EventArgs e)
{
DisplayContainerContent(ActiveContainer);

View file

@ -59,12 +59,13 @@ namespace MatterHackers.MatterControl.PrintLibrary
private OverflowDropdown overflowDropdown;
private PopupButton activeContainerPopup;
private TextWidget activeContainerTitle;
//private DropDownMenu actionMenu;
private List<PrintItemAction> menuActions = new List<PrintItemAction>();
private FolderBreadCrumbWidget breadCrumbWidget;
private GuiWidget searchInput;
private ILibraryContainer searchContainer;
public PrintLibraryWidget()
{
this.Padding = 0;
@ -84,61 +85,75 @@ namespace MatterHackers.MatterControl.PrintLibrary
ApplicationController.Instance.Library.ContainerChanged += Library_ContainerChanged;
var breadCrumbBar = new FlowLayoutWidget()
var navBar = new FlowLayoutWidget()
{
HAnchor = HAnchor.Stretch,
VAnchor = VAnchor.Fit,
Padding = ApplicationController.Instance.Theme.ToolbarPadding
HAnchor = HAnchor.Stretch
};
allControls.AddChild(navBar);
CheckBox showFolders = new CheckBox("Folders")
{
Name = "Show Folders Toggle",
Checked = libraryView.ShowContainers
};
showFolders.CheckedStateChanged += (s, e) =>
{
libraryView.ShowContainers = showFolders.Checked;
libraryView.Reload();
};
allControls.AddChild(showFolders);
breadCrumbWidget = new FolderBreadCrumbWidget(libraryView);
navBar.AddChild(breadCrumbWidget);
var icon = AggContext.StaticData.LoadIcon("icon_search_24x24.png", 16, 16);
var buttonFactory = ApplicationController.Instance.Theme.SmallMarginButtonFactory;
var searchPanel = new SearchInputBox()
{
Visible = false,
Margin = new BorderDouble(10, 0, 5, 0)
};
searchPanel.searchInput.ActualTextEditWidget.EnterPressed += (s, e) =>
{
this.PerformSearch();
};
searchPanel.resetButton.Click += (s, e) =>
{
breadCrumbWidget.Visible = true;
searchPanel.Visible = false;
searchPanel.searchInput.Text = "";
this.ClearSearch();
};
int arrowHeight = 5;
// Store a reference to the input field
this.searchInput = searchPanel.searchInput;
var directionArrow = new PathStorage();
directionArrow.MoveTo(-arrowHeight, 0);
directionArrow.LineTo(arrowHeight, 0);
directionArrow.LineTo(0, -arrowHeight);
navBar.AddChild(searchPanel);
var buttonView = new FlowLayoutWidget()
Button searchButton = buttonFactory.Generate("", icon);
searchButton.ToolTipText = "Search".Localize();
searchButton.Name = "Search Library Button";
searchButton.Margin = 0;
searchButton.Click += (s, e) =>
{
HAnchor = HAnchor.Stretch,
VAnchor = VAnchor.Fit,
MinimumSize = new Vector2(0, ApplicationController.Instance.Theme.ButtonFactory.FixedHeight)
};
buttonView.AfterDraw += (s, e) =>
{
e.graphics2D.Render(directionArrow, buttonView.LocalBounds.Right - arrowHeight * 2 - 2, buttonView.LocalBounds.Center.y + arrowHeight / 2, ActiveTheme.Instance.SecondaryTextColor);
};
activeContainerTitle = new TextWidget(ApplicationController.Instance.Library.ActiveContainer.Name, textColor: ActiveTheme.Instance.PrimaryTextColor)
{
Margin = new BorderDouble(left: 6),
VAnchor = VAnchor.Center
};
buttonView.AddChild(activeContainerTitle);
activeContainerPopup = new PopupButton(buttonView)
{
VAnchor = VAnchor.Center,
HAnchor = HAnchor.Stretch,
Margin = 0
};
activeContainerPopup.DynamicPopupContent = () =>
{
var container = new GuiWidget(400, this.Height)
if (searchPanel.Visible)
{
BackgroundColor = ActiveTheme.Instance.SecondaryBackgroundColor
};
container.AddChild(new ListContainerBrowser(this.libraryView, ApplicationController.Instance.Library)
PerformSearch();
}
else
{
HAnchor = HAnchor.Stretch,
VAnchor = VAnchor.Stretch
});
searchContainer = ApplicationController.Instance.Library.ActiveContainer;
return container;
breadCrumbWidget.Visible = false;
searchPanel.Visible = true;
searchInput.Focus();
}
};
breadCrumbBar.AddChild(activeContainerPopup);
navBar.AddChild(searchButton);
overflowDropdown = new OverflowDropdown(allowLightnessInvert: true)
{
@ -146,9 +161,7 @@ namespace MatterHackers.MatterControl.PrintLibrary
AlignToRightEdge = true,
Name = "Print Library Overflow Menu",
};
breadCrumbBar.AddChild(overflowDropdown);
allControls.AddChild(breadCrumbBar);
navBar.AddChild(overflowDropdown);
allControls.AddChild(libraryView);
@ -166,6 +179,28 @@ namespace MatterHackers.MatterControl.PrintLibrary
this.AddChild(allControls);
}
private void PerformSearch()
{
UiThread.RunOnIdle(() =>
{
ApplicationController.Instance.Library.ActiveContainer.KeywordFilter = searchInput.Text.Trim();
});
}
private void ClearSearch()
{
UiThread.RunOnIdle(() =>
{
searchContainer.KeywordFilter = "";
// Restore the original ActiveContainer before search started - some containers may change context
ApplicationController.Instance.Library.ActiveContainer = searchContainer;
searchContainer = null;
});
}
private void SelectedItems_CollectionChanged(object sender, System.Collections.Specialized.NotifyCollectionChangedEventArgs e)
{
if (e.Action == System.Collections.Specialized.NotifyCollectionChangedAction.Reset)
@ -213,10 +248,8 @@ namespace MatterHackers.MatterControl.PrintLibrary
addToLibraryButton.Enabled = containerSupportsEdits;
createFolderButton.Enabled = containerSupportsEdits && writableContainer?.AllowAction(ContainerActions.AddContainers) == true;
activeContainerTitle.Text = activeContainer.Name;
// searchInput.Text = activeContainer.KeywordFilter;
//breadCrumbWidget.SetBreadCrumbs(activeContainer);
searchInput.Text = activeContainer.KeywordFilter;
breadCrumbWidget.SetBreadCrumbs(activeContainer);
activeContainer.Reloaded += UpdateStatus;
@ -868,5 +901,32 @@ namespace MatterHackers.MatterControl.PrintLibrary
base.OnLoad(args);
}
private class SearchInputBox : GuiWidget
{
internal MHTextEditWidget searchInput;
internal Button resetButton;
public SearchInputBox()
{
this.VAnchor = VAnchor.Center | VAnchor.Fit;
this.HAnchor = HAnchor.Stretch;
searchInput = new MHTextEditWidget(messageWhenEmptyAndNotSelected: "Search Library".Localize())
{
Name = "Search Library Edit",
HAnchor = HAnchor.Stretch,
VAnchor = VAnchor.Center
};
this.AddChild(searchInput);
resetButton = ApplicationController.Instance.Theme.CreateSmallResetButton();
resetButton.HAnchor = HAnchor.Right | HAnchor.Fit;
resetButton.VAnchor = VAnchor.Center | VAnchor.Fit;
resetButton.Name = "Close Search";
resetButton.ToolTipText = "Clear".Localize();
this.AddChild(resetButton);
}
}
}
}