Skip to content
This repository has been archived by the owner on May 1, 2024. It is now read-only.

Commit

Permalink
Develop to Main for 1.1 (#1108)
Browse files Browse the repository at this point in the history
* Added new TextCaseType to TextCaseConverter (#763)

* Added new TextCaseType to TextCaseConverter

Added support for first char to upper rest to lower case.

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Converters/TextCaseConverter.shared.cs

* Added unit tests and fix bug for empty string

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Converters/TextCaseConverter.shared.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Converters/TextCaseConverter.shared.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Converters/TextCaseConverter.shared.cs

Co-authored-by: Pedro Jesus <[email protected]>

Co-authored-by: joacim wall <[email protected]>
Co-authored-by: Andrei <[email protected]>
Co-authored-by: Pedro Jesus <[email protected]>

* Add LocalizedString class for automatic  ViewModel string updates (#750)

* Add LocalizedString

* Update test name

* Remove from NETSTANDARD1_0

* LangVersion latest

* Revert "LangVersion latest"

This reverts commit e22a4c1.

* Not using linq discard

* Fix test

* Fix test. Add constructor with localizationManager

* Add new feature to sample app

* Add Dispose() to unsubscribe from localizationManager.PropertyChanged

* Fix Sample localization resources generation

* Update sample app to change AppResources.Culture

* Update LocalizedString to use ObservableObject

* Return unsubscribing from localizationManager.PropertyChanged

* Add WeakSubscribe

* Refactor LocalizedString to use WeakSubscribe

* Add test to ensure instance of LocalizedString is disposed

* Dont create instance of LocalizationResourceManager

* Add null checks to WeakSubscribe

* Invoke action with less code

null check has already been done

* Replace spaces with tabs

* Revert "Use Single for getting culture"

* added one more unit test

Co-authored-by: Pedro Jesus <[email protected]>

* Add CommandFactory class (#797)

* Create CommandHelper.shared.cs

* Use CommandHelper in Sample app

* Rename to CommandFactory

* Replace "is null" with "== null"

* Update GravatarImageViewModel.cs

* Update SearchViewModel.cs

* Move CommandFactory to ObjectModel

* Update ConvertExecute and ConvertCanExecute to throw InvalidCommandParameterException

* Add tests

* Skip test in question

* Revert Xamarin.CommunityToolkit.csproj changes

* Fix tests

* Add tests for AsyncValueCommand

* Revert AsyncValueCommandSupport

* Revert "Revert AsyncValueCommandSupport"

This reverts commit 07a178c.

* Creating AsyncValueCommand using CreateValue

* Revert "Creating AsyncValueCommand using CreateValue"

This reverts commit 7b32561.

* Add Create overloads without optional parameters for Task to act as tiebreakers

* Add different names to "execute" parameters to provide another way to resolve ambiguity

* Updated CommandFactory

- Add XML Documentation
- Separated Command.Factory.Command.shared.cs, Command.Factory.IAsyncCommand.shared.cs and Command.Factory.IAsyncValueCommand.shared.cs
- Removed unnecessary CommandFactory.Create methods
- Added missing CommandFactory.Create methods
- Updated Unit Tests

* Updated XML Documentation

Co-authored-by: Brandon Minnick <[email protected]>

* Deprecate LocalizationResourceManager.SetCulture (#766)

* Deprecate SetCulture

* Add EditorBrowsableState.Never

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Helpers/LocalizationResourceManager.shared.cs

* Fix obsolete warning in tests

* Remove unneeded line

* Use new LocalizationResourceManager for tests

Tests were failing from time to time because the same instance of LRM was used for all of them. And since tests are executed in parallel, this caused some issues

* Siplify impicit conversion test to test only conversion itself

* Return Invalidate mathod

Co-authored-by: Pedro Jesus <[email protected]>

* ShadowEffect (#725)

* #461

* Added mac support

* Added sample

* Updated shadows

* Fixed iOS crash

* removed pragma

* Remove effect when color if default

* cleaned code

* Implemented LazyView (#796)

* Created LazyView and implemented it on TabView

* Added Preserve attribute

* Update LazyTestView.xaml

* Adds Popup Control (#653)

* Ported Popup Control from xamarin/Xamarin.Forms#9616 to Xamarin Community Toolkit

* Added missing async/await api

* Added popup result sample and fixed uwp/android implementations

* Renamed View->Content

* Updated styles of sample popups

* Updated BorderColor to be a platform specific property for UWP

* Moved Android/iOS/UWP renderers to platform specific folders

* Changed PopupDismissedEventArgs so it is immutable

* Removed visual studio edits to sample android project

* Removed = false for isDisposed as it is default

* Normalized accessor properties for ios and uwp

* Removed performance apis since they are used internally at Xamarin.Forms

* Simplified OnElementChanged to use shared method ConfigureControl

* Removed iOS 9 code

* Updated NavigationExtensions to follow Xamarin Essentials style by adding netstandard impl that throws exception

* Added Control.Cleanup invocation to dispose method

* [iOS] Removed async/await from OnDismissed since it is an event the invocation doesn't need to know when it is complete

* Fixed comment

* Updated iOS to use WeakEventManager

* changed instantiation to use default(SizeRequest)

* ios - Changed WeakEventManager so it is a protected static object on the popup renderer. This will help create a weak reference to the popup delegate for the GC

* Moved sample popup code to new location

* Added WeakEventManager for BasePopup events (Opened, Dismissed)

* ios - changed popover delegate to use action

* Added PopOverDelegate.PopoverDismissed

* Updated accessor for LightDismiss to protected internal

* Updated comment in LightDismiss

* Removed stale iOS code

* Updated xml comments

* Removed obj dir from compilation in 'netstandard' projects and fixed debugger issues

* removed Init method and added code to get the Context

* changed accessor of ToolkitPlatform to internal

* Added new UI popup tests for Xaml binding vs C# binding

* Updated XCT xmlns to use uri instead of fully qualified namespace

* Added shared popup size across samples

* Fixed popup BindingContext not working when set in XAML

* Update Samples

- Capitalize x:Name variables
- Replace expression-bodied properties with read-only properties where applicable

* Add PopupDismissedEventArgs<T>

* Add Default Values for Color and Size

* Remove Unncessary `base` Keyword, per styling guide

* Optimize originX + originX, Add missing `await`

* Update PopupAnchorViewModel.cs

* Fix orignY

Copy/paste error

* Update PopupRenderer.ios.cs

* Update NavigationExtensions.netstandard.macos.tvos.watchos.tizen.wpf.gtk.cs

* Added NavigableElementExtension - This allows rendering popup from ContentPage and other children of NavigableElement

Co-authored-by: Brandon Minnick <[email protected]>
Co-authored-by: Pedro Jesus <[email protected]>

* Update BaseGalleryViewModel.cs

* Merging is hard

* Fix Anchor Popup Sample NRE (#834)

* Changed LoadView to be Async (#828)

* Changed LoadView to ValueTask LoadViewAsync and added summaries

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Views/LazyView/LazyView.shared.cs

* Popup out of the screen horizontally in Android sample (#839)

* Fix popup out of horizontal bounds

#653 (comment)

* Device Size dependent

* Essentials namespace

* revert

* [Android] Converting dimensions to pixels in popup renderer (#856)

* [Android] Converting dimensions to pixels in popup renderer

* Add fixed and relative to screen sizes instead of platform specific sizes.

* Update ButtonPopup size.

* Update CsharpBindingPopup size.

* Update MultipleButtonPopup size.

* Update NoLightDismissPopup size.

* Update OpenedEventSimplePopup size.

* Update ReturnResultPopup size.

* Update SimplePopup size.

* Update ToggleSizePopup size.

* Update TransparentPopup size.

* Update XamlBindingPopup size.

* #704 [Bug] No padding around text in a Toast or Snackbar (#714)

* Make ShieldView more customizable (#874)

* Add SubjectBackgroundColor, SubjectTextColor/reorganization.

* Update sample.

* Obsolete message

* Correct typo in comment

Co-authored-by: Gerald Versluis <[email protected]>

* Drop UpdateTextColor()

Co-authored-by: Gerald Versluis <[email protected]>

* fixed csproj to produce sourcelink (#893)

* [iOS] Remove popup arrow if anchor isn't set (#854)

* Remove popup arrow if anchor isn't set

* Create PopoverArrowDirection.cs

* Create Popup.shared.cs

* Add arrow direction platform specific.

* Add arrow direction platform specific sample.

* Rename PopoverArrowDirection.cs to PopoverArrowDirection.shared.cs

* Change ArrowDirection to up

* Remove switch PopoverArrowDirection.None since default is already zero.

* Use div 2 instead of multiply by 0.5 for consistency.

Co-authored-by: Sebastian Klatte <[email protected]>

* ProgressBar Attached Property to enable progress animation (#352)

* ProgressBar Attached Property to enable progress animation

* Fixes remarks on PR

* Fix remarks PR

* Changes need for new gallery viewmodel

* Correct version from before rebase

* Update AttachedPropertiesGalleryViewModel.cs

* Update ProgressBarAttachedProperties.shared.cs

* Update ProgressBarAttachedProperties.shared.cs

* Change Attached property to behavior

* Update samples/XCT.Sample/Xamarin.CommunityToolkit.Sample.csproj

Co-authored-by: Andrei <[email protected]>

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Behaviors/ProgressBarAnimationBehavior.cs

Co-authored-by: Andrei <[email protected]>

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Xamarin.CommunityToolkit.csproj

Co-authored-by: Andrei <[email protected]>

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Behaviors/ProgressBarAnimationBehavior.cs

Co-authored-by: Cfun <[email protected]>

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/AttachedProperties/ProgressBarAttachedProperties.shared.cs

Co-authored-by: Cfun <[email protected]>

* Remove old attached property and rename new behavior

Co-authored-by: Gerald Versluis <[email protected]>
Co-authored-by: Andrei <[email protected]>
Co-authored-by: Cfun <[email protected]>

* Merge main into dev (#913)

* [Android] Fix Long Press blocks CollectionView selection  (#764)

* #760

* Moved helper methods to VisualElementExtensions

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Extensions/VisualElementExtension.shared.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Extensions/VisualElementExtension.shared.cs

Co-authored-by: Javier Suárez <[email protected]>
Co-authored-by: Gerald Versluis <[email protected]>

* [Android] Fix SideMenuView + Slider issue (#824)

* [Android] Allow using slider inside SideMenu with disabled gestures

#810

* Refactored gesture default threshold
#810

* Cleaned code. Added linker safety code

* Fixed build

Co-authored-by: Javier Suárez <[email protected]>

* Automated dotnet-format update (#837)

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>

* Remove `Device` dependency from command implementation (#825) (#830)

* Remove `Device` dependency from command implementation (#804)

* Move Xamarin.CommunityToolkit.ObjectModel.Internals classes to `Internals` folder

* Add Platform-Specific MainThread Implementations, Update Unit Tests to Acommidate Context Switching

* Update BaseCommand.uwp.cs

* Add BaseCommand.wpf.cs

* Finish BaseCommand.gtk.cs

* Update BaseCommand.shared.cs

Co-authored-by: Eugen Richter <[email protected]>
Co-authored-by: Brandon Minnick <[email protected]>

* Automated dotnet-format update (#865)

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>

* Fixes #859 (#864)

Co-authored-by: Gerald Versluis <[email protected]>

* ValidationBehavior: Added IsNotValid property (#836)

* Added IsNotValid property to validators

* small fix

* Updated sample

* #822 (#877)

* Fixes AvatarView - Valid source images dont load for the first time they are created  (#849)

* #805

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Views/AvatarView/AvatarView.shared.cs

Co-authored-by: Gerald Versluis <[email protected]>

* Fixed image loading

* Fixed null ref

* Fixes crashes

Co-authored-by: Gerald Versluis <[email protected]>
Co-authored-by: Javier Suárez <[email protected]>
Co-authored-by: Pedro Jesus <[email protected]>

* Added inline docs (#882)

* Update ViewsGalleryViewModel.cs (#888)

removed duplicated text "used to"

* Document all behaviors and associated (#895)

* Housekeeping remove XamlCompilation from code-behind. (#897)

* Changed TabView SelectedIndex property to use TwoWay binding mode (#903)

* Add inline Docs/Comments to Converters (#907)

* Update azure-pipelines.yml

Co-authored-by: Andrei <[email protected]>
Co-authored-by: Javier Suárez <[email protected]>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Eugen Richter <[email protected]>
Co-authored-by: Eugen Richter <[email protected]>
Co-authored-by: Brandon Minnick <[email protected]>
Co-authored-by: Pedro Jesus <[email protected]>
Co-authored-by: WillAutioItrax <[email protected]>
Co-authored-by: Cfun <[email protected]>

* Add "Add(IEnumerable<T> collection)" to ObservableRangeCollection<T> (#891)

* Create ObservableRangeCollectionEx.shared.cs

* Add test

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/ObjectModel/Extensions/ObservableRangeCollectionEx.shared.cs

* Resolve comments

* Add AddToNullCollection test

* Fix WeakSubscribe parameter type

* Revert "Fix WeakSubscribe parameter type"

This reverts commit 221ee0f.

Co-authored-by: Andrei <[email protected]>

* Update INotifyPropertyChangedEx.shared.cs (#918)

* [Breaking Changes] ValidationBehavior Async checks support (#912)

* Refactored validation behavior

* Refactored to ValueTask

* added configure await false

* Fixed isRunning

* LifeCycleEvents (#674)

* Created LifeCycleEffect and platform implementations

* Added sample to LifeCycle effect

* refactor UnLoaded logic

* clean up csproj

* Fixed NRE for shell

* Code Review fixes

* code style

* improved the sample

* fixed tizen path

* Fixed iOS support

* Implemented WeakEventManager

* Added inline docs/comments

* changed to nameof

* Msbuild hotfix (#946)

* fixed msbuild instructions

* revert android sample csproj

* Add `Grouping` class from Refractored.MvvmHelpers (#957)

* Fix LocalizedString gets unsubscribed while still in use (#987)

* Fixed all the things

* Make PersistentObservableObject abstract

* Reverse the inheritance

* Commit to rerun tests

* Remove PersistentObservableObject

* Grammar

* Feature/371 enum boolean converter (#925)

* Implement EnumToBoolConverter (#371)

* Add example for EnumToBoolConverter

* Make it work with flagged enums (#371)

* Simplify code (#371)

* Make the method an local static method (#371)

* Cache enum type info (#371)

Co-authored-by: Eugen Richter <[email protected]>

* Add VSM to ValidationBehavior (#955)

* Add VSM to ValidationBehavior

* dumb commit: Re trigger CI

* Fix typo

* Fix typo

Co-authored-by: Andrei <[email protected]>

* Change string properties to public

* Apply Pascal Case Naming

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Behaviors/Validators/ValidationBehavior.shared.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Behaviors/Validators/ValidationBehavior.shared.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Behaviors/Validators/ValidationBehavior.shared.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Behaviors/Validators/ValidationBehavior.shared.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Behaviors/Validators/ValidationBehavior.shared.cs

Co-authored-by: Andrei <[email protected]>

* Fix Singleton Pattern for LocalizationResourceManager (#919)

* Update LocalizationResourceManager.shared.cs

* Implement Lazy Loading for Thread Safety

* Fix Namespace

* Removed changes from main branch

* Revert Commit

* Update LocalizationResourceManager.shared.cs

* Fix Unit Tests

* Add Collection to LocalizationResourceManagerTests

The `Collection` attribute prevents these tests from running in parallel https://xunit.net/docs/running-tests-in-parallel.html

* [Enhancement] Add Scale support for SideMenuView (#1011)

* SideMenu scaling #1007

* Added easing

* Update azure-pipelines.yml

* [iOS] Fix missing binding context for popup view (#1003)

* [iOS] Fix missing binding context for popup view

* Fix handle binding context changes.

* Enable Nullable (#1009)

* Enable Nullable on Unit Tests (#1008)

* Enable Nullability on Xamarin.CommunityToolkit.Markup (#1013)

* Enable Nullable on Unit Tests

* Enable Nullable on Xamarin.CommunityToolkit.Markup

* Enable Nullability on Xamarin.CommunityToolkit.Sample (#1014)

* Enable Nullable on Unit Tests

* Enable Nullable on Xamarin.CommunityToolkit.Markup

* Enable Nullable on Xamarin.CommunityToolkit.Sample

* Enable Nullability for Android, GTK, iOS, Tizen, UWP & WPF Sample Projects (#1015)

* Enable Nullable on Unit Tests

* Enable Nullable on Xamarin.CommunityToolkit.Markup

* Enable Nullable on Xamarin.CommunityToolkit.Sample

* Enable Nullable on Android, GTK, iOS and Tizen Samples

* Enable Nullable for UWP & WPF Sample Projects

* Enable Nullability on Xamarin.CommunityToolkit (#1016)

* Enable Nullable on Unit Tests

* Enable Nullable on Xamarin.CommunityToolkit.Markup

* Enable Nullable on Xamarin.CommunityToolkit.Sample

* Enable Nullable on Android, GTK, iOS and Tizen Samples

* Enable Nullable for UWP & WPF Sample Projects

* Add Nullability

* Enable Nullable on XamarinCommunityToolkit (#1023)

* Enable Nullable on Unit Tests

* Enable Nullable on Xamarin.CommunityToolkit.Markup

* Enable Nullable on Xamarin.CommunityToolkit.Sample

* Enable Nullable on Android, GTK, iOS and Tizen Samples

* Enable Nullable for UWP & WPF Sample Projects

* Add Nullability

* Resolve Possible Null References

* Removed Possible Null References

* Update AppResources.Designer.cs

* Handle Nullability

* Updated Nullabiltiy

* Update Converters & Unit Tests

* Resolve MediaSource Unit Tests

* Fix Unit Tests (#1036)

* Enable Nullable on Unit Tests

* Enable Nullable on Xamarin.CommunityToolkit.Markup

* Enable Nullable on Xamarin.CommunityToolkit.Sample

* Enable Nullable on Android, GTK, iOS and Tizen Samples

* Enable Nullable for UWP & WPF Sample Projects

* Add Nullability

* Resolve Possible Null References

* Removed Possible Null References

* Update AppResources.Designer.cs

* Handle Nullability

* Updated Nullabiltiy

* Update Converters & Unit Tests

* Resolve MediaSource Unit Tests

* Fix VariableMultiValueConverter

* Fixed ImpliedOrderGridBehavior

* Update NumericValidationBehavior.shared.cs

* Resolve Nullable in SideMenuView

* Move <Nullable>enable</Nullable> to Directory.Build.props

* Update Xamarin.CommunityToolkit.Sample.csproj

* Revert Designer.cs

* Update Xamarin.CommunityToolkit.Sample.csproj

* Update ItemSelectedEventArgsConverter_Tests.cs

* Update SearchViewModel.cs

* Update ItemTappedEventArgsConverter_Tests.cs

* Update Xamarin.CommunityToolkit.UnitTests.csproj

* Add Nullability

* Resolve Compiler Warnings

* Ignore Closing square brackets should be spaced correctly

With Nullable enabled, `byte[]?` is now valid, however SA1011 was still generating a warning

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Behaviors/ImpliedOrderGridBehavior.shared.cs

Co-authored-by: Pedro Jesus <[email protected]>

* Update CameraFragment.android.cs

* Update CameraFragment.android.cs

* Update ImpliedOrderGridBehavior.shared.cs

* Update MaskedBehavior.shared.cs

* Update PopupRenderer.uwp.cs

* Use .NET 5.0

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Add UWP to Release Build

* Update Nullability

* Update Nullablity

* Update TabView.shared.cs

* Update Nullability

* Revert "Update Nullability"

This reverts commit e391b9c.

* Resolved Nullable

* Update azure-pipelines.yml

* Revert UWP Build Properties

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Revert "Update azure-pipelines.yml"

This reverts commit 0842280.

* Update azure-pipelines.yml

* Revert "Revert UWP Build Properties"

This reverts commit 77226bf.

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Revert "Update azure-pipelines.yml"

This reverts commit 4eb36f4.

* Update azure-pipelines.yml

* Revert "Update azure-pipelines.yml"

This reverts commit e41a477.

* Fix ValidationBehavior.ForceValidate and ValidationBehavior.DefaultForceValidateCommand

* Update SelectAllTextEffect.ios.cs

* Remove Nullabilty from LocalizedString.generator

* Update MediaElementRenderer.ios.cs

* Update PopupRenderer.uwp.cs

* Update PopupRenderer.ios.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Views/Snackbar/Helpers/iOS/SnackbarViews/BaseSnackBarView.ios.cs

Co-authored-by: Maksym Koshovyi <[email protected]>

* Update TranslateExtension.shared.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Views/Snackbar/SnackBar.android.cs

Co-authored-by: Maksym Koshovyi <[email protected]>

* Update Logic

* Fix Failing ICommand Tests

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Views/Snackbar/SnackBar.tizen.cs

Co-authored-by: Maksym Koshovyi <[email protected]>

* Throw Faulted Task

* Use Cast instead of Pattern Matching

* Update RangeSlider.shared.cs

* Fix missing semi-colons

* Throw InvalidOperationException in LocalizationResourceManager

* Make TranslateExtension.StringFormat nullable

* Update UserStoppedTypingBehavior.shared.cs

* Update SearchPage.logic.cs

* Update TouchEffectCollectionViewPage.xaml.cs

* Update AppResources.Designer.cs

* Update AppResources.Designer.cs

* Update EnumToBoolConverterViewModel.cs

* Update EnumToBoolConverter_Tests.cs

* Update IntToBoolConverter_Tests.cs

* Update InvertedBoolConverter_Tests.cs

* Update IsNotNullOrEmptyConverter_Tests.cs

* Update MultiConverter_Tests.cs

* Update NotEqualConverter_Tests.cs

* Update TextCaseConverter_Tests.cs

* Update MockPlatformServices.cs

* Update MockPlatformServices.cs

* Update Namespace_Tests.cs

* Update ObservableRangeCollection_Tests.cs

* Update ObservableRangeCollection_Tests.cs

* Use `async Task` instead of `async void`

* Update MultiValidationBehavior.shared.cs

* Update EnumToBoolConverter.shared.cs

* Update EnumToBoolConverter.shared.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Converters/NotEqualConverter.shared.cs

Co-authored-by: Pedro Jesus <[email protected]>

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Converters/StateToBooleanConverter.shared.cs

Co-authored-by: Pedro Jesus <[email protected]>

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Converters/TextCaseConverter.shared.cs

Co-authored-by: Pedro Jesus <[email protected]>

* Update IconTintColorEffectRouter.android.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Effects/SelectAllText/SelectAllTextEffect.android.cs

Co-authored-by: Pedro Jesus <[email protected]>

* Update SelectAllTextEffect.android.cs

* Update SelectAllTextEffect.ios.cs

* Update PlatformTouchEffect.ios.cs

* Update PlatformTouchEffect.uwp.cs

* Update PlatformTouchEffect.uwp.cs

* Update PlatformTouchEffect.macos.cs

* Update PlatformTouchEffect.uwp.cs

* Update PlatformTouchEffect.uwp.cs

* Ensure nullable results from BindableProperties are still resolved

* Update ImageResourceExtension.shared.cs

* Update BaseCommand.android.cs

* Use protected private constructor for BaseCommand

* Update BadgeView.shared.cs

* Update CameraFragment.android.cs

* Fix Android Media Bugs

* Update async/await

* Update CameraView_Tests.cs

* Update CameraView

* Update UriTypeConverter.shared.cs

* Update PopupRenderer.uwp.cs

* Update PopoverArrowDirection.shared.cs

* Update PopoverArrowDirection.shared.cs

* Update TabView.shared.cs

* Improve AsyncCommand Tests

* Ensure Context is non nullable

* Remove Missing Translations

* Fix async/await in TouchEffect.shared.cs

* Make Easing Nullable

* Update Samples

* Fix Null Exception

* Resolve NullReferenceExceptions

* Make IBadgeAnimation Nullable

* Add ShutterCommandValueCreator null check

* Add Timeout to prevent race conditions from stalling tests

* Unsubscribe Event Handlers for AsyncCommand Tests

* Update azure-pipelines.yml

* For WPF, Use Cross-Platform Implementation for `BaseCommand.IsMainThread` and `BaseCommand.BeginInvokeOnMainThread` (#965)

* Add Non-WPF Support to .NET Core 3.1

* Update comments

* Merge .NET Standard and WPF Functionality

* Fix Null Reference

* Update ICommand_AsyncValueCommand_Tests.cs

* Add volatile keyword

* Update AsyncValueCommand_Tests.cs

* Remove Timeouts

* Fix Event Unsubscription

* Add .ConfigureAwait(false);

* Run dotnet test serially

* Use SemaphoreSlim to prevent Race Conditions

Co-authored-by: Pedro Jesus <[email protected]>
Co-authored-by: Maksym Koshovyi <[email protected]>

* add SetFocusOnEntryCompleted (#841) (#911)

* add SetFocusOnEntryCompleted (#841)

* prevent SetFocusOnEntryCompleted memory leak (#841)

also force exception if used on non-Entry

* cleanup (reuse variable) (#841)

* change to attached behavior SetFocusOnEntryCompletedBehavior

* remove AttachedBehaviors sub-namespace

* fix SetFocusOnEntryCompleted_Tests

* simplify SetFocusOnEntryCompletedBehaviorPage

* fixed code to be nullable safe

* code style

Co-authored-by: Pedro Jesus <[email protected]>

* #1046 (#1052)

* #1025 (#1042)

* Merge fixing

* Implement SafeFireAndForgetExtensions (#1054)

* Implement Safe-Fire-And-Forget

* Change `public` to `internal`

* Update PlatformTouchEffect.android.cs

* Regression #853 (#1063)

* [iOS] Fix popup default color and dark mode (#1041)

* [iOS] Fix popup default color and dark mode

* [Android] Set correct background for default color

* [Android] GetWindowColor() for popup background color

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Views/Popup/Android/PopupRenderer.android.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Views/Popup/Android/PopupRenderer.android.cs

* Update BasePopup.shared.cs

* Update PopupRenderer.android.cs

* Update PopupRenderer.android.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Views/Popup/BasePopup.shared.cs

Co-authored-by: Andrei <[email protected]>
Co-authored-by: Brandon Minnick <[email protected]>

* Add remove border effect implementation for uwp (#1048)

Co-authored-by: Alexander Witkowski <[email protected]>

* Added long press event #851 (#1064)

* Update LocalizedString.shared.cs (#1071)

* Image resource converter (#1068)

* Implement ImageResourceConverter

* Add a sample for ImageResource extension

* Fix nullable errors

* Rename converter file to be compiled.

* Better exception message

Co-authored-by: Andrei <[email protected]>

* Update samples/XCT.Sample/ViewModels/Converters/ImageResourceConverterViewModel.cs

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Converters/ImageResourceConverter.shared.cs

* Update samples/XCT.Sample/ViewModels/Converters/ImageResourceConverterViewModel.cs

* Update samples/XCT.Sample/ViewModels/Converters/ImageResourceConverterViewModel.cs

* Update samples/XCT.Sample/ViewModels/Converters/ImageResourceConverterViewModel.cs

* Fix GalleryPage and VM

* Update samples/XCT.Sample/ViewModels/Extensions/ExtensionsGalleryViewModel.cs

Co-authored-by: Andrei <[email protected]>

* Update samples/XCT.Sample/ViewModels/Extensions/ExtensionsGalleryViewModel.cs

Co-authored-by: Andrei <[email protected]>

* Replace Exception approach by extension used by XF (#1028)

* Replace Exception approach by extension used by XF

* Simplified syntax as requested

* Add a missing namespace

* Resolve `IAsyncCommand` / `IAsyncValueValueCommand` Unit Test Race Condition (#1076)

* Add Unit Test Timeouts

* Add macOS Unit Tests

* Build 'samples/XCT.Sample.sln' on macOS

* Restore Unit Test NuGet Packages

* Fix YAML formatting

* Add xunit.runner.console

* Use latest stable version of Microsoft.NET.Test.Sdk

* Fix Unit Tests on macos

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Add SemaphoreSlim

* Add `dotnet restore`

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Revert "Add SemaphoreSlim"

This reverts commit 6875865.

* Revert BaseCommand.semaphoreSlim

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Update azure-pipelines.yml

* Add ConfigureAwait(false) to ValueTaskDelay(int)

* Change Platform from NetCore to macOS

* Passthrough ValueTask

* Update azure-pipelines.yml

* Revert "Update azure-pipelines.yml"

This reverts commit d7b2842.

* Use ConfigureAwait(false)

* Rename Task

* Remove `static`

* Remove `static`

* Revert p:BuildInParallel=false

* Update azure-pipelines.yml

* Revert "Update azure-pipelines.yml"

This reverts commit bf93f0c.

* Revert "Revert "Update azure-pipelines.yml""

This reverts commit 031121a.

* Revert "Revert "Revert "Update azure-pipelines.yml"""

This reverts commit 458feb2.

* #1066 (#1078)

Co-authored-by: Brandon Minnick <[email protected]>

* fix badge background color (#1080) (#1081)

Co-authored-by: Matthew S <[email protected]>
Co-authored-by: Brandon Minnick <[email protected]>
Co-authored-by: Pedro Jesus <[email protected]>

* allow TextCaseConverter to handle any value type (#1053)

* allow TextCaseConverter to handle any value type

* remove duplicate Convert method

* fix nullability

* update TextCaseConverter tests

* Update src/CommunityToolkit/Xamarin.CommunityToolkit/Converters/TextCaseConverter.shared.cs

Co-authored-by: Andrei <[email protected]>
Co-authored-by: Brandon Minnick <[email protected]>
Co-authored-by: Pedro Jesus <[email protected]>

* #850 (#1056)

Co-authored-by: Brandon Minnick <[email protected]>
Co-authored-by: Pedro Jesus <[email protected]>

* Platform specific API (#949)

* added iOS platformSpecific

* added UWP platform specific

* Changed the sample

* code clean up

* added null check for Element

Co-authored-by: Brandon Minnick <[email protected]>
Co-authored-by: Gerald Versluis <[email protected]>

* Add some null checks (#1033)

Co-authored-by: Brandon Minnick <[email protected]>
Co-authored-by: Javier Suárez <[email protected]>
Co-authored-by: Gerald Versluis <[email protected]>

* Migrate Unit Tests to NUnit (#1090)

* Migrate to NUnit

* Update Tests

* Update Azure Pipelines

* Update TextCaseConverter_Tests.cs

* Update DateTimeOffsetConverter_Tests.cs

* Increase Timeout

* Increase Timeout

* Add `const int defaultTimeoutThreshold`

Co-authored-by: Gerald Versluis <[email protected]>

* Enable Nullable for Xamarin.CommunityToolkit.Markup.UnitTests (#1086)

* Add Markup Unit Tests

* Add Nullable to Xamarin.CommunityToolkit.Markdown.UnitTests

* Update BindingHelpers.cs

* Fix Failing Unit Tests

* Don't capture XUnit's Synchronization Context

* Re-order Unit Tests

* Revert "Don't capture XUnit's Synchronization Context"

This reverts commit b8b3f16.

Co-authored-by: Javier Suárez <[email protected]>

* Implement a generic version of the EventToCommandBehavior (#1010)

* created ECBGeneric

* Added Generic implemention to the EventToCommandBehavior

* make EventToCommandBehavior<TType> sealed

* Fixed for value types

* added nullable notations

* update the comment

* fixed unit test

* Migrate Unit Tests to NUnit

* Fixed unitTest

* changed to use C#9 features

* removed Convert method

* Add Inheritance Test

Co-authored-by: Gerald Versluis <[email protected]>
Co-authored-by: Brandon Minnick <[email protected]>

* [UWP] TouchEffect OnPointerReleased crash (#1088)

* Fixed TouchEffect UWP crash

* Touch Effect more nullRef fixes

* fixed build

* fix build

Co-authored-by: Javier Suárez <[email protected]>
Co-authored-by: Pedro Jesus <[email protected]>
Co-authored-by: Brandon Minnick <[email protected]>

Co-authored-by: Joacim Wall <[email protected]>
Co-authored-by: joacim wall <[email protected]>
Co-authored-by: Andrei <[email protected]>
Co-authored-by: Pedro Jesus <[email protected]>
Co-authored-by: Maksym Koshovyi <[email protected]>
Co-authored-by: Brandon Minnick <[email protected]>
Co-authored-by: Andrew Hoefling <[email protected]>
Co-authored-by: Cfun <[email protected]>
Co-authored-by: Sebastian Klatte <[email protected]>
Co-authored-by: Vladislav Antonyuk <[email protected]>
Co-authored-by: Sebastian Klatte <[email protected]>
Co-authored-by: Glenn Versweyveld <[email protected]>
Co-authored-by: Javier Suárez <[email protected]>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Eugen Richter <[email protected]>
Co-authored-by: Eugen Richter <[email protected]>
Co-authored-by: WillAutioItrax <[email protected]>
Co-authored-by: tranb3r <[email protected]>
Co-authored-by: Jacob Egner <[email protected]>
Co-authored-by: Alexander Witkowski <[email protected]>
Co-authored-by: Alexander Witkowski <[email protected]>
Co-authored-by: Matthew S <[email protected]>
Co-authored-by: Matthew S <[email protected]>
Co-authored-by: Dan Siegel <[email protected]>
  • Loading branch information
25 people authored Mar 22, 2021
1 parent 1ae67e1 commit aba6205
Show file tree
Hide file tree
Showing 454 changed files with 12,145 additions and 4,647 deletions.
6 changes: 6 additions & 0 deletions .editorconfig
Original file line number Diff line number Diff line change
Expand Up @@ -107,3 +107,9 @@ csharp_new_line_before_catch = true
csharp_new_line_before_finally = true
csharp_new_line_before_members_in_object_initializers = true
csharp_new_line_before_members_in_anonymous_types = true

# SA1011: Closing square brackets should be spaced correctly
dotnet_diagnostic.SA1011.severity = none

# CS4014: Because this call is not awaited, execution of the current method continues before the call is completed
dotnet_diagnostic.CS4014.severity = error
5 changes: 4 additions & 1 deletion Directory.Build.props
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,12 @@
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">

<PropertyGroup>
<LangVersion>8.0</LangVersion>
<LangVersion>9.0</LangVersion>
<Nullable>enable</Nullable>
<WarningsAsErrors>nullable</WarningsAsErrors>
</PropertyGroup>


<PropertyGroup>
<CodeAnalysisRuleSet>$(MSBuildThisFileDirectory)Xamarin.CommunityToolkit.ruleset</CodeAnalysisRuleSet>
<TreatWarningsAsErrors>false</TreatWarningsAsErrors>
Expand Down
1 change: 0 additions & 1 deletion Xamarin.CommunityToolkit.ruleset
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
<Rule Id="SA1008" Action="Warning" />
<Rule Id="SA1009" Action="Warning" />
<Rule Id="SA1010" Action="Warning" />
<Rule Id="SA1011" Action="Warning" />
<Rule Id="SA1012" Action="Warning" />
<Rule Id="SA1013" Action="Warning" />
<Rule Id="SA1014" Action="Warning" />
Expand Down
89 changes: 64 additions & 25 deletions azure-pipelines.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,16 @@ variables:
NugetPackageVersion: '$(CurrentSemanticVersion)'
#MONO_VERSION: 6_4_0
#XCODE_VERSION: 11.4
NETCORE_VERSION: '3.1.x'
NETCORE_TEST_VERSION: '3.1.x'
NETCORE_VERSION: '5.0.x'
NETCORE_TEST_VERSION_3_1: '3.1.x'
NETCORE_TEST_VERSION_2_1: '2.1.x'
RunPoliCheck: 'false'
PathToCsproj: 'src/CommunityToolkit/Xamarin.CommunityToolkit/Xamarin.CommunityToolkit.csproj'
PathToMarkupCsproj: 'src/Markup/Xamarin.CommunityToolkit.Markup/Xamarin.CommunityToolkit.Markup.csproj'
PathToCommunityToolkitCsproj: 'src/CommunityToolkit/Xamarin.CommunityToolkit/Xamarin.CommunityToolkit.csproj'
PathToSamplesSln: 'samples/XCT.Sample.sln'
PathToCommunityToolkitUnitTestCsproj: 'src/CommunityToolkit/Xamarin.CommunityToolkit.UnitTests/Xamarin.CommunityToolkit.UnitTests.csproj'
PathToMarkupUnitTestCsproj: 'src/Markup/Xamarin.CommunityToolkit.Markup.UnitTests/Xamarin.CommunityToolkit.Markup.UnitTests.csproj'
PathToMsBuildOnMacOS: 'mono /Applications/Visual\ studio.app/Contents/Resources/lib/monodevelop/bin/MSBuild/Current/bin/MSBuild.dll'
PathToSln: 'samples/XCT.Sample.sln'

resources:
Expand Down Expand Up @@ -68,6 +73,21 @@ jobs:
pool:
vmImage: windows-2019
steps:
- task: UseDotNet@2
displayName: 'Install .NET SDK'
inputs:
version: $(NETCORE_VERSION)
includePreviewVersions: false
- task: UseDotNet@2
displayName: 'Install .NET 3.1 Test SDK'
inputs:
version: $(NETCORE_TEST_VERSION_3_1)
includePreviewVersions: false
- task: UseDotNet@2
displayName: 'Install .NET 2.1 Test SDK'
inputs:
version: $(NETCORE_TEST_VERSION_2_1)
includePreviewVersions: false
# if this is a tagged build, then update the version number
- powershell: |
$buildSourceBranch = "$(Build.SourceBranch)"
Expand All @@ -78,19 +98,19 @@ jobs:
condition: startsWith(variables['Build.SourceBranch'], 'refs/tags/')
# restore, build and pack the packages
- task: MSBuild@1
displayName: Build Solution
displayName: Build Xamarin.CommunityToolkit.csproj
inputs:
solution: $(PathToCsproj)
solution: $(PathToCommunityToolkitCsproj)
configuration: Release
msbuildArguments: '/restore /t:Build /p:ContinuousIntegrationBuild=true /p:Deterministic=false'
- task: CopyFiles@2
inputs:
Contents: 'SignList.xml'
TargetFolder: '$(Build.ArtifactStagingDirectory)/nuget'
- task: MSBuild@1
displayName: Pack NuGets
displayName: Pack Community Toolkit NuGets
inputs:
solution: $(PathToCsproj)
solution: $(PathToCommunityToolkitCsproj)
configuration: Release
msbuildArguments: '/t:Pack /p:PackageVersion=$(NugetPackageVersion) /p:PackageOutputPath="$(Build.ArtifactStagingDirectory)/nuget"'
- task: MSBuild@1
Expand All @@ -112,12 +132,14 @@ jobs:
# command: 'custom'
# custom: 'nuget'
# arguments: 'push --source https://nuget.pkg.github.com/xamarin/index.json --api-key $(GitHub.NuGet.Token) "$(Build.ArtifactStagingDirectory)\nuget\*.nupkg"'
- task: DotNetCoreCLI@2
displayName: Run Tests
- task: CmdLine@2
displayName: 'Run Markup Unit Tests'
inputs:
script: dotnet test $(PathToMarkupUnitTestCsproj) -c Release --collect "Code coverage" -p:BuildInParallel=false
- task: CmdLine@2
displayName: 'Run Community Toolkit Unit Tests'
inputs:
command: test
projects: '**/*.UnitTests.csproj'
arguments: '--configuration Release --collect "Code coverage"'
script: dotnet test $(PathToCommunityToolkitUnitTestCsproj) -c Release --collect "Code coverage" -p:BuildInParallel=false
# publish the packages
- task: PublishBuildArtifacts@1
displayName: 'Publish Unsigned NuGets'
Expand Down Expand Up @@ -161,27 +183,44 @@ jobs:
# displayName: Switch to the latest Xcode
# restore, build and pack the packages
- task: UseDotNet@2
displayName: 'Use .Net Core sdk'
displayName: 'Install .NET SDK'
inputs:
version: $(NETCORE_VERSION)
includePreviewVersions: false
- task: UseDotNet@2
displayName: 'Use .Net Core sdk'
displayName: 'Install .NET 3.1 Test SDK'
inputs:
version: $(NETCORE_TEST_VERSION)
version: $(NETCORE_TEST_VERSION_3_1)
includePreviewVersions: false
- task: MSBuild@1
displayName: Build Solution
- task: UseDotNet@2
displayName: 'Install .NET 2.1 Test SDK'
inputs:
solution: $(PathToCsproj)
configuration: Release
msbuildArguments: '/restore /t:Build /p:ContinuousIntegrationBuild=true /p:Deterministic=false'
- task: MSBuild@1
displayName: Pack NuGets
version: $(NETCORE_TEST_VERSION_2_1)
includePreviewVersions: false
- task: CmdLine@2
displayName: 'Build Markup'
inputs:
solution: $(PathToCsproj)
configuration: Release
msbuildArguments: '/t:Pack /p:PackageVersion=$(NugetPackageVersion) /p:PackageOutputPath="$(Build.ArtifactStagingDirectory)/nuget"'
script: '$(PathToMsBuildOnMacOS) $(PathToMarkupCsproj) /p:Configuration=Release /restore /t:Build /p:ContinuousIntegrationBuild=true /p:Deterministic=false'
- task: CmdLine@2
displayName: 'Build Community Toolkit'
inputs:
script: '$(PathToMsBuildOnMacOS) $(PathToCommunityToolkitCsproj) /p:Configuration=Release /restore /t:Build /p:ContinuousIntegrationBuild=true /p:Deterministic=false'
- task: CmdLine@2
displayName: 'Run Markup Unit Tests'
inputs:
script: 'dotnet test $(PathToMarkupUnitTestCsproj) /p:Configuration=Release -p:BuildInParallel=false'
- task: CmdLine@2
displayName: 'Run Community Toolkit Unit Tests'
inputs:
script: 'dotnet test $(PathToCommunityToolkitUnitTestCsproj) /p:Configuration=Release -p:BuildInParallel=false'
- task: CmdLine@2
displayName: 'Pack Markup NuGets'
inputs:
script: '$(PathToMsBuildOnMacOS) $(PathToMarkupUnitTestCsproj) /p:Configuration=Release /t:Pack /p:PackageVersion=$(NugetPackageVersion) /p:PackageOutputPath="$(Build.ArtifactStagingDirectory)/nuget"'
- task: CmdLine@2
displayName: 'Pack CommunityToolkit NuGets'
inputs:
script: '$(PathToMsBuildOnMacOS) $(PathToCommunityToolkitCsproj) /p:Configuration=Release /t:Pack /p:PackageVersion=$(NugetPackageVersion) /p:PackageOutputPath="$(Build.ArtifactStagingDirectory)/nuget"'

- ${{ if eq(variables['System.TeamProject'], 'devdiv') }}:
- template: sign-artifacts/jobs/v2.yml@internal-templates
Expand Down
5 changes: 2 additions & 3 deletions samples/XCT.Sample.Android/MainActivity.cs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@
using Android.Content.PM;
using Android.OS;
using Android.Runtime;
using Xamarin.Essentials;

namespace Xamarin.CommunityToolkit.Sample.Droid
{
Expand All @@ -17,14 +16,14 @@ protected override void OnCreate(Bundle savedInstanceState)
base.OnCreate(savedInstanceState);

global::Xamarin.Forms.Forms.SetFlags("CollectionView_Experimental");
Platform.Init(this, savedInstanceState);
Essentials.Platform.Init(this, savedInstanceState);
global::Xamarin.Forms.Forms.Init(this, savedInstanceState);
LoadApplication(new App());
}

public override void OnRequestPermissionsResult(int requestCode, string[] permissions, [GeneratedEnum] Permission[] grantResults)
{
Platform.OnRequestPermissionsResult(requestCode, permissions, grantResults);
Essentials.Platform.OnRequestPermissionsResult(requestCode, permissions, grantResults);

base.OnRequestPermissionsResult(requestCode, permissions, grantResults);
}
Expand Down
2 changes: 1 addition & 1 deletion samples/XCT.Sample.Android/SplashActivity.cs
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ namespace Xamarin.CommunityToolkit.Sample.Droid
[Activity(Label = "XamarinCommunityToolkitSample", Icon = "@mipmap/icon", Theme = "@style/SplashTheme", MainLauncher = true, ConfigurationChanges = ConfigChanges.ScreenSize | ConfigChanges.Orientation)]
public class SplashActivity : AppCompatActivity
{
protected override void OnCreate(Bundle savedInstanceState)
protected override void OnCreate(Bundle? savedInstanceState)
{
base.OnCreate(savedInstanceState);
var intent = new Intent(this, typeof(MainActivity));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
<DebugSymbols>true</DebugSymbols>
<DebugType>portable</DebugType>
<DebugType>full</DebugType>
<Optimize>false</Optimize>
<OutputPath>bin\Debug</OutputPath>
<DefineConstants>DEBUG;</DefineConstants>
Expand Down
4 changes: 2 additions & 2 deletions samples/XCT.Sample.UWP/App.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ protected override void OnLaunched(LaunchActivatedEventArgs e)
/// </summary>
/// <param name="sender">The Frame which failed navigation</param>
/// <param name="e">Details about the navigation failure</param>
void OnNavigationFailed(object sender, NavigationFailedEventArgs e)
void OnNavigationFailed(object? sender, NavigationFailedEventArgs e)
{
throw new Exception("Failed to load Page " + e.SourcePageType.FullName);
}
Expand All @@ -97,7 +97,7 @@ void OnNavigationFailed(object sender, NavigationFailedEventArgs e)
/// </summary>
/// <param name="sender">The source of the suspend request.</param>
/// <param name="e">Details about the suspend request.</param>
void OnSuspending(object sender, SuspendingEventArgs e)
void OnSuspending(object? sender, SuspendingEventArgs e)
{
var deferral = e.SuspendingOperation.GetDeferral();

Expand Down
7 changes: 5 additions & 2 deletions samples/XCT.Sample.iOS/Renderers/NoLineNavigationRenderer.cs
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,11 @@ public override void ViewWillAppear(bool animated)
// Newest iOS version fix - trycatch isn't optimal
try
{
NavigationBar.ScrollEdgeAppearance.ShadowImage = new UIKit.UIImage();
NavigationBar.ScrollEdgeAppearance.ShadowColor = null;
if (NavigationBar.ScrollEdgeAppearance != null)
{
NavigationBar.ScrollEdgeAppearance.ShadowImage = new UIKit.UIImage();
NavigationBar.ScrollEdgeAppearance.ShadowColor = null;
}
}
catch (Exception)
{
Expand Down
36 changes: 33 additions & 3 deletions samples/XCT.Sample.sln
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,9 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Xamarin.CommunityToolkit.Sa
EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{F695F5E8-420F-475F-A4CF-F5BB3FA6E818}"
ProjectSection(SolutionItems) = preProject
.editorconfig = .editorconfig
Directory.Build.props = Directory.Build.props
Xamarin.CommunityToolkit.ruleset = Xamarin.CommunityToolkit.ruleset
..\.editorconfig = ..\.editorconfig
..\Directory.Build.props = ..\Directory.Build.props
..\Xamarin.CommunityToolkit.ruleset = ..\Xamarin.CommunityToolkit.ruleset
EndProjectSection
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Xamarin.CommunityToolkit.Sample.WPF", "XCT.Sample.WPF\Xamarin.CommunityToolkit.Sample.WPF.csproj", "{C4D6CD2D-8DF4-4D46-936C-1AB31C87B5EA}"
Expand All @@ -31,6 +31,8 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Xamarin.CommunityToolkit.Sa
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Xamarin.CommunityToolkit.Markup", "..\src\Markup\Xamarin.CommunityToolkit.Markup\Xamarin.CommunityToolkit.Markup.csproj", "{A5AAB927-15D7-498C-8295-4209F21836CE}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Xamarin.CommunityToolkit.Markup.UnitTests", "..\src\Markup\Xamarin.CommunityToolkit.Markup.UnitTests\Xamarin.CommunityToolkit.Markup.UnitTests.csproj", "{AAE423C4-E9B4-434E-885C-2164C12BF79C}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
Expand Down Expand Up @@ -62,6 +64,7 @@ Global
{8B80BFA6-7B19-4DE7-BD97-7D84194AD0C2}.Debug|x86.Build.0 = Debug|Any CPU
{8B80BFA6-7B19-4DE7-BD97-7D84194AD0C2}.Release|Any CPU.ActiveCfg = Release|Any CPU
{8B80BFA6-7B19-4DE7-BD97-7D84194AD0C2}.Release|Any CPU.Build.0 = Release|Any CPU
{8B80BFA6-7B19-4DE7-BD97-7D84194AD0C2}.Release|Any CPU.Deploy.0 = Release|Any CPU
{8B80BFA6-7B19-4DE7-BD97-7D84194AD0C2}.Release|ARM.ActiveCfg = Release|Any CPU
{8B80BFA6-7B19-4DE7-BD97-7D84194AD0C2}.Release|ARM.Build.0 = Release|Any CPU
{8B80BFA6-7B19-4DE7-BD97-7D84194AD0C2}.Release|iPhone.ActiveCfg = Release|Any CPU
Expand Down Expand Up @@ -191,6 +194,8 @@ Global
{91C748B4-E9ED-4543-880A-26747B03DE3A}.Debug|x86.Build.0 = Debug|x86
{91C748B4-E9ED-4543-880A-26747B03DE3A}.Debug|x86.Deploy.0 = Debug|x86
{91C748B4-E9ED-4543-880A-26747B03DE3A}.Release|Any CPU.ActiveCfg = Release|x86
{91C748B4-E9ED-4543-880A-26747B03DE3A}.Release|Any CPU.Build.0 = Release|x86
{91C748B4-E9ED-4543-880A-26747B03DE3A}.Release|Any CPU.Deploy.0 = Release|x86
{91C748B4-E9ED-4543-880A-26747B03DE3A}.Release|ARM.ActiveCfg = Release|ARM
{91C748B4-E9ED-4543-880A-26747B03DE3A}.Release|ARM.Build.0 = Release|ARM
{91C748B4-E9ED-4543-880A-26747B03DE3A}.Release|ARM.Deploy.0 = Release|ARM
Expand Down Expand Up @@ -298,12 +303,37 @@ Global
{A5AAB927-15D7-498C-8295-4209F21836CE}.Release|x64.Build.0 = Release|Any CPU
{A5AAB927-15D7-498C-8295-4209F21836CE}.Release|x86.ActiveCfg = Release|Any CPU
{A5AAB927-15D7-498C-8295-4209F21836CE}.Release|x86.Build.0 = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|Any CPU.Build.0 = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|ARM.ActiveCfg = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|ARM.Build.0 = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|iPhone.ActiveCfg = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|iPhone.Build.0 = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|x64.ActiveCfg = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|x64.Build.0 = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|x86.ActiveCfg = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Debug|x86.Build.0 = Debug|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|Any CPU.ActiveCfg = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|Any CPU.Build.0 = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|ARM.ActiveCfg = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|ARM.Build.0 = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|iPhone.ActiveCfg = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|iPhone.Build.0 = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|iPhoneSimulator.Build.0 = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|x64.ActiveCfg = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|x64.Build.0 = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|x86.ActiveCfg = Release|Any CPU
{AAE423C4-E9B4-434E-885C-2164C12BF79C}.Release|x86.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
GlobalSection(NestedProjects) = preSolution
{54B7812B-45A5-4FE2-9CEA-C5F17D65BDE9} = {47DFE508-04F1-433D-8C55-0C1ACD033573}
{AAE423C4-E9B4-434E-885C-2164C12BF79C} = {47DFE508-04F1-433D-8C55-0C1ACD033573}
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {449686DB-B85A-4DFA-AA26-9BC92468CC2A}
Expand Down
6 changes: 5 additions & 1 deletion samples/XCT.Sample/App.xaml.cs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
using Xamarin.CommunityToolkit.Helpers;
using System.Globalization;
using Xamarin.CommunityToolkit.Helpers;
using Xamarin.CommunityToolkit.Sample.Pages;
using Xamarin.CommunityToolkit.Sample.Resx;
using Xamarin.Forms.PlatformConfiguration;
Expand All @@ -11,7 +12,10 @@ public partial class App : Forms.Application
public App()
{
On<Windows>().SetImageDirectory("Assets");

LocalizationResourceManager.Current.PropertyChanged += (sender, e) => AppResources.Culture = LocalizationResourceManager.Current.CurrentCulture;
LocalizationResourceManager.Current.Init(AppResources.ResourceManager);
LocalizationResourceManager.Current.CurrentCulture = new CultureInfo("en");

InitializeComponent();
MainPage = new BaseNavigationPage(new WelcomePage());
Expand Down
Loading

0 comments on commit aba6205

Please sign in to comment.