Improving store page
This commit is contained in:
parent
4ee2a41852
commit
1fda0e7320
10 changed files with 303 additions and 54 deletions
143
MatterControlLib/Library/Widgets/StorePage/ArticleItem.cs
Normal file
143
MatterControlLib/Library/Widgets/StorePage/ArticleItem.cs
Normal file
|
|
@ -0,0 +1,143 @@
|
|||
/*
|
||||
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.Image;
|
||||
using MatterHackers.Agg.UI;
|
||||
|
||||
namespace MatterHackers.MatterControl.PartPreviewWindow.PlusTab
|
||||
{
|
||||
public class ArticleItem : FlowLayoutWidget
|
||||
{
|
||||
private FeedItemData item;
|
||||
private ThemeConfig theme;
|
||||
|
||||
public static int IconSize => (int)(40 * GuiWidget.DeviceScale);
|
||||
public static int ItemSpacing { get; } = 10;
|
||||
|
||||
public ArticleItem(FeedItemData item, ThemeConfig theme)
|
||||
{
|
||||
this.HAnchor = HAnchor.Absolute;
|
||||
this.Width = 400 * GuiWidget.DeviceScale;
|
||||
//this.Border = spacing;
|
||||
this.Padding = ItemSpacing;
|
||||
this.item = item;
|
||||
this.theme = theme;
|
||||
|
||||
var image = new ImageBuffer(IconSize, IconSize);
|
||||
|
||||
if (item.icon != null)
|
||||
{
|
||||
var imageWidget = new ImageWidget(image)
|
||||
{
|
||||
Selectable = false,
|
||||
VAnchor = VAnchor.Top,
|
||||
Margin = new BorderDouble(right: ItemSpacing)
|
||||
};
|
||||
|
||||
WebCache.RetrieveImageAsync(image, item.icon, true, new BlenderPreMultBGRA());
|
||||
this.AddChild(imageWidget);
|
||||
}
|
||||
else if (item.widget_url != null)
|
||||
{
|
||||
var whiteBackground = new GuiWidget(IconSize, IconSize)
|
||||
{
|
||||
// these images expect to be on white so change the background to white
|
||||
BackgroundColor = Color.White,
|
||||
Margin = new BorderDouble(right: ItemSpacing)
|
||||
};
|
||||
this.AddChild(whiteBackground);
|
||||
|
||||
var imageWidget = new ImageWidget(image)
|
||||
{
|
||||
Selectable = false,
|
||||
VAnchor = VAnchor.Center,
|
||||
};
|
||||
|
||||
WebCache.RetrieveImageAsync(image, item.widget_url, true, new BlenderPreMultBGRA());
|
||||
whiteBackground.AddChild(imageWidget);
|
||||
}
|
||||
|
||||
var wrappedText = new WrappedTextWidget(item.title, textColor: theme.TextColor, pointSize: theme.DefaultFontSize)
|
||||
{
|
||||
Selectable = false,
|
||||
VAnchor = VAnchor.Center | VAnchor.Fit,
|
||||
Margin = 3
|
||||
};
|
||||
this.AddChild(wrappedText);
|
||||
wrappedText.Load += (s, e) =>
|
||||
{
|
||||
wrappedText.VAnchor = VAnchor.Top | VAnchor.Fit;
|
||||
};
|
||||
|
||||
this.Cursor = Cursors.Hand;
|
||||
}
|
||||
|
||||
public override Color BackgroundColor
|
||||
{
|
||||
get => (mouseInBounds) ? theme.AccentMimimalOverlay : base.BackgroundColor;
|
||||
set => base.BackgroundColor = value;
|
||||
}
|
||||
|
||||
private bool mouseInBounds = false;
|
||||
|
||||
public override void OnMouseEnterBounds(MouseEventArgs mouseEvent)
|
||||
{
|
||||
mouseInBounds = true;
|
||||
base.OnMouseEnterBounds(mouseEvent);
|
||||
|
||||
this.Invalidate();
|
||||
}
|
||||
|
||||
public override void OnMouseLeaveBounds(MouseEventArgs mouseEvent)
|
||||
{
|
||||
mouseInBounds = false;
|
||||
base.OnMouseLeaveBounds(mouseEvent);
|
||||
|
||||
this.Invalidate();
|
||||
}
|
||||
|
||||
protected override void OnClick(MouseEventArgs mouseEvent)
|
||||
{
|
||||
if (mouseEvent.Button == MouseButtons.Left)
|
||||
{
|
||||
if (item.url != null)
|
||||
{
|
||||
ApplicationController.LaunchBrowser("http://www.matterhackers.com/" + item.url);
|
||||
}
|
||||
else if (item.link != null)
|
||||
{
|
||||
ApplicationController.LaunchBrowser(item.link);
|
||||
}
|
||||
}
|
||||
|
||||
base.OnClick(mouseEvent);
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue