diff options
author | Rui Marinho <me@ruimarinho.net> | 2017-01-27 12:52:38 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-01-27 12:52:38 +0000 |
commit | 004197380ae45d394fcf3b0e8cc53ab840135433 (patch) | |
tree | 4445d8507e6b05db8d5d729afb8e3089002507a3 /Xamarin.Forms.ControlGallery.MacOS | |
parent | de96051a2eef9073574e0b45470b4a0feefc4930 (diff) | |
download | xamarin-forms-004197380ae45d394fcf3b0e8cc53ab840135433.tar.gz xamarin-forms-004197380ae45d394fcf3b0e8cc53ab840135433.tar.bz2 xamarin-forms-004197380ae45d394fcf3b0e8cc53ab840135433.zip |
Add MacOS gallery and UITest (#721)
* [MacOS] Cleanup
* [Controls] Add Header support to ListView
* [MacOS] NSView reuse on NSTableView
* [MacOS] Some fix on layour order
* [MacOS] Add CarouselPageRenderer
* [MacOS] Implement EventTracker on PageRenderer
* [MacOS] Cleanup CarouselPageRenderer
* [MacOS] Add MasterDetailPage renderer
* [MacOS] MDP renderer don't allow drag of splitter
* [MacOS] Add TabbedPage renderer
* [MacOS] Initial sketch of NavigationPageRenderer
* [MacOS] Send disappearing of CurrentPage on Dispose on NavigationPageRenderer
* [MacOS] Add Gallery page for Mac
* [MacOS] Add MacOSExpressionSearch
* [MacOS] Fix ColorExtension
* [MacOS] Fix MDP renderer layout
* [MacOS] Implement native selection on ListViewRenderer
* [MacOS] Deselect a item on NSTableView
* [MacOS] Remove previous SplitViewItems
* [MacOS] Fix navigationpage height
* [MacOS] Add toolbar for NavigationPageRenderer
* [MacOS] Don't remove selection for now (crashing)
* [MacOS] Refactor page and back button title on NavigationPageRenderer
* [MacOS] Fix bug when native navigate back
* [MacOS] Hide layer when transition
* [MacOS] ListviewRenderer fix BbackgroundColor
* [MacOS] Fix background on ScrollViewRenderer
* [MacOS] Fix header measure on ListViewRenderer
* [MacOS] Add Mac twitter demo
* [Controls] Spaces for easy reading
* [MacOS] More xaml cleanup
* [Core] Add Mac as aTargetPlatform
* [MacOS] Add alerts and actionsheets
* [MacOS] Add GestureRecognizers
* [MacOS] Fix Layout issues when adding children, enable transformations
* [MacOS] Fix title on tab item, move to tabbed navigation based on segmented control
* [MacOS] Hide toolbar when not needed, this allows to work with tabbed page, cleanup
* [MacOS] Add NativeBindings and NativeViewWrapper
* [MacOS] Fix AssemblyInfo
* [MacOS] FIX NRE on SetBackgroundColor BoxView
* [MacOS] Fix NavigationPageRenderer
* [MacOS] Fix build
* [MacOS] Also update page when it resizes
* [MacOS] Add LayoutRenderer for handle items position when the bounds change.
* [MacOS] Refactor/Cleanup
* [MacOS] Add toolbar items support to NavigationPage
* [MacOS] Resize images for TabViewITems
* [MacOS] Fix TabbedPage resize issues , allow users to override some features when creating TVI
* [MacOS] Fix hide/show Navigation toolbar
* [MacOS] Redo CarouselPageRenderer with NSPageController
* [MacOS] Add support for Modal pages
* [MacOS] Refactor navigation from platform
* [Nuget] Add nuget for MacOS
* [Nuget]Fix nuspec
* [Nuget] Add variables for CI
* [Controls] Remove MainMenu from MacOS
* [MacOS] Add TableView renderer (no headers yet)
* [MacOS] Refactoring, marking extensions as internal
* [MacOS] Add group headers for TableViewRenderer
* [MacOS] Workaround for updates on listview collection
* [MacOS] Handle updates of rows in the ListViewRenderer properly
* [MacOS] Fix navigation animation
* Fix navigation header issues with modal pages
* [MacOS] Fix MDP issues with resizing
* [MacOS] Fix general dispose
* [MacOS] Add a ViewControllerWrapper for NSSplitView
* [MacOS] MDP renderer fix animation
* [MacOS] Fix ListView selection bug
* [MacOS] Fix rendering MDP Layout inside wrappers
* [MacOS] Re write the MainToolbar handler
* [MacOS] Don't use Sierra new extensions so we can run in stable channel
* [MacOS] Another way to hide the toolbar (smarter i think)
* [MacOS] Fix MDP bug and remove debug color
* [Controls] Add HanselForms sample
* [MacOS] Fix NRE WebviewRenderer
* [MacOS] Fix uneven rows on ListView renderer
* [MacOS] Fix NRE on load (can+t find the reason this happens)
* [MacOS] Fix uneven rows
* [MacOS] Fix header sizing on ListViewRenderer
* [Controls] More stuff on HanselForms
* [MacOS] Remove warning from ListViewRenderer
* [MacOS] Fix PageRenderer bug double init
* [MacOS] Don't calculate height if RowHeight is provided
* [Controls] More Hanselforms stuff
* [MacOS] Once again a new implementation for the NavigationBar, this time using a custom view to support BackgroundColor
* [MacOS] Fix build
* [MacOS] Refactoring AwesomeBar related controls
* Fix build
* [MacOS] NavigationBar update background and t test colors
* [MacOS] Fix when we remove navigation so it works when the NavigationRenderer wasn't removed from the parent controller like in a TabbedPage
* [MacOS] Add support for ListView grouping
* [MacOS] Fix image extension method.
* [MacOS] Add base Maps project
* [MacOS] Export MapRenderer
* [MacOS] Add pin click and geocoderbacked for Maps
* [MacOS] Add extra binding project for API not in stable.
* [MacOS] Add MacOS Maps lib
* [MacOS]Fix build on alpha
* [MacOS] Remove MacOS Maps extra binding
* [UITest] Basic macOS setup
* [UITest] Add MacOSApp wrapper implementation
* [MacOS] Set AutomationID
* [UITests] Add ActionSheetUITests to MacOS UITest
* [MacOS] Fix bug on Picker
* [UITests] Link basic uitest basefixture and related files
* [MacOS] Fix pickers reuse
* [UItests] Fix MacOS app path
* [UITest] Ignore UItest for appearing on macOS for now
* [UITest] Update macOS for 2.0.3
* [UITest] Refactor EnterText MacOS app
* [UITest]Fix ViewQuery on MacOS
* [UITest]Fix IsEnabled UItest on macOS
* [UITest] Implement Enter, mark some tests inconclusive fix others
* [MacOS] Implement Entry Completed event
* [UITests] Fix UITest for IsVisible, ignore ToolbarItem test for now
* [UITests] Fix ISVisible again add extra category
* [Controls] Cleanup macOS gallery
* [MacOS] Fix Assembly info
* [Docs] Fix docs
* Fix build
* [Nuget] Fix nuspec
* [Controls] Link files on MacOS
* [Core] Update Forms stack before firing a event saying page was removed, possible breaking change
* [MacOS] Implement RemovePage on NavigationPAgeRenderer
* [UItest] Ignore some , implement back on MacOS UITest app
* [MacOS] Add default back button name (needs to be translated)
* [MacOS] Fix dispose
* [UITest] Make 29257 work on MacOS
* [MacOS] Rename stuff
* [MacOS] More renaming and cleanup
* [MacOS] Share implementations for iOS
* [MacOS] Reuse more IOS extensions
* [MacOS] Reuse FontExtensions
* [MacOS] Share NativeViewWrapper related stuff
* [MAcOS] Share event args and ExportRenderer
* [MacOS] Share platform effect
* [MacOS] Fix build
* [Docs]Fixing docs
* [MacOS] Fix ViewCell reuse
* [Core] Support ListView CachingStrategy on MacOS
* [MacOS] Fix issues with TextCell and ImageCell (we can’t set null to a NSControl value)
* [MacOS] Fix MDP child sizing bug
[UITest] Query marked by id and text
* [MacOS] Comment test related with context actions
* [MacOS] Implement missing stuff on ticker
* [MacOS] Make sure VisualElemenTracker calls the ticker update
* [UITests]Ignore context actions and not possible to test
* [MacOS] Fix Grouping bug on Listview
* [MacOS] Fix selection on Listview when using grouping
* [MacOS] Update navbar when page is popped
* [MacOS] Cleanup NavigationBar
* [Controls] More info on exceptions
* [MacOS] Fix bug animation pop modal
* [MacOS] Bring back BackgroundColor of NavigationBar
* [MacOS] Fix UITest animation delay
* [MacOS] Treat warnings as errors
* [MacOS] Center title on toolbar
* [Core] Add Platform configuration specific for MacOS
* [MacOS] Implement TabbedPage platform specific to handle TabItems on NavigationPage bar
* [MacOS] Fix warning
* [MacOS] Fix bug on SearchBar color
* [MacOS]Fix build
* [MacOS] remove extra dll from maps
* [Docs] Update docs
* [MacOS]Cleanup and refactoring
* Revert "[MacOS] remove extra dll from maps"
This reverts commit 73b948937001fea3f28449a963d0b94943e07aa0.
* [MacOS] Fix wrong refactoring
* [MacOS] dix formatting
* [MacOS] Fix build
* [MacOS] Fix bug on TabbedPageRenderer no title
* [MacOS,UITest] Update packages
* [MacOS ,UITest] Add delay when tapping something, and focus with double click
* [MacOS,UITest] Ignore UITest, not possible to test with current version
* [MacOS,UITest] Ignore test that uses Frame, UITest doesn’t return it
* [MacOS] Fix bug when no title on toolbar items
* [MacOS] Remove FormsNSView
* [MacOS] Cleanup on dispose on MDP renderer
* [MacOS] Different way to test leak of MDP, need to look at this again after
* [MacOS] Update current page when source changes
* [MacOS] More cleanup
* [MacOS,UITest] Implement ClearText
* [MacOS,UITest] ClearText doesn’t work for now on MacOS uitest
* [MacOS] Make sure we show the previous page when popping a Modal
* [MacOS] Fix issue with sizing the Header and visibility, remove for now header renderer reuse
* [MacOS] Clean CustomNSTableView
* [MacOS] Share LabelRenderer with iOS
* [MacOS,UITest] Don’t try to scroll for the element
* [MacOS] Share ResourcesProvider with iOS
* [MAcoS] Share VisualElementPackager with iOS
* [MacOS] Share ViewRenderer with iOS
* [MacOS] Merge with VisualElementTracker from iOS
* [MacOS] Merge with EventTracker from iOS
* [MacOS] Merge with VisualElementRenderer of iOS
* [MacOS] Make sure we always have a layer
* [MacOS] Fix Tracker merge with iOS version
* [MacOS] Fix bug with tabbed page on modal without navigation
* [Core] Rever change on core
* [Controls] Add missing image
* [MacOS] Clear renderers before setting them MDP
* [MacOS] Update tabbedPage ContainerArea
* [Controls] Add Custom renderers tests
* [MacOS] Fix ListViewRenderer
* [MacOS,UITest] Refactoring, implement index
* [MacOS] Make sure we don’t pass null to TextField string value
* [MacOS] Support for multiple clicks in same selected item on NSTableView
* [MacOS, UITest] Fix bug on Back because of refactoring
* [MacOS,UITest] Ignore UITest because we’d-not have ScrollDownTo yet
* [MacOS] Support Focus on EntryRenderer
* [MacOS,UITest] Ignore more a couple of tests that we can’t test on UITest Desktop
* [MacOS,UITest] MacOSApp looks for StaticText fields too
* [MacOS, UITest] Fix EnterText for marked Entry
* [MacOS] Fix index bug on TablevIewDataSource
* [MacOS] Fix SelectedItem TableViewDataSource
* [Nuget] Add Mac to Maps nuspec
* [Nuget]Fix path
* [Controls] Add basic FormsGallery sample
* [macOS] Fixed Tab NSImage crash in TabbedPageRenderer (#705)
* [macOS] Fixed Tab NSImage crash in TabbedPageRenderer
* Coding Style
* Coding Style
* [MacOS] Fix previous merge with master
* [MacOS] Possible simple fix for click on views overlapping
* [UItest] Ignore this part of the test we can’t click on NSViews yet
* [MacOS] Rename to IsOnViewCell
* fix docs
* [MacOS] Cleanup, Address feedback from Samantha’s review
* [MacOS] Add ContextActions
* [Controls] Remove FormsGalery for now
* [Docs] Update docs
* [MacOS] Implement ContextActions
* [MacOS,UITests] Enable and support UITests of ContextActions
Diffstat (limited to 'Xamarin.Forms.ControlGallery.MacOS')
20 files changed, 1224 insertions, 0 deletions
diff --git a/Xamarin.Forms.ControlGallery.MacOS/AppDelegate.cs b/Xamarin.Forms.ControlGallery.MacOS/AppDelegate.cs new file mode 100644 index 00000000..ac4940df --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/AppDelegate.cs @@ -0,0 +1,246 @@ +using System; +using System.Globalization; +using AppKit; +using CoreGraphics; +using Foundation; +using Xamarin.Forms.Controls; +using Xamarin.Forms.Controls.Issues; +using Xamarin.Forms.Platform.MacOS; + +namespace Xamarin.Forms.ControlGallery.MacOS +{ + [Register("AppDelegate")] + public class AppDelegate : FormsApplicationDelegate + { + + NSWindow _window; + public AppDelegate() + { + ObjCRuntime.Runtime.MarshalManagedException += (sender, args) => + { + Console.WriteLine(args.Exception.ToString()); + }; + + var style = NSWindowStyle.Closable | NSWindowStyle.Resizable | NSWindowStyle.Titled; + + var rect = new CoreGraphics.CGRect(200, 1000, 1024, 768); + //var rect = NSWindow.FrameRectFor(NSScreen.MainScreen.Frame, style); + _window = new NSWindow(rect, style, NSBackingStore.Buffered, false); + _window.Title = "Twitter XF Mac"; + _window.TitleVisibility = NSWindowTitleVisibility.Hidden; + } + + public override NSWindow MainWindow + { + get { return _window; } + } + + public override void DidFinishLaunching(NSNotification notification) + { + Forms.Init(); + FormsMaps.Init(); + + var app = new App(); + // When the native control gallery loads up, it'll let us know so we can add the nested native controls + MessagingCenter.Subscribe<NestedNativeControlGalleryPage>(this, NestedNativeControlGalleryPage.ReadyForNativeControlsMessage, AddNativeControls); + MessagingCenter.Subscribe<Bugzilla40911>(this, Bugzilla40911.ReadyToSetUp40911Test, SetUp40911Test); + + // When the native binding gallery loads up, it'll let us know so we can set up the native bindings + MessagingCenter.Subscribe<NativeBindingGalleryPage>(this, NativeBindingGalleryPage.ReadyForNativeBindingsMessage, AddNativeBindings); + + LoadApplication(app); + base.DidFinishLaunching(notification); + } + + void AddNativeControls(NestedNativeControlGalleryPage page) + { + if (page.NativeControlsAdded) + { + return; + } + + StackLayout sl = page.Layout; + + // Create and add a native UILabel + var originalText = "I am a native UILabel"; + var longerText = + "I am a native UILabel with considerably more text. Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua."; + + var uilabel = new NSTextField + { + StringValue = originalText, + MaximumNumberOfLines = 0, + LineBreakMode = NSLineBreakMode.ByWordWrapping, + Font = NSFont.FromFontName("Helvetica", 24f) + }; + + sl?.Children.Add(uilabel); + + // Create and add a native Button + var uibutton = NSButtonExtensions.CreateButton("Toggle Text Amount", () => + { + uilabel.StringValue = uilabel.StringValue == originalText ? longerText : originalText; + uilabel.SizeToFit(); + }); + uibutton.Font = NSFont.FromFontName("Helvetica", 14f); + + + sl?.Children.Add(uibutton.ToView()); + + // Create some control which we know don't behave correctly with regard to measurement + var difficultControl0 = new BrokenNativeControl + { + Font = NSFont.FromFontName("Helvetica", 14f), + MaximumNumberOfLines = 0, + LineBreakMode = NSLineBreakMode.ByWordWrapping, + StringValue = "Doesn't play nice with sizing. That's why there's a big gap around it." + }; + + var difficultControl1 = new BrokenNativeControl + { + Font = NSFont.FromFontName("Helvetica", 14f), + MaximumNumberOfLines = 0, + LineBreakMode = NSLineBreakMode.ByWordWrapping, + StringValue = "Custom size fix specified. No gaps." + }; + + var explanation0 = new NSTextField + { + StringValue = "The next control is a customized label with a bad SizeThatFits implementation.", + MaximumNumberOfLines = 0, + LineBreakMode = NSLineBreakMode.ByWordWrapping, + Font = NSFont.FromFontName("Helvetica", 14f), + }; + + var explanation1 = new NSTextField + { + StringValue = "The next control is the same broken class as above, but we pass in an override to the GetDesiredSize method.", + MaximumNumberOfLines = 0, + LineBreakMode = NSLineBreakMode.ByWordWrapping, + Font = NSFont.FromFontName("Helvetica", 14f), + }; + + // Add a misbehaving control + sl?.Children.Add(explanation0); + sl?.Children.Add(difficultControl0); + + // Add the misbehaving control with a custom delegate for FixSize + sl?.Children.Add(explanation1); + sl?.Children.Add(difficultControl1, FixSize); + + page.NativeControlsAdded = true; + } + + SizeRequest? FixSize(NativeViewWrapperRenderer renderer, double width, double height) + { + var uiView = renderer.Control; + var view = renderer.Element; + + if (uiView == null || view == null) + { + return null; + } + + var constraint = new CGSize(width, height); + + // Let the BrokenNativeControl determine its size (which we know will be wrong) + var badRect = uiView.FittingSize; + + // And we'll use the width (which is fine) and substitute our own height + return new SizeRequest(new Size(badRect.Width, 20)); + } + + void AddNativeBindings(NativeBindingGalleryPage page) + { + if (page.NativeControlsAdded) + return; + + StackLayout sl = page.Layout; + + int width = 200; + int heightCustomLabelView = 100; + + var uilabel = new NSTextField(new CGRect(0, 0, width, heightCustomLabelView)) + { + BackgroundColor = NSColor.Clear, + Editable = false, + Bezeled = false, + DrawsBackground = false, + MaximumNumberOfLines = 0, + LineBreakMode = NSLineBreakMode.ByWordWrapping, + Font = NSFont.FromFontName("Helvetica", 24f), + StringValue = "DefaultText" + }; + + var uibuttonColor = NSButtonExtensions.CreateButton("Toggle Text Color Binding", () => uilabel.TextColor = NSColor.Blue); + uibuttonColor.Font = NSFont.FromFontName("Helvetica", 14f); + + uilabel.SetBinding("StringValue", new Binding("NativeLabel")); + uilabel.SetBinding(nameof(uilabel.TextColor), new Binding("NativeLabelColor", converter: new ColorConverter())); + + sl?.Children.Add(uilabel); + sl?.Children.Add(uibuttonColor.ToView()); + //var colorPicker = new NSColorWell(); + //colorPicker.SetBinding("SelectedColor", new Binding("NativeLabelColor", BindingMode.TwoWay, new ColorConverter()), "ColorPicked"); + //sl?.Children.Add(colorPicker); + page.NativeControlsAdded = true; + } + + #region Stuff for repro of Bugzilla case 40911 + + void SetUp40911Test(Bugzilla40911 page) + { + var button = new Button { Text = "Start" }; + + button.Clicked += (s, e) => + { + StartPressed40911(); + }; + + page.Layout.Children.Add(button); + } + + public void StartPressed40911() + { + var loginViewController = new NSViewController { View = { } }; + var button = NSButtonExtensions.CreateButton("Login", () => + { + Xamarin.Forms.Application.Current.MainPage = new ContentPage { Content = new Label { Text = "40911 Success" } }; + //loginViewController.DismissViewController()true, null); + + }); + + button.Frame = new CGRect(20, 100, 200, 44); + loginViewController.View.AddSubview(button); + + var window = NSApplication.SharedApplication.KeyWindow; + var vc = window.ContentViewController; + while (vc.PresentedViewControllers.Length > 0) + { + vc = vc.PresentedViewControllers[0]; + } + + //vc.PresentViewController(loginViewController, new NSViewControllerPresentationAnimator(); + } + + #endregion + + public class ColorConverter : IValueConverter + { + public object Convert(object value, Type targetType, object parameter, CultureInfo culture) + { + if (value is Color) + return ((Color)value).ToNSColor(); + return value; + } + + public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture) + { + if (value is NSColor) + return ((NSColor)value).ToColor(); + return value; + } + } + } +} + diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-128.png b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-128.png Binary files differnew file mode 100644 index 00000000..d0b5a809 --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-128.png diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-128@2x.png b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-128@2x.png Binary files differnew file mode 100644 index 00000000..f4c8d290 --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-128@2x.png diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-16.png b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-16.png Binary files differnew file mode 100644 index 00000000..ebb5a0fe --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-16.png diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-16@2x.png b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-16@2x.png Binary files differnew file mode 100644 index 00000000..0986d31b --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-16@2x.png diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-256.png b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-256.png Binary files differnew file mode 100644 index 00000000..f4c8d290 --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-256.png diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-256@2x.png b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-256@2x.png Binary files differnew file mode 100644 index 00000000..a142c83f --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-256@2x.png diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-32.png b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-32.png Binary files differnew file mode 100644 index 00000000..0986d31b --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-32.png diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-32@2x.png b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-32@2x.png Binary files differnew file mode 100644 index 00000000..412d6ca9 --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-32@2x.png diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-512.png b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-512.png Binary files differnew file mode 100644 index 00000000..a142c83f --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-512.png diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-512@2x.png b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-512@2x.png Binary files differnew file mode 100644 index 00000000..e99022ae --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/AppIcon-512@2x.png diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/Contents.json b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/Contents.json new file mode 100644 index 00000000..6b285452 --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/AppIcons.appiconset/Contents.json @@ -0,0 +1,68 @@ +{ + "images": [ + { + "filename": "AppIcon-16.png", + "size": "16x16", + "scale": "1x", + "idiom": "mac" + }, + { + "filename": "AppIcon-16@2x.png", + "size": "16x16", + "scale": "2x", + "idiom": "mac" + }, + { + "filename": "AppIcon-32.png", + "size": "32x32", + "scale": "1x", + "idiom": "mac" + }, + { + "filename": "AppIcon-32@2x.png", + "size": "32x32", + "scale": "2x", + "idiom": "mac" + }, + { + "filename": "AppIcon-128.png", + "size": "128x128", + "scale": "1x", + "idiom": "mac" + }, + { + "filename": "AppIcon-128@2x.png", + "size": "128x128", + "scale": "2x", + "idiom": "mac" + }, + { + "filename": "AppIcon-256.png", + "size": "256x256", + "scale": "1x", + "idiom": "mac" + }, + { + "filename": "AppIcon-256@2x.png", + "size": "256x256", + "scale": "2x", + "idiom": "mac" + }, + { + "filename": "AppIcon-512.png", + "size": "512x512", + "scale": "1x", + "idiom": "mac" + }, + { + "filename": "AppIcon-512@2x.png", + "size": "512x512", + "scale": "2x", + "idiom": "mac" + } + ], + "info": { + "version": 1, + "author": "xcode" + } +}
\ No newline at end of file diff --git a/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/Contents.json b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/Contents.json new file mode 100644 index 00000000..4caf392f --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "version" : 1, + "author" : "xcode" + } +}
\ No newline at end of file diff --git a/Xamarin.Forms.ControlGallery.MacOS/BrokenNativeControl.cs b/Xamarin.Forms.ControlGallery.MacOS/BrokenNativeControl.cs new file mode 100644 index 00000000..5c353664 --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/BrokenNativeControl.cs @@ -0,0 +1,23 @@ +using System; +using AppKit; +using CoreGraphics; + +namespace Xamarin.Forms.ControlGallery.MacOS +{ + /// <summary> + /// This is a custom Android control which deliberately does some incorrect measuring/layout + /// </summary> + public class BrokenNativeControl : NSTextField + { + public override string StringValue + { + get { return base.StringValue; } + set { base.StringValue = value.ToUpper(); } + } + + public override CGSize SizeThatFits(CGSize size) + { + return new CGSize(size.Width, 150); + } + } +} diff --git a/Xamarin.Forms.ControlGallery.MacOS/CustomRenderers.cs b/Xamarin.Forms.ControlGallery.MacOS/CustomRenderers.cs new file mode 100644 index 00000000..ae058896 --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/CustomRenderers.cs @@ -0,0 +1,346 @@ +using System; +using System.Collections.Generic; +using AppKit; +using CoreGraphics; +using Foundation; +using Xamarin.Forms; +using Xamarin.Forms.ControlGallery.MacOS; +using Xamarin.Forms.Controls.Issues; +using Xamarin.Forms.Platform.MacOS; + +[assembly: ExportRenderer(typeof(NativeCell), typeof(NativeMacCellRenderer))] +[assembly: ExportRenderer(typeof(NativeListView2), typeof(NativeMacOSListViewRenderer))] +[assembly: ExportRenderer(typeof(NativeListView), typeof(NativeListViewRenderer))] +namespace Xamarin.Forms.ControlGallery.MacOS +{ + public class NativeMacOSListViewRenderer : ViewRenderer<NativeListView2, NSView> + { + NSTableView _nsTableView; + public NativeMacOSListViewRenderer() + { + } + + protected override void OnElementChanged(ElementChangedEventArgs<NativeListView2> e) + { + base.OnElementChanged(e); + + if (Control == null) + { + var scroller = new NSScrollView + { + AutoresizingMask = NSViewResizingMask.HeightSizable | NSViewResizingMask.WidthSizable, + DocumentView = _nsTableView = new NSTableView().AsListViewLook() + }; + + _nsTableView.RowHeight = 60; + SetNativeControl(scroller); + } + + if (e.OldElement != null) + { + // unsubscribe + } + + if (e.NewElement != null) + { + // subscribe + + var s = new NativeiOSListViewSource(e.NewElement, _nsTableView); + _nsTableView.Source = s; + } + } + + protected override void OnElementPropertyChanged(object sender, System.ComponentModel.PropertyChangedEventArgs e) + { + base.OnElementPropertyChanged(sender, e); + + if (e.PropertyName == NativeListView.ItemsProperty.PropertyName) + { + // update the Items list in the UITableViewSource + var s = new NativeiOSListViewSource(Element, _nsTableView); + _nsTableView.Source = s; + } + } + + public override SizeRequest GetDesiredSize(double widthConstraint, double heightConstraint) + { + return Control.GetSizeRequest(widthConstraint, heightConstraint, 44, 44); + } + } + + public class NativeListViewRenderer : ViewRenderer<NativeListView, NSView> + { + public NativeListViewRenderer() + { + } + NSTableView table; + protected override void OnElementChanged(ElementChangedEventArgs<NativeListView> e) + { + base.OnElementChanged(e); + + if (Control == null) + { + var scroller = new NSScrollView + { + AutoresizingMask = NSViewResizingMask.HeightSizable | NSViewResizingMask.WidthSizable, + DocumentView = table = new NSTableView().AsListViewLook() + }; + + table.RowHeight = 60; + + SetNativeControl(scroller); + } + + if (e.OldElement != null) + { + // unsubscribe + } + + if (e.NewElement != null) + { + // subscribe + + var s = new NativeListViewSource(e.NewElement, table); + table.Source = s; + } + } + + protected override void OnElementPropertyChanged(object sender, System.ComponentModel.PropertyChangedEventArgs e) + { + base.OnElementPropertyChanged(sender, e); + + if (e.PropertyName == NativeListView.ItemsProperty.PropertyName) + { + // update the Items list in the UITableViewSource + var s = new NativeListViewSource(Element, table); + table.Source = s; + } + } + + public override SizeRequest GetDesiredSize(double widthConstraint, double heightConstraint) + { + return Control.GetSizeRequest(widthConstraint, heightConstraint, 44, 44); + } + } + + public class NativeiOSListViewSource : NSTableViewSource + { + IList<DataSource> _tableItems; + NativeListView2 _listView; + readonly NSTableView _nsTableView; + readonly NSString _cellIdentifier = new NSString("TableCell"); + + public IEnumerable<DataSource> Items + { + set { _tableItems = new List<DataSource>(value); } + } + + public NativeiOSListViewSource(NativeListView2 view, NSTableView nsTableView) + { + _tableItems = new List<DataSource>(view.Items); + _listView = view; + _nsTableView = nsTableView; + } + + public override nint GetRowCount(NSTableView tableView) + { + return _tableItems.Count; + } + + public override void SelectionDidChange(NSNotification notification) + { + var selectedRow = (int)_nsTableView.SelectedRow; + if (selectedRow == -1) + return; + _listView.NotifyItemSelected(_tableItems[selectedRow]); + Console.WriteLine("Row " + selectedRow.ToString() + " selected"); + _nsTableView.DeselectRow(selectedRow); + } + + public override NSView GetViewForItem(NSTableView tableView, NSTableColumn tableColumn, nint row) + { + NativeMacOsCell cell = tableView.MakeView(_cellIdentifier, tableView) as NativeMacOsCell; + + if (cell == null) + { + cell = new NativeMacOsCell(_cellIdentifier); + } + int rowNumber = (int)row; + if (string.IsNullOrWhiteSpace(_tableItems[rowNumber].ImageFilename)) + { + cell.UpdateCell(_tableItems[rowNumber].Name + , _tableItems[rowNumber].Category + , null); + } + else + { + cell.UpdateCell(_tableItems[rowNumber].Name + , _tableItems[rowNumber].Category + , new NSImage("Images/" + _tableItems[rowNumber].ImageFilename + ".jpg")); + } + + return cell; + } + } + + public class NativeListViewSource : NSTableViewSource + { + // declare vars + IList<string> _tableItems; + string _cellIdentifier = "TableCell"; + NativeListView _listView; + readonly NSTableView _nsTableView; + + public IEnumerable<string> Items + { + set + { + _tableItems = new List<string>(value); + } + } + + public NativeListViewSource(NativeListView view, NSTableView nsTableView) + { + _tableItems = new List<string>(view.Items); + _listView = view; + _nsTableView = nsTableView; + } + + public override nint GetRowCount(NSTableView tableView) + { + return _tableItems.Count; + } + + public override void SelectionDidChange(NSNotification notification) + { + var selectedRow = (int)_nsTableView.SelectedRow; + if (selectedRow == -1) + return; + _listView.NotifyItemSelected(_tableItems[selectedRow]); + Console.WriteLine("Row " + selectedRow.ToString() + " selected"); + _nsTableView.DeselectRow(selectedRow); + } + + public override NSView GetViewForItem(NSTableView tableView, NSTableColumn tableColumn, nint row) + { + var cell = tableView.MakeView(_cellIdentifier, tableView); + + if (cell == null) + { + cell = new NSView(new CGRect(0, 0, tableView.Frame.Width, tableView.RowHeight)); + var textLabel = new NSTextField(new CGRect(1, 1, tableView.Frame.Width, tableView.RowHeight - 10)); + cell.AddSubview(textLabel); + } + var label = cell.Subviews[0] as NSTextField; + label.StringValue = _tableItems[(int)row]; + return cell; + } + } + + public class NativeMacCellRenderer : ViewCellRenderer + { + static NSString s_rid = new NSString("NativeCell"); + + public NativeMacCellRenderer() + { + } + + public override NSView GetCell(Cell item, NSView reusableView, NSTableView tv) + { + var x = (NativeCell)item; + Console.WriteLine(x); + + NativeMacOsCell c = reusableView as NativeMacOsCell; + + if (c == null) + { + c = new NativeMacOsCell(s_rid); + } + + NSImage i = null; + if (!string.IsNullOrWhiteSpace(x.ImageFilename)) + { + i = new NSImage("Images/" + x.ImageFilename + ".jpg"); + } + + base.WireUpForceUpdateSizeRequested(item, c, tv); + + c.UpdateCell(x.Name, x.Category, i); + + return c; + } + } + + public class NativeMacOsCell : NSView + { + NSTextField _headingLabel; + NSTextField _subheadingLabel; + NSImageView _imageView; + + public NativeMacOsCell() : this(new NSString("NativeMacOsCell")) + { + } + public NativeMacOsCell(NSString cellId) + { + Identifier = cellId; + WantsLayer = true; + Layer.BackgroundColor = NSColor.FromRgb(218, 255, 127).CGColor; + + _imageView = new NSImageView(); + + _headingLabel = new NSTextField() + { + Font = NSFont.FromFontName("Cochin-BoldItalic", 22f), + TextColor = NSColor.FromRgb(127, 51, 0), + BackgroundColor = NSColor.Clear + }; + + _subheadingLabel = new NSTextField() + { + Font = NSFont.FromFontName("AmericanTypewriter", 12f), + TextColor = NSColor.FromRgb(38, 127, 0), + Alignment = NSTextAlignment.Center, + BackgroundColor = NSColor.Clear + }; + + AddSubview(_headingLabel); + AddSubview(_subheadingLabel); + AddSubview(_imageView); + } + + public void UpdateCell(string caption, string subtitle, NSImage image) + { + _imageView.Image = image; + _headingLabel.StringValue = caption; + _subheadingLabel.StringValue = subtitle; + } + + public override void Layout() + { + base.Layout(); + + _imageView.Frame = new CGRect(Bounds.Width - 63, 5, 33, 33); + _headingLabel.Frame = new CGRect(5, 4, Bounds.Width - 63, 25); + _subheadingLabel.Frame = new CGRect(100, 18, 100, 20); + } + } + + public static class NSTableViewExtensions + { + public static NSTableView AsListViewLook(this NSTableView self) + { + self.SelectionHighlightStyle = NSTableViewSelectionHighlightStyle.SourceList; + + self.AllowsColumnReordering = false; + self.AllowsColumnResizing = false; + self.AllowsColumnSelection = false; + + //this is needed .. can we go around it ? + self.AddColumn(new NSTableColumn("1")); + //this line hides the header by default + self.HeaderView = null; + return self; + } + } + +} diff --git a/Xamarin.Forms.ControlGallery.MacOS/Entitlements.plist b/Xamarin.Forms.ControlGallery.MacOS/Entitlements.plist new file mode 100644 index 00000000..9ae59937 --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Entitlements.plist @@ -0,0 +1,6 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> +<plist version="1.0"> +<dict> +</dict> +</plist> diff --git a/Xamarin.Forms.ControlGallery.MacOS/Info.plist b/Xamarin.Forms.ControlGallery.MacOS/Info.plist new file mode 100644 index 00000000..da20b03b --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Info.plist @@ -0,0 +1,37 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> +<plist version="1.0"> +<dict> + <key>CFBundleName</key> + <string>Xamarin.Forms.ControlGallery.MacOS</string> + <key>CFBundleIdentifier</key> + <string>com.xamarin.xamarin-forms-controlgallery-macos</string> + <key>CFBundleShortVersionString</key> + <string>1.0</string> + <key>CFBundleVersion</key> + <string>1</string> + <key>LSMinimumSystemVersion</key> + <string>10.10</string> + <key>CFBundleDevelopmentRegion</key> + <string>en</string> + <key>CFBundleInfoDictionaryVersion</key> + <string>6.0</string> + <key>CFBundlePackageType</key> + <string>APPL</string> + <key>CFBundleSignature</key> + <string>????</string> + <key>NSHumanReadableCopyright</key> + <string>rmarinho</string> + <key>NSPrincipalClass</key> + <string>NSApplication</string> + <key>XSAppIconAssets</key> + <string>Assets.xcassets/AppIcons.appiconset</string> + <key>LSApplicationCategoryType</key> + <string>public.app-category.developer-tools</string> + <key>NSAppTransportSecurity</key> + <dict> + <key>NSAllowsArbitraryLoads</key> + <true/> + </dict> +</dict> +</plist> diff --git a/Xamarin.Forms.ControlGallery.MacOS/Main.cs b/Xamarin.Forms.ControlGallery.MacOS/Main.cs new file mode 100644 index 00000000..72dfdb5f --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Main.cs @@ -0,0 +1,14 @@ +using AppKit; + +namespace Xamarin.Forms.ControlGallery.MacOS +{ + static class MainClass + { + static void Main(string[] args) + { + NSApplication.Init(); + NSApplication.SharedApplication.Delegate = new AppDelegate(); + NSApplication.Main(args); + } + } +} diff --git a/Xamarin.Forms.ControlGallery.MacOS/NativeServices.cs b/Xamarin.Forms.ControlGallery.MacOS/NativeServices.cs new file mode 100644 index 00000000..1b813a4e --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/NativeServices.cs @@ -0,0 +1,83 @@ +using System; +using System.IO; +using Xamarin.Forms; +using Xamarin.Forms.ControlGallery.MacOS; +using Xamarin.Forms.Controls; +using Xamarin.Forms.Platform.MacOS; + +[assembly: Dependency(typeof(TestCloudService))] +[assembly: Dependency(typeof(StringProvider))] +[assembly: Dependency(typeof(CacheService))] +[assembly: ExportRenderer(typeof(DisposePage), typeof(DisposePageRenderer))] +[assembly: ExportRenderer(typeof(DisposeLabel), typeof(DisposeLabelRenderer))] + +namespace Xamarin.Forms.ControlGallery.MacOS +{ + public class CacheService : ICacheService + { + public void ClearImageCache() + { + var documents = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments); + var cache = Path.Combine(documents, ".config", ".isolated-storage", "ImageLoaderCache"); + foreach (var file in Directory.GetFiles(cache)) + { + File.Delete(file); + } + } + } + + public class DisposePageRenderer : PageRenderer + { + protected override void Dispose(bool disposing) + { + if (disposing) + { + ((DisposePage)Element).SendRendererDisposed(); + } + base.Dispose(disposing); + + } + } + + public class DisposeLabelRenderer : LabelRenderer + { + protected override void Dispose(bool disposing) + { + + if (disposing) + { + ((DisposeLabel)Element).SendRendererDisposed(); + } + base.Dispose(disposing); + } + } + + public class StringProvider : IStringProvider + { + public string CoreGalleryTitle + { + get { return "iOS Core Gallery"; } + } + } + + public class TestCloudService : ITestCloudService + { + public bool IsOnTestCloud() + { + var isInTestCloud = Environment.GetEnvironmentVariable("XAMARIN_TEST_CLOUD"); + + return isInTestCloud != null && isInTestCloud.Equals("1"); + } + + public string GetTestCloudDeviceName() + { + return Environment.GetEnvironmentVariable("XTC_DEVICE_NAME"); + } + + public string GetTestCloudDevice() + { + return Environment.GetEnvironmentVariable("XTC_DEVICE"); + } + } +} + diff --git a/Xamarin.Forms.ControlGallery.MacOS/Xamarin.Forms.ControlGallery.MacOS.csproj b/Xamarin.Forms.ControlGallery.MacOS/Xamarin.Forms.ControlGallery.MacOS.csproj new file mode 100644 index 00000000..af78b601 --- /dev/null +++ b/Xamarin.Forms.ControlGallery.MacOS/Xamarin.Forms.ControlGallery.MacOS.csproj @@ -0,0 +1,395 @@ +<?xml version="1.0" encoding="utf-8"?> +<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> + <PropertyGroup> + <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration> + <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform> + <ProjectGuid>{8D3DFCB7-DB10-40E5-ACFE-411AAA85520D}</ProjectGuid> + <ProjectTypeGuids>{A3F8F2AB-B479-4A4A-A458-A89E7DC349F1};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}</ProjectTypeGuids> + <OutputType>Exe</OutputType> + <RootNamespace>Xamarin.Forms.ControlGallery.MacOS</RootNamespace> + <AssemblyName>Xamarin.Forms.ControlGallery.MacOS</AssemblyName> + <TargetFrameworkVersion>v2.0</TargetFrameworkVersion> + <TargetFrameworkIdentifier>Xamarin.Mac</TargetFrameworkIdentifier> + <MonoMacResourcePrefix>Resources</MonoMacResourcePrefix> + </PropertyGroup> + <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "> + <DebugSymbols>true</DebugSymbols> + <DebugType>full</DebugType> + <Optimize>false</Optimize> + <OutputPath>bin\Debug</OutputPath> + <DefineConstants>DEBUG;</DefineConstants> + <ErrorReport>prompt</ErrorReport> + <WarningLevel>4</WarningLevel> + <ConsolePause>false</ConsolePause> + <EnableCodeSigning>false</EnableCodeSigning> + <CodeSigningKey>Mac Developer</CodeSigningKey> + <CreatePackage>false</CreatePackage> + <EnablePackageSigning>false</EnablePackageSigning> + <IncludeMonoRuntime>false</IncludeMonoRuntime> + <UseSGen>true</UseSGen> + <UseRefCounting>true</UseRefCounting> + <Profiling>true</Profiling> + <HttpClientHandler></HttpClientHandler> + <TlsProvider></TlsProvider> + <LinkMode></LinkMode> + <XamMacArch></XamMacArch> + </PropertyGroup> + <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> + <Optimize>true</Optimize> + <OutputPath>bin\Release</OutputPath> + <DefineConstants></DefineConstants> + <ErrorReport>prompt</ErrorReport> + <WarningLevel>4</WarningLevel> + <ConsolePause>false</ConsolePause> + <EnableCodeSigning>true</EnableCodeSigning> + <CodeSigningKey>Developer ID Application</CodeSigningKey> + <CreatePackage>true</CreatePackage> + <EnablePackageSigning>false</EnablePackageSigning> + <IncludeMonoRuntime>true</IncludeMonoRuntime> + <UseSGen>true</UseSGen> + <UseRefCounting>true</UseRefCounting> + <LinkMode>SdkOnly</LinkMode> + <HttpClientHandler></HttpClientHandler> + <TlsProvider></TlsProvider> + <XamMacArch></XamMacArch> + </PropertyGroup> + <ItemGroup> + <Reference Include="System" /> + <Reference Include="System.Core" /> + <Reference Include="Xamarin.Mac" /> + </ItemGroup> + <ItemGroup> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\Contents.json" /> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\AppIcon-128.png" /> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\AppIcon-128%402x.png" /> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\AppIcon-16.png" /> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\AppIcon-16%402x.png" /> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\AppIcon-256.png" /> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\AppIcon-256%402x.png" /> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\AppIcon-32.png" /> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\AppIcon-32%402x.png" /> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\AppIcon-512.png" /> + <ImageAsset Include="Assets.xcassets\AppIcons.appiconset\AppIcon-512%402x.png" /> + <ImageAsset Include="Assets.xcassets\Contents.json" /> + </ItemGroup> + <ItemGroup> + <Folder Include="Resources\" /> + </ItemGroup> + <ItemGroup> + <None Include="Info.plist" /> + <None Include="Entitlements.plist" /> + </ItemGroup> + <ItemGroup> + <Compile Include="Main.cs" /> + <Compile Include="AppDelegate.cs" /> + <Compile Include="NativeServices.cs" /> + <Compile Include="BrokenNativeControl.cs" /> + <Compile Include="CustomRenderers.cs" /> + </ItemGroup> + <ItemGroup> + <ProjectReference Include="..\Xamarin.Forms.Controls\Xamarin.Forms.Controls.csproj"> + <Project>{CB9C96CE-125C-4A68-B6A1-C3FF1FBF93E1}</Project> + <Name>Xamarin.Forms.Controls</Name> + </ProjectReference> + <ProjectReference Include="..\Xamarin.Forms.Core\Xamarin.Forms.Core.csproj"> + <Project>{57B8B73D-C3B5-4C42-869E-7B2F17D354AC}</Project> + <Name>Xamarin.Forms.Core</Name> + </ProjectReference> + <ProjectReference Include="..\Xamarin.Forms.Maps\Xamarin.Forms.Maps.csproj"> + <Project>{7D13BAC2-C6A4-416A-B07E-C169B199E52B}</Project> + <Name>Xamarin.Forms.Maps</Name> + </ProjectReference> + <ProjectReference Include="..\Xamarin.Forms.Platform\Xamarin.Forms.Platform.csproj"> + <Project>{67F9D3A8-F71E-4428-913F-C37AE82CDB24}</Project> + <Name>Xamarin.Forms.Platform</Name> + </ProjectReference> + <ProjectReference Include="..\Xamarin.Forms.Platform.MacOS\Xamarin.Forms.Platform.MacOS.csproj"> + <Project>{C0059C45-EA1E-42F3-8A0E-794BB547EC3C}</Project> + <Name>Xamarin.Forms.Platform.macOS</Name> + </ProjectReference> + <ProjectReference Include="..\Xamarin.Forms.Xaml\Xamarin.Forms.Xaml.csproj"> + <Project>{9DB2F292-8034-4E06-89AD-98BBDA4306B9}</Project> + <Name>Xamarin.Forms.Xaml</Name> + </ProjectReference> + <ProjectReference Include="..\Xamarin.Forms.Maps.MacOS\Xamarin.Forms.Maps.MacOS.csproj"> + <Project>{C3C24A6D-2D0C-4053-9FCC-E54FF9CA1884}</Project> + <Name>Xamarin.Forms.Maps.macOS</Name> + </ProjectReference> + </ItemGroup> + <ItemGroup> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\about.png"> + <Link>Resources\about.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\about%402x.png"> + <Link>Resources\about%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\blog.png"> + <Link>Resources\blog.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\blog%402x.png"> + <Link>Resources\blog%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\facebook.png"> + <Link>Resources\facebook.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\facebook%402x.png"> + <Link>Resources\facebook%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\favorite.png"> + <Link>Resources\favorite.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\googleplus.png"> + <Link>Resources\googleplus.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\googleplus%402x.png"> + <Link>Resources\googleplus%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\hm_full.jpg"> + <Link>Resources\hm_full.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\hm.png"> + <Link>Resources\hm.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\hm%402x.png"> + <Link>Resources\hm%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\home.png"> + <Link>Resources\home.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ic_pause.png"> + <Link>Resources\ic_pause.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ic_pause%402x.png"> + <Link>Resources\ic_pause%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ic_play.png"> + <Link>Resources\ic_play.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ic_play%402x.png"> + <Link>Resources\ic_play%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ic_share.png"> + <Link>Resources\ic_share.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ic_share%402x.png"> + <Link>Resources\ic_share%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ic_stop.png"> + <Link>Resources\ic_stop.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ic_stop%402x.png"> + <Link>Resources\ic_stop%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\Icon-60%402x.png"> + <Link>Resources\Icon-60%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\Icon-Small-40%402x.png"> + <Link>Resources\Icon-Small-40%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\Icon-Small.png"> + <Link>Resources\Icon-Small.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\Icon-Small%402x.png"> + <Link>Resources\Icon-Small%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\Icon.png"> + <Link>Resources\Icon.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\Icon%402x.png"> + <Link>Resources\Icon%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\instagram.png"> + <Link>Resources\instagram.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\instagram%402x.png"> + <Link>Resources\instagram%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\lists.png"> + <Link>Resources\lists.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\messages.png"> + <Link>Resources\messages.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\notifications.png"> + <Link>Resources\notifications.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\profile.png"> + <Link>Resources\profile.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ratchet_full.jpg"> + <Link>Resources\ratchet_full.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ratchet.png"> + <Link>Resources\ratchet.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\ratchet%402x.png"> + <Link>Resources\ratchet%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\refresh.png"> + <Link>Resources\refresh.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\refresh%402x.png"> + <Link>Resources\refresh%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\reply.png"> + <Link>Resources\reply.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\retweet.png"> + <Link>Resources\retweet.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\rui.jpg"> + <Link>Resources\rui.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\scott.png"> + <Link>Resources\scott.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\scott159.png"> + <Link>Resources\scott159.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\search.png"> + <Link>Resources\search.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\slideout.png"> + <Link>Resources\slideout.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\slideout%402x.png"> + <Link>Resources\slideout%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\tdl_full.jpg"> + <Link>Resources\tdl_full.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\tdl.png"> + <Link>Resources\tdl.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\tdl%402x.png"> + <Link>Resources\tdl%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\tweet.png"> + <Link>Resources\tweet.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\twitter.png"> + <Link>Resources\twitter.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\twitter%402x.png"> + <Link>Resources\twitter%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\twitternav.png"> + <Link>Resources\twitternav.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\twitternav%402x.png"> + <Link>Resources\twitternav%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Resources\xamarinlogo.png"> + <Link>Resources\xamarinlogo.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\bank.png"> + <Link>Resources\bank.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\bank%402x.png"> + <Link>Resources\bank%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\calculator.png"> + <Link>Resources\calculator.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\calculator%402x.png"> + <Link>Resources\calculator%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\coffee%402x.png"> + <Link>Resources\coffee%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\cover1.jpg"> + <Link>Resources\cover1.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\cover1small.jpg"> + <Link>Resources\cover1small.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\crimson.jpg"> + <Link>Resources\crimson.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\crimsonsmall.jpg"> + <Link>Resources\crimsonsmall.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Default-568h%402x.png"> + <Link>Resources\Default-568h%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Default-667h%402x.png"> + <Link>Resources\Default-667h%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Goobuntu-icon.png"> + <Link>Resources\Goobuntu-icon.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Intranet-icon.png"> + <Link>Resources\Intranet-icon.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\local.html"> + <Link>Resources\local.html</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\menuIcon.png"> + <Link>Resources\menuIcon.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\menuIcon%402x.png"> + <Link>Resources\menuIcon%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\move_slider_one_right_ios6_iphone.base64"> + <Link>Resources\move_slider_one_right_ios6_iphone.base64</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\move_slider_three_right_ios6_iphone.base64"> + <Link>Resources\move_slider_three_right_ios6_iphone.base64</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\move_slider_two_right_ios6_iphone.base64"> + <Link>Resources\move_slider_two_right_ios6_iphone.base64</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\oasis.jpg"> + <Link>Resources\oasis.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\oasissmall.jpg"> + <Link>Resources\oasissmall.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\photo.jpg"> + <Link>Resources\photo.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\seth.png"> + <Link>Resources\seth.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\seth%402x.png"> + <Link>Resources\seth%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\settings%402x.png"> + <Link>Resources\settings%402x.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\test.jpg"> + <Link>Resources\test.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\toolbar_close.png"> + <Link>Resources\toolbar_close.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\coffee.png"> + <Link>Resources\coffee.png</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Images\FlowerBuds.jpg"> + <Link>Images\FlowerBuds.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Images\FlowerBuds%402x.jpg"> + <Link>Images\FlowerBuds%402x.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Images\Fruits.jpg"> + <Link>Images\Fruits.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Images\Fruits%402x.jpg"> + <Link>Images\Fruits%402x.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Images\Legumes.jpg"> + <Link>Images\Legumes.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Images\Legumes%402x.jpg"> + <Link>Images\Legumes%402x.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Images\Vegetables.jpg"> + <Link>Images\Vegetables.jpg</Link> + </BundleResource> + <BundleResource Include="..\Xamarin.Forms.ControlGallery.iOS\Images\Vegetables%402x.jpg"> + <Link>Images\Vegetables%402x.jpg</Link> + </BundleResource> + </ItemGroup> + <Import Project="$(MSBuildExtensionsPath)\Xamarin\Mac\Xamarin.Mac.CSharp.targets" /> +</Project>
\ No newline at end of file |