This commit is contained in:
Sivaram ganesan 2018-08-07 17:32:19 +05:30
Родитель 3e3a351361
Коммит eaef91e110
124 изменённых файлов: 8694 добавлений и 6298 удалений

Просмотреть файл

@ -1,7 +1,7 @@

Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio 14
VisualStudioVersion = 14.0.25420.1
# Visual Studio 15
VisualStudioVersion = 15.0.27703.2042
MinimumVisualStudioVersion = 10.0.40219.1
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ExpenseAnalysis", "ExpenseAnalysis\ExpenseAnalysis\ExpenseAnalysis.csproj", "{B0B25CE3-0BD0-49CC-BCE4-49260106218A}"
EndProject
@ -11,6 +11,8 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ExpenseAnalysis.iOS", "Expe
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ExpenseAnalysis.UWP", "ExpenseAnalysis\ExpenseAnalysis.UWP\ExpenseAnalysis.UWP.csproj", "{E67232AE-84B8-400B-BD13-80E750DBE388}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ExpenseAnalysis.macOS", "ExpenseAnalysis\ExpenseAnalysis.macOS\ExpenseAnalysis.macOS.csproj", "{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Ad-Hoc|Any CPU = Ad-Hoc|Any CPU
@ -176,6 +178,7 @@ Global
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.AppStore|x64.ActiveCfg = AppStore|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.AppStore|x86.ActiveCfg = AppStore|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Debug|Any CPU.ActiveCfg = Debug|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Debug|Any CPU.Build.0 = Debug|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Debug|ARM.ActiveCfg = Debug|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Debug|iPhone.ActiveCfg = Debug|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Debug|iPhone.Build.0 = Debug|iPhone
@ -183,6 +186,7 @@ Global
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Debug|iPhoneSimulator.Build.0 = Debug|iPhoneSimulator
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Debug|x64.ActiveCfg = Debug|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Debug|x86.ActiveCfg = Debug|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Debug|x86.Build.0 = Debug|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Release|Any CPU.ActiveCfg = Release|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Release|Any CPU.Build.0 = Release|iPhone
{A52F1D41-5F5A-400A-B1C6-1225B236B55A}.Release|ARM.ActiveCfg = Release|iPhone
@ -256,8 +260,59 @@ Global
{E67232AE-84B8-400B-BD13-80E750DBE388}.Release|x86.ActiveCfg = Release|x86
{E67232AE-84B8-400B-BD13-80E750DBE388}.Release|x86.Build.0 = Release|x86
{E67232AE-84B8-400B-BD13-80E750DBE388}.Release|x86.Deploy.0 = Release|x86
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|Any CPU.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|ARM.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|ARM.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|iPhone.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|iPhoneSimulator.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|x64.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|x64.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|x86.ActiveCfg = Release|x86
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Ad-Hoc|x86.Build.0 = Release|x86
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|Any CPU.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|Any CPU.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|ARM.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|ARM.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|iPhone.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|iPhone.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|iPhoneSimulator.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|x64.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|x64.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|x86.ActiveCfg = Release|x86
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.AppStore|x86.Build.0 = Release|x86
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|Any CPU.Build.0 = Debug|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|ARM.ActiveCfg = Debug|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|ARM.Build.0 = Debug|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|iPhone.ActiveCfg = Debug|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|iPhone.Build.0 = Debug|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|x64.ActiveCfg = Debug|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|x64.Build.0 = Debug|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|x86.ActiveCfg = Debug|x86
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Debug|x86.Build.0 = Debug|x86
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|Any CPU.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|Any CPU.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|ARM.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|ARM.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|iPhone.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|iPhone.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|iPhoneSimulator.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|x64.ActiveCfg = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|x64.Build.0 = Release|Any CPU
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|x86.ActiveCfg = Release|x86
{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}.Release|x86.Build.0 = Release|x86
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {40D98E52-F2F7-4012-9E44-BBBE94448BBC}
EndGlobalSection
EndGlobal

Просмотреть файл

@ -98,77 +98,62 @@
<HintPath>..\..\packages\SQLitePCLRaw.provider.e_sqlite3.android.1.1.2\lib\MonoAndroid\SQLitePCLRaw.provider.e_sqlite3.dll</HintPath>
<Private>True</Private>
</Reference>
<Reference Include="Syncfusion.Core.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.Core.16.1.0.37\lib\MonoAndroid10\Syncfusion.Core.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.Core.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.Core.16.2.0.42\lib\MonoAndroid10\Syncfusion.Core.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.Data.Portable, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.1.0.37\lib\MonoAndroid10\Syncfusion.Data.Portable.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.Data.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\MonoAndroid10\Syncfusion.Data.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.DataSource.Portable, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.DataSource.16.1.0.37\lib\MonoAndroid10\Syncfusion.DataSource.Portable.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.DataSource.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.DataSource.16.2.0.42\lib\MonoAndroid10\Syncfusion.DataSource.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.GridCommon.Portable, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.GridCommon.16.1.0.37\lib\MonoAndroid10\Syncfusion.GridCommon.Portable.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.GridCommon.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.GridCommon.16.2.0.42\lib\MonoAndroid10\Syncfusion.GridCommon.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfChart.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfChart.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.Licensing, Version=16.2.0.43, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Licensing.16.2.0.43\lib\MonoAndroid10\Syncfusion.Licensing.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfChart.XForms.Android, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfChart.XForms.Android.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfChart.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfChart.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataForm.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataForm.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfDataForm.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfChart.XForms.Android, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfChart.XForms.Android.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataForm.XForms.Android, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataForm.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfDataForm.XForms.Android.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfDataForm.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataForm.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfDataForm.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataGrid.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfDataGrid.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfDataForm.XForms.Android, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataForm.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfDataForm.XForms.Android.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataGrid.XForms.Android, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfDataGrid.XForms.Android.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfDataGrid.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfDataGrid.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfListView.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfListView.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfDataGrid.XForms.Android, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfDataGrid.XForms.Android.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfListView.XForms.Android, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfListView.XForms.Android.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfListView.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfListView.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericTextBox.Android, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfNumericTextBox.Android.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfListView.XForms.Android, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfListView.XForms.Android.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericTextBox.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfNumericTextBox.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericTextBox.Android, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfNumericTextBox.Android.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericTextBox.XForms.Android, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfNumericTextBox.XForms.Android.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericTextBox.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfNumericTextBox.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.Android, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfNumericUpDown.Android.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericTextBox.XForms.Android, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfNumericTextBox.XForms.Android.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfNumericUpDown.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericUpDown.Android, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfNumericUpDown.Android.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.XForms.Android, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.1.0.37\lib\MonoAndroid10\Syncfusion.SfNumericUpDown.XForms.Android.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericUpDown.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfNumericUpDown.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.XForms.Android, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.2.0.42\lib\MonoAndroid10\Syncfusion.SfNumericUpDown.XForms.Android.dll</HintPath>
</Reference>
<Reference Include="System" />
<Reference Include="System.Core" />

Просмотреть файл

@ -6,6 +6,7 @@ using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.OS;
using Android.Graphics;
namespace ExpenseAnalysis.Droid
{
@ -16,9 +17,8 @@ namespace ExpenseAnalysis.Droid
{
TabLayoutResource = Resource.Layout.Tabbar;
ToolbarResource = Resource.Layout.Toolbar;
Window.SetStatusBarColor(Color.Rgb(63,83, 159));
base.OnCreate(bundle);
global::Xamarin.Forms.Forms.Init(this, bundle);
LoadApplication(new App());
}

Разница между файлами не показана из-за своего большого размера Загрузить разницу

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 2.3 KiB

Двоичный файл не отображается.

До

Ширина:  |  Высота:  |  Размер: 1.4 KiB

После

Ширина:  |  Высота:  |  Размер: 325 B

Двоичный файл не отображается.

До

Ширина:  |  Высота:  |  Размер: 3.2 KiB

После

Ширина:  |  Высота:  |  Размер: 950 B

Двоичный файл не отображается.

До

Ширина:  |  Высота:  |  Размер: 2.1 KiB

После

Ширина:  |  Высота:  |  Размер: 673 B

Двоичный файл не отображается.

До

Ширина:  |  Высота:  |  Размер: 2.6 KiB

После

Ширина:  |  Высота:  |  Размер: 839 B

Просмотреть файл

@ -8,15 +8,16 @@
<package id="SQLitePCLRaw.core" version="1.1.2" targetFramework="monoandroid60" />
<package id="SQLitePCLRaw.lib.e_sqlite3.android" version="1.1.2" targetFramework="monoandroid60" />
<package id="SQLitePCLRaw.provider.e_sqlite3.android" version="1.1.2" targetFramework="monoandroid60" />
<package id="Syncfusion.Xamarin.Core" version="16.1.0.37" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.DataSource" version="16.1.0.37" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.GridCommon" version="16.1.0.37" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfChart" version="16.1.0.37" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfDataForm" version="16.1.0.37" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfDataGrid" version="16.1.0.37" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfListView" version="16.1.0.37" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfNumericTextBox" version="16.1.0.37" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfNumericUpDown" version="16.1.0.37" targetFramework="monoandroid80" />
<package id="Syncfusion.Licensing" version="16.2.0.43" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.Core" version="16.2.0.42" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.DataSource" version="16.2.0.42" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.GridCommon" version="16.2.0.42" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfChart" version="16.2.0.42" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfDataForm" version="16.2.0.42" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfDataGrid" version="16.2.0.42" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfListView" version="16.2.0.42" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfNumericTextBox" version="16.2.0.42" targetFramework="monoandroid80" />
<package id="Syncfusion.Xamarin.SfNumericUpDown" version="16.2.0.42" targetFramework="monoandroid80" />
<package id="System.AppContext" version="4.1.0" targetFramework="monoandroid60" />
<package id="System.Collections" version="4.0.11" targetFramework="monoandroid60" />
<package id="System.Collections.Concurrent" version="4.0.12" targetFramework="monoandroid60" />

Просмотреть файл

@ -2,7 +2,7 @@
x:Class="ExpenseAnalysis.UWP.App"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:ExpenseAnalysis.UWP"
xmlns:local="using:ExpenseAnalysis.UWP"
RequestedTheme="Light">
<Application.Resources>

Просмотреть файл

@ -17,7 +17,8 @@
<EnableDotNetNativeCompatibleProfile>true</EnableDotNetNativeCompatibleProfile>
<FileAlignment>512</FileAlignment>
<ProjectTypeGuids>{A5A43C5B-DE2A-4C0C-9213-0A381AF9435A};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}</ProjectTypeGuids>
<PackageCertificateKeyFile>Windows_TemporaryKey.pfx</PackageCertificateKeyFile>
<PackageCertificateKeyFile>ExpenseAnalysis.UWP_TemporaryKey.pfx</PackageCertificateKeyFile>
<PackageCertificateThumbprint>98DF2D09E024104C8550637D99F0FB4D284C4509</PackageCertificateThumbprint>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|ARM'">
<DebugSymbols>true</DebugSymbols>
@ -90,6 +91,7 @@
</PropertyGroup>
<ItemGroup>
<!-- A reference to the entire .Net Framework and Windows SDK are automatically included -->
<None Include="ExpenseAnalysis.UWP_TemporaryKey.pfx" />
<None Include="project.json" />
</ItemGroup>
<ItemGroup>

Просмотреть файл

@ -1,9 +1,18 @@
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<Project ToolsVersion="14.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup Condition="'$(NuGetPackageRoot)' == ''">
<NuGetPackageRoot>$(UserProfile)\.nuget\packages\</NuGetPackageRoot>
<PropertyGroup Condition=" '$(ExcludeRestorePackageImports)' != 'true' ">
<RestoreSuccess Condition=" '$(RestoreSuccess)' == '' ">True</RestoreSuccess>
<RestoreTool Condition=" '$(RestoreTool)' == '' ">NuGet</RestoreTool>
<ProjectAssetsFile Condition=" '$(ProjectAssetsFile)' == '' ">D:\Muneesh_Exp\ExpenseAnalysis\ExpenseAnalysis.UWP\project.lock.json</ProjectAssetsFile>
<NuGetPackageRoot Condition=" '$(NuGetPackageRoot)' == '' ">$(UserProfile)\.nuget\packages\</NuGetPackageRoot>
<NuGetPackageFolders Condition=" '$(NuGetPackageFolders)' == '' ">C:\Users\mageshkumarkrishnan\.nuget\packages\</NuGetPackageFolders>
<NuGetProjectStyle Condition=" '$(NuGetProjectStyle)' == '' ">ProjectJson</NuGetProjectStyle>
<NuGetToolVersion Condition=" '$(NuGetToolVersion)' == '' ">4.7.0</NuGetToolVersion>
</PropertyGroup>
<ImportGroup>
<Import Project="$(NuGetPackageRoot)\Xamarin.Forms\2.4.0.280\build\netstandard1.0\Xamarin.Forms.props" Condition="Exists('$(NuGetPackageRoot)\Xamarin.Forms\2.4.0.280\build\netstandard1.0\Xamarin.Forms.props')" />
<PropertyGroup>
<MSBuildAllProjects>$(MSBuildAllProjects);$(MSBuildThisFileFullPath)</MSBuildAllProjects>
</PropertyGroup>
<ImportGroup Condition=" '$(ExcludeRestorePackageImports)' != 'true' ">
<Import Project="$(NuGetPackageRoot)xamarin.forms\2.4.0.280\build\netstandard1.0\Xamarin.Forms.props" Condition="Exists('$(NuGetPackageRoot)xamarin.forms\2.4.0.280\build\netstandard1.0\Xamarin.Forms.props')" />
</ImportGroup>
</Project>

Просмотреть файл

@ -1,10 +1,10 @@
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<Project ToolsVersion="14.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup Condition="'$(NuGetPackageRoot)' == ''">
<NuGetPackageRoot>$(UserProfile)\.nuget\packages\</NuGetPackageRoot>
<PropertyGroup>
<MSBuildAllProjects>$(MSBuildAllProjects);$(MSBuildThisFileFullPath)</MSBuildAllProjects>
</PropertyGroup>
<ImportGroup>
<Import Project="$(NuGetPackageRoot)\SQLitePCLRaw.lib.e_sqlite3.v140\1.1.2\build\SQLitePCLRaw.lib.e_sqlite3.v140.targets" Condition="Exists('$(NuGetPackageRoot)\SQLitePCLRaw.lib.e_sqlite3.v140\1.1.2\build\SQLitePCLRaw.lib.e_sqlite3.v140.targets')" />
<Import Project="$(NuGetPackageRoot)\Xamarin.Forms\2.4.0.280\build\netstandard1.0\Xamarin.Forms.targets" Condition="Exists('$(NuGetPackageRoot)\Xamarin.Forms\2.4.0.280\build\netstandard1.0\Xamarin.Forms.targets')" />
<ImportGroup Condition=" '$(ExcludeRestorePackageImports)' != 'true' ">
<Import Project="$(NuGetPackageRoot)xamarin.forms\2.4.0.280\build\netstandard1.0\Xamarin.Forms.targets" Condition="Exists('$(NuGetPackageRoot)xamarin.forms\2.4.0.280\build\netstandard1.0\Xamarin.Forms.targets')" />
<Import Project="$(NuGetPackageRoot)sqlitepclraw.lib.e_sqlite3.v140\1.1.2\build\SQLitePCLRaw.lib.e_sqlite3.v140.targets" Condition="Exists('$(NuGetPackageRoot)sqlitepclraw.lib.e_sqlite3.v140\1.1.2\build\SQLitePCLRaw.lib.e_sqlite3.v140.targets')" />
</ImportGroup>
</Project>

Двоичный файл не отображается.

Просмотреть файл

@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<Package xmlns="http://schemas.microsoft.com/appx/manifest/foundation/windows10" xmlns:mp="http://schemas.microsoft.com/appx/2014/phone/manifest" xmlns:uap="http://schemas.microsoft.com/appx/manifest/uap/windows10" IgnorableNamespaces="uap mp">
<Identity Name="0dc5979e-9c72-4bbb-a2db-baf399d495ff" Publisher="CN=mageshkumarkrishnan" Version="1.0.0.0" />
<Identity Name="0dc5979e-9c72-4bbb-a2db-baf399d495ff" Publisher="CN=Syncfusion" Version="1.0.0.0" />
<mp:PhoneIdentity PhoneProductId="0dc5979e-9c72-4bbb-a2db-baf399d495ff" PhonePublisherId="00000000-0000-0000-0000-000000000000" />
<Properties>
<DisplayName>ExpenseAnalysis.UWP</DisplayName>

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.UWP/category.png

Двоичный файл не отображается.

До

Ширина:  |  Высота:  |  Размер: 393 B

После

Ширина:  |  Высота:  |  Размер: 325 B

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.UWP/message.png

Двоичный файл не отображается.

До

Ширина:  |  Высота:  |  Размер: 846 B

После

Ширина:  |  Высота:  |  Размер: 950 B

Просмотреть файл

@ -4,12 +4,13 @@
"sqlite-net-pcl": "1.3.1",
"SQLite.Net-PCL": "3.1.0",
"SQLitePCL.raw": "0.9.4-pre1",
"Syncfusion.Xamarin.DataSource": "16.1.0.37",
"Syncfusion.Xamarin.SfChart": "16.1.0.37",
"Syncfusion.Xamarin.SfDataForm": "16.1.0.37",
"Syncfusion.Xamarin.SfDataGrid": "16.1.0.37",
"Syncfusion.Xamarin.SfListView": "16.1.0.37",
"Syncfusion.Xamarin.SfNumericTextBox": "16.1.0.37",
"Syncfusion.Licensing": "16.2.0.43",
"Syncfusion.Xamarin.DataSource": "16.2.0.42",
"Syncfusion.Xamarin.SfChart": "16.2.0.42",
"Syncfusion.Xamarin.SfDataForm": "16.2.0.42",
"Syncfusion.Xamarin.SfDataGrid": "16.2.0.42",
"Syncfusion.Xamarin.SfListView": "16.2.0.42",
"Syncfusion.Xamarin.SfNumericTextBox": "16.2.0.42",
"Xamarin.Forms": "2.4.0.280"
},
"frameworks": {

Разница между файлами не показана из-за своего большого размера Загрузить разницу

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.UWP/trend.png

Двоичный файл не отображается.

До

Ширина:  |  Высота:  |  Размер: 592 B

После

Ширина:  |  Высота:  |  Размер: 673 B

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.UWP/user.png

Двоичный файл не отображается.

До

Ширина:  |  Высота:  |  Размер: 689 B

После

Ширина:  |  Высота:  |  Размер: 839 B

Просмотреть файл

@ -138,77 +138,62 @@
<HintPath>..\..\packages\SQLitePCLRaw.provider.sqlite3.ios_unified.1.1.2\lib\Xamarin.iOS10\SQLitePCLRaw.provider.sqlite3.dll</HintPath>
<Private>True</Private>
</Reference>
<Reference Include="Syncfusion.Core.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.Core.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.Core.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.Core.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.Core.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.Core.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.Data.Portable, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.Data.Portable.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.Data.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.Data.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.DataSource.Portable, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.DataSource.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.DataSource.Portable.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.DataSource.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.DataSource.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.DataSource.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.GridCommon.Portable, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.GridCommon.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.GridCommon.Portable.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.GridCommon.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.GridCommon.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.GridCommon.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfChart.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfChart.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.Licensing, Version=16.2.0.43, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Licensing.16.2.0.43\lib\Xamarin.iOS10\Syncfusion.Licensing.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfChart.XForms.iOS, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfChart.XForms.iOS.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfChart.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfChart.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataForm.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataForm.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfDataForm.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfChart.XForms.iOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfChart.XForms.iOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataForm.XForms.iOS, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataForm.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfDataForm.XForms.iOS.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfDataForm.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataForm.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfDataForm.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataGrid.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfDataGrid.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfDataForm.XForms.iOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataForm.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfDataForm.XForms.iOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataGrid.XForms.iOS, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfDataGrid.XForms.iOS.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfDataGrid.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfDataGrid.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfListView.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfListView.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfDataGrid.XForms.iOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfDataGrid.XForms.iOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfListView.XForms.iOS, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfListView.XForms.iOS.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfListView.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfListView.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericTextBox.iOS, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfNumericTextBox.iOS.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfListView.XForms.iOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfListView.XForms.iOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericTextBox.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfNumericTextBox.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericTextBox.iOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfNumericTextBox.iOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericTextBox.XForms.iOS, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfNumericTextBox.XForms.iOS.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericTextBox.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfNumericTextBox.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.iOS, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfNumericUpDown.iOS.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericTextBox.XForms.iOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfNumericTextBox.XForms.iOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfNumericUpDown.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericUpDown.iOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfNumericUpDown.iOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.XForms.iOS, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.1.0.37\lib\Xamarin.iOS10\Syncfusion.SfNumericUpDown.XForms.iOS.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericUpDown.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfNumericUpDown.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.XForms.iOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.2.0.42\lib\Xamarin.iOS10\Syncfusion.SfNumericUpDown.XForms.iOS.dll</HintPath>
</Reference>
<Reference Include="System" />
<Reference Include="System.IO.Compression" />
@ -396,7 +381,8 @@
</Compile>
<InterfaceDefinition Include="MainStoryboard.storyboard" />
<InterfaceDefinition Include="Resources\SplashScreen.xib" />
</ItemGroup> <ItemGroup>
</ItemGroup>
<ItemGroup>
<BundleResource Include="Resources\burgericon.png" />
</ItemGroup>
<Import Project="$(MSBuildExtensionsPath)\Xamarin\iOS\Xamarin.iOS.CSharp.targets" />

Просмотреть файл

@ -7,15 +7,16 @@
<package id="SQLitePCLRaw.bundle_green" version="1.1.2" targetFramework="xamarinios10" />
<package id="SQLitePCLRaw.core" version="1.1.2" targetFramework="xamarinios10" />
<package id="SQLitePCLRaw.provider.sqlite3.ios_unified" version="1.1.2" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.Core" version="16.1.0.37" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.DataSource" version="16.1.0.37" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.GridCommon" version="16.1.0.37" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfChart" version="16.1.0.37" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfDataForm" version="16.1.0.37" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfDataGrid" version="16.1.0.37" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfListView" version="16.1.0.37" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfNumericTextBox" version="16.1.0.37" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfNumericUpDown" version="16.1.0.37" targetFramework="xamarinios10" />
<package id="Syncfusion.Licensing" version="16.2.0.43" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.Core" version="16.2.0.42" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.DataSource" version="16.2.0.42" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.GridCommon" version="16.2.0.42" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfChart" version="16.2.0.42" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfDataForm" version="16.2.0.42" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfDataGrid" version="16.2.0.42" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfListView" version="16.2.0.42" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfNumericTextBox" version="16.2.0.42" targetFramework="xamarinios10" />
<package id="Syncfusion.Xamarin.SfNumericUpDown" version="16.2.0.42" targetFramework="xamarinios10" />
<package id="System.AppContext" version="4.1.0" targetFramework="xamarinios10" />
<package id="System.Collections" version="4.0.11" targetFramework="xamarinios10" />
<package id="System.Collections.Concurrent" version="4.0.12" targetFramework="xamarinios10" />

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/.DS_Store поставляемый Normal file

Двоичный файл не отображается.

Просмотреть файл

@ -0,0 +1,53 @@
using AppKit;
using CoreGraphics;
using Foundation;
using Syncfusion.ListView.XForms.MacOS;
using Syncfusion.SfChart.XForms.MacOS;
using Syncfusion.SfDataGrid.XForms.MacOS;
using Xamarin.Forms;
using Xamarin.Forms.Platform.MacOS;
namespace ExpenseAnalysis.MacOS
{
[Register("AppDelegate")]
public class AppDelegate : FormsApplicationDelegate
{
NSWindow window;
public AppDelegate()
{
var style = NSWindowStyle.Closable | NSWindowStyle.Resizable | NSWindowStyle.Titled;
var rect = new CGRect(0, 1000, 200, 200);
window = new NSWindow(rect, style, NSBackingStore.Buffered, false);
rect = window.Screen.Frame;
var width = 850;
var height = 750;
window.SetFrame(new CGRect(rect.Width/2-width/2, rect.Height-height, width, height), true, true);
window.TitleVisibility = NSWindowTitleVisibility.Hidden;
}
public override NSWindow MainWindow
{
get { return window; }
}
public override void DidFinishLaunching(NSNotification notification)
{
Forms.Init();
SfListViewRenderer.Init();
SfChartRenderer.Init();
SfDataGridRenderer.Init();
LoadApplication(new App());
base.DidFinishLaunching(notification);
}
public override void WillTerminate(NSNotification notification)
{
}
}
}

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 7.9 KiB

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 20 KiB

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 711 B

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 1.4 KiB

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 20 KiB

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 58 KiB

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 1.4 KiB

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 3.3 KiB

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 58 KiB

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 174 KiB

Просмотреть файл

@ -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"
}
}

Просмотреть файл

@ -0,0 +1,6 @@
{
"info" : {
"version" : 1,
"author" : "xcode"
}
}

Просмотреть файл

@ -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>

Просмотреть файл

@ -0,0 +1,319 @@
<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<Import Project="..\..\packages\Xamarin.Forms.2.4.0.280\build\netstandard1.0\Xamarin.Forms.props" Condition="Exists('..\..\packages\Xamarin.Forms.2.4.0.280\build\netstandard1.0\Xamarin.Forms.props')" />
<Import Project="..\..\packages\Xamarin.Forms.2.5.0.280555\build\netstandard1.0\Xamarin.Forms.props" Condition="Exists('..\..\packages\Xamarin.Forms.2.5.0.280555\build\netstandard1.0\Xamarin.Forms.props')" />
<PropertyGroup>
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
<Platform Condition=" '$(Platform)' == '' ">x86</Platform>
<ProjectGuid>{AFDD6E9B-C2D8-44E4-A829-17446D9C485F}</ProjectGuid>
<ProjectTypeGuids>{A3F8F2AB-B479-4A4A-A458-A89E7DC349F1};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}</ProjectTypeGuids>
<OutputType>Exe</OutputType>
<RootNamespace>ExpenseAnalysis.MacOS</RootNamespace>
<AssemblyName>ExpenseAnalysis.macOS</AssemblyName>
<TargetFrameworkVersion>v2.0</TargetFrameworkVersion>
<TargetFrameworkIdentifier>Xamarin.Mac</TargetFrameworkIdentifier>
<MonoMacResourcePrefix>Resources</MonoMacResourcePrefix>
<NuGetPackageImportStamp>
</NuGetPackageImportStamp>
</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>
<EnableCodeSigning>false</EnableCodeSigning>
<CodeSigningKey>Mac Developer</CodeSigningKey>
<CreatePackage>false</CreatePackage>
<EnablePackageSigning>false</EnablePackageSigning>
<IncludeMonoRuntime>false</IncludeMonoRuntime>
<UseSGen>true</UseSGen>
<UseRefCounting>true</UseRefCounting>
<HttpClientHandler>HttpClientHandler</HttpClientHandler>
<LinkMode>None</LinkMode>
<XamMacArch>x86_64</XamMacArch>
<PackageSigningKey>3rd Party Mac Developer Installer</PackageSigningKey>
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' ">
<DebugSymbols>true</DebugSymbols>
<DebugType>full</DebugType>
<Optimize>false</Optimize>
<OutputPath>bin\Debug</OutputPath>
<DefineConstants>DEBUG;</DefineConstants>
<ErrorReport>prompt</ErrorReport>
<WarningLevel>4</WarningLevel>
<EnableCodeSigning>false</EnableCodeSigning>
<CodeSigningKey>Mac Developer</CodeSigningKey>
<CreatePackage>false</CreatePackage>
<EnablePackageSigning>false</EnablePackageSigning>
<IncludeMonoRuntime>false</IncludeMonoRuntime>
<UseSGen>true</UseSGen>
<UseRefCounting>true</UseRefCounting>
<HttpClientHandler>HttpClientHandler</HttpClientHandler>
<LinkMode>None</LinkMode>
<XamMacArch>x86_64</XamMacArch>
<PackageSigningKey>3rd Party Mac Developer Installer</PackageSigningKey>
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
<DebugType>
</DebugType>
<Optimize>true</Optimize>
<OutputPath>bin\Release</OutputPath>
<DefineConstants>
</DefineConstants>
<ErrorReport>prompt</ErrorReport>
<WarningLevel>4</WarningLevel>
<EnableCodeSigning>false</EnableCodeSigning>
<CreatePackage>true</CreatePackage>
<EnablePackageSigning>false</EnablePackageSigning>
<IncludeMonoRuntime>true</IncludeMonoRuntime>
<UseSGen>true</UseSGen>
<UseRefCounting>true</UseRefCounting>
<LinkMode>None</LinkMode>
<HttpClientHandler>HttpClientHandler</HttpClientHandler>
<XamMacArch>x86_64</XamMacArch>
<CodeSigningKey>Mac Developer</CodeSigningKey>
<PackageSigningKey>3rd Party Mac Developer Installer</PackageSigningKey>
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|x86' ">
<DebugType>
</DebugType>
<Optimize>true</Optimize>
<OutputPath>bin\Release</OutputPath>
<DefineConstants>
</DefineConstants>
<ErrorReport>prompt</ErrorReport>
<WarningLevel>4</WarningLevel>
<EnableCodeSigning>false</EnableCodeSigning>
<CreatePackage>true</CreatePackage>
<EnablePackageSigning>false</EnablePackageSigning>
<IncludeMonoRuntime>true</IncludeMonoRuntime>
<UseSGen>true</UseSGen>
<UseRefCounting>true</UseRefCounting>
<LinkMode>None</LinkMode>
<HttpClientHandler>HttpClientHandler</HttpClientHandler>
<XamMacArch>x86_64</XamMacArch>
<CodeSigningKey>Mac Developer</CodeSigningKey>
<PackageSigningKey>3rd Party Mac Developer Installer</PackageSigningKey>
</PropertyGroup>
<ItemGroup>
<Reference Include="Syncfusion.Core.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.Core.16.2.0.42\lib\Xamarin.Mac\Syncfusion.Core.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.Core.XForms.macOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.Core.16.2.0.42\lib\Xamarin.Mac\Syncfusion.Core.XForms.macOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.Data.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\Xamarin.Mac\Syncfusion.Data.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.DataSource.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.DataSource.16.2.0.42\lib\netstandard1.0\Syncfusion.DataSource.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.GridCommon.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.GridCommon.16.2.0.42\lib\Xamarin.Mac\Syncfusion.GridCommon.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.Licensing, Version=16.2.0.43, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Licensing.16.2.0.43\lib\Xamarin.Mac\Syncfusion.Licensing.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfChart.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.2.0.42\lib\Xamarin.Mac\Syncfusion.SfChart.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfChart.XForms.macOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.2.0.42\lib\Xamarin.Mac\Syncfusion.SfChart.XForms.macOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataGrid.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\Xamarin.Mac\Syncfusion.SfDataGrid.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataGrid.XForms.macOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\Xamarin.Mac\Syncfusion.SfDataGrid.XForms.macOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfListView.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.2.0.42\lib\Xamarin.Mac\Syncfusion.SfListView.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfListView.XForms.macOS, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.2.0.42\lib\Xamarin.Mac\Syncfusion.SfListView.XForms.macOS.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericTextBox.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.2.0.42\lib\netstandard1.0\Syncfusion.SfNumericTextBox.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.2.0.42\lib\netstandard1.0\Syncfusion.SfNumericUpDown.XForms.dll</HintPath>
</Reference>
<Reference Include="System" />
<Reference Include="System.Core" />
<Reference Include="Xamarin.Forms.Core, Version=2.0.0.0, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Xamarin.Forms.2.4.0.280\lib\Xamarin.Mac\Xamarin.Forms.Core.dll</HintPath>
</Reference>
<Reference Include="Xamarin.Forms.Platform, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Xamarin.Forms.2.4.0.280\lib\Xamarin.Mac\Xamarin.Forms.Platform.dll</HintPath>
</Reference>
<Reference Include="Xamarin.Forms.Platform.macOS, Version=2.0.0.0, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Xamarin.Forms.2.4.0.280\lib\Xamarin.Mac\Xamarin.Forms.Platform.macOS.dll</HintPath>
</Reference>
<Reference Include="Xamarin.Forms.Xaml, Version=2.0.0.0, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Xamarin.Forms.2.4.0.280\lib\Xamarin.Mac\Xamarin.Forms.Xaml.dll</HintPath>
</Reference>
<Reference Include="Xamarin.Mac" />
<Reference Include="SQLitePCLRaw.core">
<HintPath>..\..\packages\SQLitePCLRaw.core.1.1.11\lib\Xamarin.Mac20\SQLitePCLRaw.core.dll</HintPath>
</Reference>
<Reference Include="SQLitePCLRaw.provider.sqlite3">
<HintPath>..\..\packages\SQLitePCLRaw.provider.sqlite3.macos.1.1.11\lib\Xamarin.Mac20\SQLitePCLRaw.provider.sqlite3.dll</HintPath>
</Reference>
<Reference Include="SQLitePCLRaw.provider.e_sqlite3">
<HintPath>..\..\packages\SQLitePCLRaw.provider.e_sqlite3.macos.1.1.11\lib\Xamarin.Mac20\SQLitePCLRaw.provider.e_sqlite3.dll</HintPath>
</Reference>
<Reference Include="SQLitePCLRaw.batteries_green">
<HintPath>..\..\packages\SQLitePCLRaw.bundle_green.1.1.11\lib\Xamarin.Mac20\SQLitePCLRaw.batteries_green.dll</HintPath>
</Reference>
<Reference Include="SQLitePCLRaw.batteries_v2">
<HintPath>..\..\packages\SQLitePCLRaw.bundle_green.1.1.11\lib\Xamarin.Mac20\SQLitePCLRaw.batteries_v2.dll</HintPath>
</Reference>
<Reference Include="SQLite-net">
<HintPath>..\..\packages\sqlite-net-pcl.1.4.118\lib\netstandard1.1\SQLite-net.dll</HintPath>
</Reference>
<Reference Include="System.Net.Http" />
<Reference Include="System.IO.Compression" />
<Reference Include="System.Xml" />
<Reference Include="Syncfusion.Licensing">
<HintPath>..\..\..\..\..\Documents\Syncfusion\16.2.0.39\Xamarin\lib\macOS\Syncfusion.Licensing.dll</HintPath>
</Reference>
</ItemGroup>
<ItemGroup>
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\Contents.json" />
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\AppIcon-128.png" />
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\AppIcon-128%402x.png" />
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\AppIcon-16.png" />
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\AppIcon-16%402x.png" />
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\AppIcon-256.png" />
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\AppIcon-256%402x.png" />
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\AppIcon-32.png" />
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\AppIcon-32%402x.png" />
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\AppIcon-512.png" />
<ImageAsset Include="Assets.xcassets\AppIcon.appiconset\AppIcon-512%402x.png" />
<ImageAsset Include="Assets.xcassets\Contents.json" />
</ItemGroup>
<ItemGroup />
<ItemGroup>
<None Include="app.config" />
<None Include="Info.plist" />
<None Include="Entitlements.plist" />
<None Include="packages.config">
<SubType>Designer</SubType>
</None>
</ItemGroup>
<ItemGroup>
<Compile Include="Main.cs" />
<Compile Include="AppDelegate.cs" />
<Compile Include="FileHelper.cs" />
<Compile Include="ViewController.cs" />
<Compile Include="ViewController.designer.cs">
<DependentUpon>ViewController.cs</DependentUpon>
</Compile>
<Compile Include="Renderer\CustomListViewRenderer.cs" />
<Compile Include="Renderer\CustomMasterDetailRenderer.cs" />
<Compile Include="Renderer\CustomButtonRenderer.cs" />
<Compile Include="Renderer\CustomDatePickerRenderer.cs" />
</ItemGroup>
<ItemGroup>
<InterfaceDefinition Include="Main.storyboard" />
<InterfaceDefinition Include="Resources\LaunchScreen.storyboard" />
<InterfaceDefinition Include="Resources\SplashScreen.xib" />
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\ExpenseAnalysis\ExpenseAnalysis.csproj">
<Project>{B0B25CE3-0BD0-49CC-BCE4-49260106218A}</Project>
<Name>ExpenseAnalysis</Name>
</ProjectReference>
</ItemGroup>
<ItemGroup>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\auto.png">
<Link>Resources\auto.png</Link>
</BundleResource>
<BundleResource Include="Resources\burgericon.png" />
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\charity.png">
<Link>Resources\charity.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\creditcard.png">
<Link>Resources\creditcard.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\date.png">
<Link>Resources\date.png</Link>
</BundleResource>
<BundleResource Include="Resources\Default-Portrait - 768 x 1024.png" />
<BundleResource Include="Resources\Default-Portrait%402x - 1536 x 2048.png" />
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\dollar.png">
<Link>Resources\dollar.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\education.png">
<Link>Resources\education.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\entertainment.png">
<Link>Resources\entertainment.png</Link>
</BundleResource>
<BundleResource Include="Resources\filter.png" />
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\food.png">
<Link>Resources\food.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\gadgets.png">
<Link>Resources\gadgets.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\health.png">
<Link>Resources\health.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\home.png">
<Link>Resources\home.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\housingloan.png">
<Link>Resources\housingloan.png</Link>
</BundleResource>
<BundleResource Include="Resources\Icon-60%402x.png" />
<BundleResource Include="Resources\Icon-60%403x.png" />
<BundleResource Include="Resources\Icon-76.png" />
<BundleResource Include="Resources\Icon-Small%402x.png" />
<BundleResource Include="Resources\Icon-Small%403x.png" />
<BundleResource Include="Resources\Icon-Small-40.png" />
<BundleResource Include="Resources\Icon-Small-40%402x.png" />
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\mobilebill.png">
<Link>Resources\mobilebill.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\pen.png">
<Link>Resources\pen.png</Link>
</BundleResource>
<BundleResource Include="Resources\plus.png" />
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\selectCategory.png">
<Link>Resources\selectCategory.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\shopping.png">
<Link>Resources\shopping.png</Link>
</BundleResource>
<BundleResource Include="Resources\Splash.png" />
<BundleResource Include="Resources\Splash%402x.png" />
<BundleResource Include="Resources\Splash%403x.png" />
<BundleResource Include="Resources\Splash~ipad.png" />
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\userImage.png">
<Link>Resources\userImage.png</Link>
</BundleResource>
<BundleResource Include="..\ExpenseAnalysis.Droid\Resources\drawable\utilities.png">
<Link>Resources\utilities.png</Link>
</BundleResource>
<BundleResource Include="Resources\tick.png" />
<BundleResource Include="Resources\user.png" />
<BundleResource Include="Resources\category.png" />
<BundleResource Include="Resources\message.png" />
<BundleResource Include="Resources\trend.png" />
</ItemGroup>
<Import Project="$(MSBuildExtensionsPath)\Xamarin\Mac\Xamarin.Mac.CSharp.targets" />
<Import Project="..\..\packages\SQLitePCLRaw.lib.e_sqlite3.osx.1.1.11\build\Xamarin.Mac20\SQLitePCLRaw.lib.e_sqlite3.osx.targets" Condition="Exists('..\..\packages\SQLitePCLRaw.lib.e_sqlite3.osx.1.1.11\build\Xamarin.Mac20\SQLitePCLRaw.lib.e_sqlite3.osx.targets')" />
<Import Project="..\..\packages\NETStandard.Library.2.0.3\build\netstandard2.0\NETStandard.Library.targets" Condition="Exists('..\..\packages\NETStandard.Library.2.0.3\build\netstandard2.0\NETStandard.Library.targets')" />
<Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild">
<PropertyGroup>
<ErrorText>This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them. For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}.</ErrorText>
</PropertyGroup>
<Error Condition="!Exists('..\..\packages\Xamarin.Forms.2.4.0.280\build\netstandard1.0\Xamarin.Forms.props')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\Xamarin.Forms.2.4.0.280\build\netstandard1.0\Xamarin.Forms.props'))" />
<Error Condition="!Exists('..\..\packages\Xamarin.Forms.2.4.0.280\build\netstandard1.0\Xamarin.Forms.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\Xamarin.Forms.2.4.0.280\build\netstandard1.0\Xamarin.Forms.targets'))" />
</Target>
<Import Project="..\..\packages\Xamarin.Forms.2.4.0.280\build\netstandard1.0\Xamarin.Forms.targets" Condition="Exists('..\..\packages\Xamarin.Forms.2.4.0.280\build\netstandard1.0\Xamarin.Forms.targets')" />
</Project>

Просмотреть файл

@ -0,0 +1,18 @@
using System;
using System.IO;
using SQLite;
[assembly: Xamarin.Forms.Dependency(typeof(ExpenseAnalysis.MacOS.FileHelper))]
namespace ExpenseAnalysis.MacOS
{
public class FileHelper : IFileHelper
{
public SQLiteConnection DbConnection()
{
var dbName = "db_sqlnet.db";
var libraryFolder = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Personal), "Library");
var databasePath = Path.Combine(libraryFolder, dbName);
return new SQLiteConnection(databasePath);
}
}
}

Просмотреть файл

@ -0,0 +1,32 @@
<?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>ExpenseAnalysis.macOS</string>
<key>CFBundleIdentifier</key>
<string>com.syncfusion.ExpenseAnalysis-macOS</string>
<key>CFBundleShortVersionString</key>
<string>1.0</string>
<key>CFBundleVersion</key>
<string>1</string>
<key>LSMinimumSystemVersion</key>
<string>10.11</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>${AuthorCopyright:HtmlEncode}</string>
<key>NSPrincipalClass</key>
<string>NSApplication</string>
<key>NSMainStoryboardFile</key>
<string>Main</string>
<key>XSAppIconAssets</key>
<string>Assets.xcassets/AppIcon.appiconset</string>
</dict>
</plist>

Просмотреть файл

@ -0,0 +1,17 @@
using AppKit;
namespace ExpenseAnalysis.MacOS
{
static class MainClass
{
static void Main(string[] args)
{
NSApplication.Init();
NSApplication.SharedApplication.Delegate = new AppDelegate();
NSApplication.Main(args);
Syncfusion.Licensing.SyncfusionLicenseProvider.RegisterLicense("");
}
}
}

Просмотреть файл

@ -0,0 +1,686 @@
<?xml version="1.0" encoding="UTF-8"?>
<document type="com.apple.InterfaceBuilder3.Cocoa.Storyboard.XIB" version="3.0" toolsVersion="14109" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES">
<dependencies>
<deployment identifier="macosx"/>
<plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="14109"/>
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
</dependencies>
<scenes>
<!--Application-->
<scene sceneID="JPo-4y-FX3">
<objects>
<application id="hnw-xV-0zn" sceneMemberID="viewController">
<menu key="mainMenu" title="Main Menu" systemMenu="main" id="AYu-sK-qS6">
<items>
<menuItem title="ExpenseAnalysis.macOS" id="1Xt-HY-uBw">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="ExpenseAnalysis.macOS" systemMenu="apple" id="uQy-DD-JDr">
<items>
<menuItem title="About ExpenseAnalysis.macOS" id="5kV-Vb-QxS">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="orderFrontStandardAboutPanel:" target="Ady-hI-5gd" id="Exp-CZ-Vem"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="VOq-y0-SEH"/>
<menuItem title="Preferences…" keyEquivalent="," id="BOF-NM-1cW"/>
<menuItem isSeparatorItem="YES" id="wFC-TO-SCJ"/>
<menuItem title="Services" id="NMo-om-nkz">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Services" systemMenu="services" id="hz9-B4-Xy5"/>
</menuItem>
<menuItem isSeparatorItem="YES" id="4je-JR-u6R"/>
<menuItem title="Hide ExpenseAnalysis.macOS" keyEquivalent="h" id="Olw-nP-bQN">
<connections>
<action selector="hide:" target="Ady-hI-5gd" id="PnN-Uc-m68"/>
</connections>
</menuItem>
<menuItem title="Hide Others" keyEquivalent="h" id="Vdr-fp-XzO">
<modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
<connections>
<action selector="hideOtherApplications:" target="Ady-hI-5gd" id="VT4-aY-XCT"/>
</connections>
</menuItem>
<menuItem title="Show All" id="Kd2-mp-pUS">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="unhideAllApplications:" target="Ady-hI-5gd" id="Dhg-Le-xox"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="kCx-OE-vgT"/>
<menuItem title="Quit ExpenseAnalysis.macOS" keyEquivalent="q" id="4sb-4s-VLi">
<connections>
<action selector="terminate:" target="Ady-hI-5gd" id="Te7-pn-YzF"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="File" id="dMs-cI-mzQ">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="File" id="bib-Uj-vzu">
<items>
<menuItem title="New" keyEquivalent="n" id="Was-JA-tGl">
<connections>
<action selector="newDocument:" target="Ady-hI-5gd" id="4Si-XN-c54"/>
</connections>
</menuItem>
<menuItem title="Open…" keyEquivalent="o" id="IAo-SY-fd9">
<connections>
<action selector="openDocument:" target="Ady-hI-5gd" id="bVn-NM-KNZ"/>
</connections>
</menuItem>
<menuItem title="Open Recent" id="tXI-mr-wws">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Open Recent" systemMenu="recentDocuments" id="oas-Oc-fiZ">
<items>
<menuItem title="Clear Menu" id="vNY-rz-j42">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="clearRecentDocuments:" target="Ady-hI-5gd" id="Daa-9d-B3U"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem isSeparatorItem="YES" id="m54-Is-iLE"/>
<menuItem title="Close" keyEquivalent="w" id="DVo-aG-piG">
<connections>
<action selector="performClose:" target="Ady-hI-5gd" id="HmO-Ls-i7Q"/>
</connections>
</menuItem>
<menuItem title="Save…" keyEquivalent="s" id="pxx-59-PXV">
<connections>
<action selector="saveDocument:" target="Ady-hI-5gd" id="teZ-XB-qJY"/>
</connections>
</menuItem>
<menuItem title="Save As…" keyEquivalent="S" id="Bw7-FT-i3A">
<connections>
<action selector="saveDocumentAs:" target="Ady-hI-5gd" id="mDf-zr-I0C"/>
</connections>
</menuItem>
<menuItem title="Revert to Saved" id="KaW-ft-85H">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="revertDocumentToSaved:" target="Ady-hI-5gd" id="iJ3-Pv-kwq"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="aJh-i4-bef"/>
<menuItem title="Page Setup…" keyEquivalent="P" id="qIS-W8-SiK">
<modifierMask key="keyEquivalentModifierMask" shift="YES" command="YES"/>
<connections>
<action selector="runPageLayout:" target="Ady-hI-5gd" id="Din-rz-gC5"/>
</connections>
</menuItem>
<menuItem title="Print…" keyEquivalent="p" id="aTl-1u-JFS">
<connections>
<action selector="print:" target="Ady-hI-5gd" id="qaZ-4w-aoO"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Edit" id="5QF-Oa-p0T">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Edit" id="W48-6f-4Dl">
<items>
<menuItem title="Undo" keyEquivalent="z" id="dRJ-4n-Yzg">
<connections>
<action selector="undo:" target="Ady-hI-5gd" id="M6e-cu-g7V"/>
</connections>
</menuItem>
<menuItem title="Redo" keyEquivalent="Z" id="6dh-zS-Vam">
<connections>
<action selector="redo:" target="Ady-hI-5gd" id="oIA-Rs-6OD"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="WRV-NI-Exz"/>
<menuItem title="Cut" keyEquivalent="x" id="uRl-iY-unG">
<connections>
<action selector="cut:" target="Ady-hI-5gd" id="YJe-68-I9s"/>
</connections>
</menuItem>
<menuItem title="Copy" keyEquivalent="c" id="x3v-GG-iWU">
<connections>
<action selector="copy:" target="Ady-hI-5gd" id="G1f-GL-Joy"/>
</connections>
</menuItem>
<menuItem title="Paste" keyEquivalent="v" id="gVA-U4-sdL">
<connections>
<action selector="paste:" target="Ady-hI-5gd" id="UvS-8e-Qdg"/>
</connections>
</menuItem>
<menuItem title="Paste and Match Style" keyEquivalent="V" id="WeT-3V-zwk">
<modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
<connections>
<action selector="pasteAsPlainText:" target="Ady-hI-5gd" id="cEh-KX-wJQ"/>
</connections>
</menuItem>
<menuItem title="Delete" id="pa3-QI-u2k">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="delete:" target="Ady-hI-5gd" id="0Mk-Ml-PaM"/>
</connections>
</menuItem>
<menuItem title="Select All" keyEquivalent="a" id="Ruw-6m-B2m">
<connections>
<action selector="selectAll:" target="Ady-hI-5gd" id="VNm-Mi-diN"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="uyl-h8-XO2"/>
<menuItem title="Find" id="4EN-yA-p0u">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Find" id="1b7-l0-nxx">
<items>
<menuItem title="Find…" tag="1" keyEquivalent="f" id="Xz5-n4-O0W">
<connections>
<action selector="performFindPanelAction:" target="Ady-hI-5gd" id="cD7-Qs-BN4"/>
</connections>
</menuItem>
<menuItem title="Find and Replace…" tag="12" keyEquivalent="f" id="YEy-JH-Tfz">
<modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
<connections>
<action selector="performFindPanelAction:" target="Ady-hI-5gd" id="WD3-Gg-5AJ"/>
</connections>
</menuItem>
<menuItem title="Find Next" tag="2" keyEquivalent="g" id="q09-fT-Sye">
<connections>
<action selector="performFindPanelAction:" target="Ady-hI-5gd" id="NDo-RZ-v9R"/>
</connections>
</menuItem>
<menuItem title="Find Previous" tag="3" keyEquivalent="G" id="OwM-mh-QMV">
<connections>
<action selector="performFindPanelAction:" target="Ady-hI-5gd" id="HOh-sY-3ay"/>
</connections>
</menuItem>
<menuItem title="Use Selection for Find" tag="7" keyEquivalent="e" id="buJ-ug-pKt">
<connections>
<action selector="performFindPanelAction:" target="Ady-hI-5gd" id="U76-nv-p5D"/>
</connections>
</menuItem>
<menuItem title="Jump to Selection" keyEquivalent="j" id="S0p-oC-mLd">
<connections>
<action selector="centerSelectionInVisibleArea:" target="Ady-hI-5gd" id="IOG-6D-g5B"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Spelling and Grammar" id="Dv1-io-Yv7">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Spelling" id="3IN-sU-3Bg">
<items>
<menuItem title="Show Spelling and Grammar" keyEquivalent=":" id="HFo-cy-zxI">
<connections>
<action selector="showGuessPanel:" target="Ady-hI-5gd" id="vFj-Ks-hy3"/>
</connections>
</menuItem>
<menuItem title="Check Document Now" keyEquivalent=";" id="hz2-CU-CR7">
<connections>
<action selector="checkSpelling:" target="Ady-hI-5gd" id="fz7-VC-reM"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="bNw-od-mp5"/>
<menuItem title="Check Spelling While Typing" id="rbD-Rh-wIN">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleContinuousSpellChecking:" target="Ady-hI-5gd" id="7w6-Qz-0kB"/>
</connections>
</menuItem>
<menuItem title="Check Grammar With Spelling" id="mK6-2p-4JG">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleGrammarChecking:" target="Ady-hI-5gd" id="muD-Qn-j4w"/>
</connections>
</menuItem>
<menuItem title="Correct Spelling Automatically" id="78Y-hA-62v">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleAutomaticSpellingCorrection:" target="Ady-hI-5gd" id="2lM-Qi-WAP"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Substitutions" id="9ic-FL-obx">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Substitutions" id="FeM-D8-WVr">
<items>
<menuItem title="Show Substitutions" id="z6F-FW-3nz">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="orderFrontSubstitutionsPanel:" target="Ady-hI-5gd" id="oku-mr-iSq"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="gPx-C9-uUO"/>
<menuItem title="Smart Copy/Paste" id="9yt-4B-nSM">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleSmartInsertDelete:" target="Ady-hI-5gd" id="3IJ-Se-DZD"/>
</connections>
</menuItem>
<menuItem title="Smart Quotes" id="hQb-2v-fYv">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleAutomaticQuoteSubstitution:" target="Ady-hI-5gd" id="ptq-xd-QOA"/>
</connections>
</menuItem>
<menuItem title="Smart Dashes" id="rgM-f4-ycn">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleAutomaticDashSubstitution:" target="Ady-hI-5gd" id="oCt-pO-9gS"/>
</connections>
</menuItem>
<menuItem title="Smart Links" id="cwL-P1-jid">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleAutomaticLinkDetection:" target="Ady-hI-5gd" id="Gip-E3-Fov"/>
</connections>
</menuItem>
<menuItem title="Data Detectors" id="tRr-pd-1PS">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleAutomaticDataDetection:" target="Ady-hI-5gd" id="R1I-Nq-Kbl"/>
</connections>
</menuItem>
<menuItem title="Text Replacement" id="HFQ-gK-NFA">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleAutomaticTextReplacement:" target="Ady-hI-5gd" id="DvP-Fe-Py6"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Transformations" id="2oI-Rn-ZJC">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Transformations" id="c8a-y6-VQd">
<items>
<menuItem title="Make Upper Case" id="vmV-6d-7jI">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="uppercaseWord:" target="Ady-hI-5gd" id="sPh-Tk-edu"/>
</connections>
</menuItem>
<menuItem title="Make Lower Case" id="d9M-CD-aMd">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="lowercaseWord:" target="Ady-hI-5gd" id="iUZ-b5-hil"/>
</connections>
</menuItem>
<menuItem title="Capitalize" id="UEZ-Bs-lqG">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="capitalizeWord:" target="Ady-hI-5gd" id="26H-TL-nsh"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Speech" id="xrE-MZ-jX0">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Speech" id="3rS-ZA-NoH">
<items>
<menuItem title="Start Speaking" id="Ynk-f8-cLZ">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="startSpeaking:" target="Ady-hI-5gd" id="654-Ng-kyl"/>
</connections>
</menuItem>
<menuItem title="Stop Speaking" id="Oyz-dy-DGm">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="stopSpeaking:" target="Ady-hI-5gd" id="dX8-6p-jy9"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Format" id="jxT-CU-nIS">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Format" id="GEO-Iw-cKr">
<items>
<menuItem title="Font" id="Gi5-1S-RQB">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Font" systemMenu="font" id="aXa-aM-Jaq">
<items>
<menuItem title="Show Fonts" keyEquivalent="t" id="Q5e-8K-NDq"/>
<menuItem title="Bold" tag="2" keyEquivalent="b" id="GB9-OM-e27"/>
<menuItem title="Italic" tag="1" keyEquivalent="i" id="Vjx-xi-njq"/>
<menuItem title="Underline" keyEquivalent="u" id="WRG-CD-K1S">
<connections>
<action selector="underline:" target="Ady-hI-5gd" id="FYS-2b-JAY"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="5gT-KC-WSO"/>
<menuItem title="Bigger" tag="3" keyEquivalent="+" id="Ptp-SP-VEL"/>
<menuItem title="Smaller" tag="4" keyEquivalent="-" id="i1d-Er-qST"/>
<menuItem isSeparatorItem="YES" id="kx3-Dk-x3B"/>
<menuItem title="Kern" id="jBQ-r6-VK2">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Kern" id="tlD-Oa-oAM">
<items>
<menuItem title="Use Default" id="GUa-eO-cwY">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="useStandardKerning:" target="Ady-hI-5gd" id="6dk-9l-Ckg"/>
</connections>
</menuItem>
<menuItem title="Use None" id="cDB-IK-hbR">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="turnOffKerning:" target="Ady-hI-5gd" id="U8a-gz-Maa"/>
</connections>
</menuItem>
<menuItem title="Tighten" id="46P-cB-AYj">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="tightenKerning:" target="Ady-hI-5gd" id="hr7-Nz-8ro"/>
</connections>
</menuItem>
<menuItem title="Loosen" id="ogc-rX-tC1">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="loosenKerning:" target="Ady-hI-5gd" id="8i4-f9-FKE"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Ligatures" id="o6e-r0-MWq">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Ligatures" id="w0m-vy-SC9">
<items>
<menuItem title="Use Default" id="agt-UL-0e3">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="useStandardLigatures:" target="Ady-hI-5gd" id="7uR-wd-Dx6"/>
</connections>
</menuItem>
<menuItem title="Use None" id="J7y-lM-qPV">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="turnOffLigatures:" target="Ady-hI-5gd" id="iX2-gA-Ilz"/>
</connections>
</menuItem>
<menuItem title="Use All" id="xQD-1f-W4t">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="useAllLigatures:" target="Ady-hI-5gd" id="KcB-kA-TuK"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Baseline" id="OaQ-X3-Vso">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Baseline" id="ijk-EB-dga">
<items>
<menuItem title="Use Default" id="3Om-Ey-2VK">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="unscript:" target="Ady-hI-5gd" id="0vZ-95-Ywn"/>
</connections>
</menuItem>
<menuItem title="Superscript" id="Rqc-34-cIF">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="superscript:" target="Ady-hI-5gd" id="3qV-fo-wpU"/>
</connections>
</menuItem>
<menuItem title="Subscript" id="I0S-gh-46l">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="subscript:" target="Ady-hI-5gd" id="Q6W-4W-IGz"/>
</connections>
</menuItem>
<menuItem title="Raise" id="2h7-ER-AoG">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="raiseBaseline:" target="Ady-hI-5gd" id="4sk-31-7Q9"/>
</connections>
</menuItem>
<menuItem title="Lower" id="1tx-W0-xDw">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="lowerBaseline:" target="Ady-hI-5gd" id="OF1-bc-KW4"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem isSeparatorItem="YES" id="Ndw-q3-faq"/>
<menuItem title="Show Colors" keyEquivalent="C" id="bgn-CT-cEk">
<connections>
<action selector="orderFrontColorPanel:" target="Ady-hI-5gd" id="mSX-Xz-DV3"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="iMs-zA-UFJ"/>
<menuItem title="Copy Style" keyEquivalent="c" id="5Vv-lz-BsD">
<modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
<connections>
<action selector="copyFont:" target="Ady-hI-5gd" id="GJO-xA-L4q"/>
</connections>
</menuItem>
<menuItem title="Paste Style" keyEquivalent="v" id="vKC-jM-MkH">
<modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
<connections>
<action selector="pasteFont:" target="Ady-hI-5gd" id="JfD-CL-leO"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Text" id="Fal-I4-PZk">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Text" id="d9c-me-L2H">
<items>
<menuItem title="Align Left" keyEquivalent="{" id="ZM1-6Q-yy1">
<connections>
<action selector="alignLeft:" target="Ady-hI-5gd" id="zUv-R1-uAa"/>
</connections>
</menuItem>
<menuItem title="Center" keyEquivalent="|" id="VIY-Ag-zcb">
<connections>
<action selector="alignCenter:" target="Ady-hI-5gd" id="spX-mk-kcS"/>
</connections>
</menuItem>
<menuItem title="Justify" id="J5U-5w-g23">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="alignJustified:" target="Ady-hI-5gd" id="ljL-7U-jND"/>
</connections>
</menuItem>
<menuItem title="Align Right" keyEquivalent="}" id="wb2-vD-lq4">
<connections>
<action selector="alignRight:" target="Ady-hI-5gd" id="r48-bG-YeY"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="4s2-GY-VfK"/>
<menuItem title="Writing Direction" id="H1b-Si-o9J">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Writing Direction" id="8mr-sm-Yjd">
<items>
<menuItem title="Paragraph" enabled="NO" id="ZvO-Gk-QUH">
<modifierMask key="keyEquivalentModifierMask"/>
</menuItem>
<menuItem id="YGs-j5-SAR">
<string key="title"> Default</string>
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="makeBaseWritingDirectionNatural:" target="Ady-hI-5gd" id="qtV-5e-UBP"/>
</connections>
</menuItem>
<menuItem id="Lbh-J2-qVU">
<string key="title"> Left to Right</string>
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="makeBaseWritingDirectionLeftToRight:" target="Ady-hI-5gd" id="S0X-9S-QSf"/>
</connections>
</menuItem>
<menuItem id="jFq-tB-4Kx">
<string key="title"> Right to Left</string>
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="makeBaseWritingDirectionRightToLeft:" target="Ady-hI-5gd" id="5fk-qB-AqJ"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="swp-gr-a21"/>
<menuItem title="Selection" enabled="NO" id="cqv-fj-IhA">
<modifierMask key="keyEquivalentModifierMask"/>
</menuItem>
<menuItem id="Nop-cj-93Q">
<string key="title"> Default</string>
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="makeTextWritingDirectionNatural:" target="Ady-hI-5gd" id="lPI-Se-ZHp"/>
</connections>
</menuItem>
<menuItem id="BgM-ve-c93">
<string key="title"> Left to Right</string>
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="makeTextWritingDirectionLeftToRight:" target="Ady-hI-5gd" id="caW-Bv-w94"/>
</connections>
</menuItem>
<menuItem id="RB4-Sm-HuC">
<string key="title"> Right to Left</string>
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="makeTextWritingDirectionRightToLeft:" target="Ady-hI-5gd" id="EXD-6r-ZUu"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem isSeparatorItem="YES" id="fKy-g9-1gm"/>
<menuItem title="Show Ruler" id="vLm-3I-IUL">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="toggleRuler:" target="Ady-hI-5gd" id="FOx-HJ-KwY"/>
</connections>
</menuItem>
<menuItem title="Copy Ruler" keyEquivalent="c" id="MkV-Pr-PK5">
<modifierMask key="keyEquivalentModifierMask" control="YES" command="YES"/>
<connections>
<action selector="copyRuler:" target="Ady-hI-5gd" id="71i-fW-3W2"/>
</connections>
</menuItem>
<menuItem title="Paste Ruler" keyEquivalent="v" id="LVM-kO-fVI">
<modifierMask key="keyEquivalentModifierMask" control="YES" command="YES"/>
<connections>
<action selector="pasteRuler:" target="Ady-hI-5gd" id="cSh-wd-qM2"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="View" id="H8h-7b-M4v">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="View" id="HyV-fh-RgO">
<items>
<menuItem title="Show Toolbar" keyEquivalent="t" id="snW-S8-Cw5">
<modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
<connections>
<action selector="toggleToolbarShown:" target="Ady-hI-5gd" id="BXY-wc-z0C"/>
</connections>
</menuItem>
<menuItem title="Customize Toolbar…" id="1UK-8n-QPP">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="runToolbarCustomizationPalette:" target="Ady-hI-5gd" id="pQI-g3-MTW"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Window" id="aUF-d1-5bR">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Window" systemMenu="window" id="Td7-aD-5lo">
<items>
<menuItem title="Minimize" keyEquivalent="m" id="OY7-WF-poV">
<connections>
<action selector="performMiniaturize:" target="Ady-hI-5gd" id="VwT-WD-YPe"/>
</connections>
</menuItem>
<menuItem title="Zoom" id="R4o-n2-Eq4">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="performZoom:" target="Ady-hI-5gd" id="DIl-cC-cCs"/>
</connections>
</menuItem>
<menuItem isSeparatorItem="YES" id="eu3-7i-yIM"/>
<menuItem title="Bring All to Front" id="LE2-aR-0XJ">
<modifierMask key="keyEquivalentModifierMask"/>
<connections>
<action selector="arrangeInFront:" target="Ady-hI-5gd" id="DRN-fu-gQh"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
<menuItem title="Help" id="wpr-3q-Mcd">
<modifierMask key="keyEquivalentModifierMask"/>
<menu key="submenu" title="Help" systemMenu="help" id="F2S-fz-NVQ">
<items>
<menuItem title="ExpenseAnalysis.macOS Help" keyEquivalent="?" id="FKE-Sm-Kum">
<connections>
<action selector="showHelp:" target="Ady-hI-5gd" id="y7X-2Q-9no"/>
</connections>
</menuItem>
</items>
</menu>
</menuItem>
</items>
</menu>
<connections>
<outlet property="delegate" destination="Voe-Tx-rLC" id="PrD-fu-P6m"/>
</connections>
</application>
<customObject id="Voe-Tx-rLC" customClass="AppDelegate"/>
<customObject id="Ady-hI-5gd" userLabel="First Responder" customClass="NSResponder" sceneMemberID="firstResponder"/>
</objects>
<point key="canvasLocation" x="75" y="0.0"/>
</scene>
<!--Window Controller-->
<scene sceneID="R2V-B0-nI4">
<objects>
<windowController id="B8D-0N-5wS" sceneMemberID="viewController">
<window key="window" title="Window" allowsToolTipsWhenApplicationIsInactive="NO" autorecalculatesKeyViewLoop="NO" oneShot="NO" releasedWhenClosed="NO" showsToolbarButton="NO" visibleAtLaunch="NO" animationBehavior="default" id="IQv-IB-iLA">
<windowStyleMask key="styleMask" titled="YES" closable="YES" miniaturizable="YES" resizable="YES"/>
<windowPositionMask key="initialPositionMask" leftStrut="YES" rightStrut="YES" topStrut="YES" bottomStrut="YES"/>
<rect key="contentRect" x="196" y="240" width="480" height="270"/>
<rect key="screenRect" x="0.0" y="0.0" width="1680" height="1027"/>
<connections>
<outlet property="delegate" destination="B8D-0N-5wS" id="FhL-m7-uEE"/>
</connections>
</window>
<connections>
<segue destination="XfG-lQ-9wD" kind="relationship" relationship="window.shadowedContentViewController" id="cq2-FE-JQM"/>
</connections>
</windowController>
<customObject id="Oky-zY-oP4" userLabel="First Responder" customClass="NSResponder" sceneMemberID="firstResponder"/>
</objects>
<point key="canvasLocation" x="75" y="250"/>
</scene>
<!--View Controller-->
<scene sceneID="hIz-AP-VOD">
<objects>
<viewController id="XfG-lQ-9wD" customClass="ViewController" sceneMemberID="viewController">
<view key="view" wantsLayer="YES" id="m2S-Jp-Qdl">
<rect key="frame" x="0.0" y="0.0" width="480" height="270"/>
<autoresizingMask key="autoresizingMask"/>
</view>
</viewController>
<customObject id="rPt-NT-nkU" userLabel="First Responder" customClass="NSResponder" sceneMemberID="firstResponder"/>
</objects>
<point key="canvasLocation" x="75" y="655"/>
</scene>
</scenes>
</document>

Просмотреть файл

@ -0,0 +1,10 @@
using System;
namespace ExpenseAnalysis.MacOS
{
public class NavigationRenderer
{
public NavigationRenderer()
{
}
}
}

Просмотреть файл

@ -0,0 +1,21 @@
using System;
using AppKit;
using CoreGraphics;
using ExpenseAnalysis.MacOS.Renderer;
using Xamarin.Forms;
using Xamarin.Forms.Platform.MacOS;
[assembly: ExportRenderer(typeof(Button), typeof(CustomButtonRenderer))]
namespace ExpenseAnalysis.MacOS.Renderer
{
public class CustomButtonRenderer : ButtonRenderer
{
protected override void OnElementChanged(ElementChangedEventArgs<Button> e)
{
base.OnElementChanged(e);
if (Control != null)
Control.Bordered = false;
}
}
}

Просмотреть файл

@ -0,0 +1,22 @@
using System;
using AppKit;
using CoreGraphics;
using ExpenseAnalysis.MacOS.Renderer;
using Xamarin.Forms;
using Xamarin.Forms.Platform.MacOS;
[assembly: ExportRenderer(typeof(DatePicker), typeof(CustomDatePickerRenderer))]
namespace ExpenseAnalysis.MacOS.Renderer
{
public class CustomDatePickerRenderer : DatePickerRenderer
{
protected override void OnElementChanged(ElementChangedEventArgs<DatePicker> e)
{
base.OnElementChanged(e);
if (Control != null)
Control.Alignment = NSTextAlignment.Right;
Control.DatePickerStyle = NSDatePickerStyle.TextFieldAndStepper;
}
}
}

Просмотреть файл

@ -0,0 +1,21 @@
using AppKit;
using ExpenseAnalysis.MacOS.Renderer;
using Xamarin.Forms;
using Xamarin.Forms.Platform.MacOS;
[assembly: ExportRenderer(typeof(ListView), typeof(CustomListViewRenderer))]
namespace ExpenseAnalysis.MacOS.Renderer
{
public class CustomListViewRenderer : ListViewRenderer
{
protected override void OnElementChanged(ElementChangedEventArgs<ListView> e)
{
base.OnElementChanged(e);
if (Control != null && Control is NSScrollView scrollView)
{
scrollView.HasVerticalScroller = false;
}
}
}
}

Просмотреть файл

@ -0,0 +1,20 @@
using System;
using AppKit;
using CoreGraphics;
using ExpenseAnalysis.MacOS.Renderer;
using Xamarin.Forms;
using Xamarin.Forms.Platform.MacOS;
[assembly: ExportRenderer(typeof(MasterDetailPage), typeof(CustomMasterDetailPageRenderer))]
namespace ExpenseAnalysis.MacOS.Renderer
{
public class CustomMasterDetailPageRenderer : MasterDetailPageRenderer
{
protected override void OnElementChanged(VisualElementChangedEventArgs e)
{
LayoutParams p = (LayoutParams)child.LayoutParameters;
p.Width = page.DrawerWidth;
base.OnElementChanged(e);
}
}
}

Просмотреть файл

@ -0,0 +1,13 @@
using System;
using ExpenseAnalysis.MacOS.Renderer;
using Xamarin.Forms;
using Xamarin.Forms.Platform.MacOS;
[assembly: ExportRenderer(typeof(MasterDetailPage), typeof(CustomMasterDetailRenderer))]
namespace ExpenseAnalysis.MacOS.Renderer
{
public class CustomMasterDetailRenderer : MasterDetailPageRenderer
{
protected override double MasterWidthPercentage => 0.2;
}
}

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/.DS_Store поставляемый Normal file

Двоичный файл не отображается.

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 88 KiB

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 221 KiB

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Icon-60@2x.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 11 KiB

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Icon-60@3x.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 3.4 KiB

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Icon-76.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 1.5 KiB

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Icon-Small-40.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 854 B

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 1.7 KiB

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Icon-Small@2x.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 1.3 KiB

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Icon-Small@3x.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 1.8 KiB

Просмотреть файл

@ -0,0 +1,77 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="11762" systemVersion="16C68" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES" colorMatched="YES" initialViewController="X5k-f2-b5h">
<device id="retina4_0" orientation="portrait">
<adaptation id="fullscreen"/>
</device>
<dependencies>
<deployment identifier="iOS"/>
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="11757"/>
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
</dependencies>
<scenes>
<!--View Controller-->
<scene sceneID="gAE-YM-kbH">
<objects>
<viewController id="X5k-f2-b5h" sceneMemberID="viewController">
<layoutGuides>
<viewControllerLayoutGuide type="top" id="Y8P-hJ-Z43"/>
<viewControllerLayoutGuide type="bottom" id="9ZL-r4-8FZ"/>
</layoutGuides>
<view key="view" contentMode="scaleToFill" id="yd7-JS-zBw">
<rect key="frame" x="0.0" y="0.0" width="600" height="600"/>
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
<subviews>
<imageView userInteractionEnabled="NO" contentMode="scaleToFill" misplaced="YES" image="Default-Portrait - 768 x 1024" translatesAutoresizingMaskIntoConstraints="NO" id="23">
<rect key="frame" x="0.0" y="-1" width="600" height="602"/>
<rect key="contentStretch" x="0.0" y="0.0" width="0.0" height="0.0"/>
</imageView>
</subviews>
<color key="backgroundColor" customColorSpace="sRGB" colorSpace="calibratedWhite" white="1" alpha="1"/>
<constraints>
<constraint firstItem="23" firstAttribute="centerY" secondItem="yd7-JS-zBw" secondAttribute="centerY" priority="1" id="39"/>
<constraint firstItem="23" firstAttribute="centerX" secondItem="yd7-JS-zBw" secondAttribute="centerX" priority="1" id="41"/>
</constraints>
<color key="tintColor" colorSpace="calibratedWhite" white="1" alpha="1"/>
</view>
</viewController>
<placeholder placeholderIdentifier="IBFirstResponder" id="XAI-xm-WK6" userLabel="First Responder" sceneMemberID="firstResponder"/>
</objects>
<point key="canvasLocation" x="348.75" y="338.0282"/>
</scene>
</scenes>
<resources>
<image name="Default-Portrait - 768 x 1024.png" width="768" height="1024"/>
<image name="Icon-60.png" width="60.3333321" height="60.3333321"/>
<image name="Icon-76.png" width="73" height="73"/>
<image name="Icon-Small-40.png" width="30" height="30"/>
<image name="Icon-Small.png" width="29.333334" height="29.333334"/>
<image name="Default-Portrait.png" width="768" height="1024"/>
<image name="auto.png" width="256" height="256"/>
<image name="category.png" width="256" height="256"/>
<image name="charity.png" width="256" height="256"/>
<image name="creditcard.png" width="128" height="128"/>
<image name="education.png" width="256" height="256"/>
<image name="entertainment.png" width="256" height="256"/>
<image name="food.png" width="256" height="256"/>
<image name="gadgets.png" width="128" height="128"/>
<image name="health.png" width="256" height="256"/>
<image name="home.png" width="256" height="256"/>
<image name="housingloan.png" width="128" height="128"/>
<image name="message.png" width="256" height="256"/>
<image name="mobilebill.png" width="128" height="128"/>
<image name="shopping.png" width="256" height="256"/>
<image name="trend.png" width="256" height="256"/>
<image name="user.png" width="256" height="256"/>
<image name="utilities.png" width="256" height="256"/>
<image name="plus.png" width="32" height="32"/>
<image name="userImage.png" width="195" height="195"/>
<image name="filter.png" width="32" height="32"/>
<image name="date.png" width="128" height="128"/>
<image name="dollar.png" width="128" height="128"/>
<image name="pen.png" width="128" height="128"/>
<image name="selectCategory.png" width="128" height="128"/>
<image name="Default-Portrait - 768 x 1024" width="768" height="1024"/>
<image name="burgericon.png" width="22" height="22"/>
</resources>
<color key="tintColor" red="1" green="1" blue="1" alpha="1" colorSpace="calibratedRGB"/>
</document>

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Splash.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 33 KiB

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Splash@2x.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 32 KiB

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Splash@3x.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 37 KiB

Просмотреть файл

@ -0,0 +1,44 @@
<?xml version="1.0" encoding="UTF-8"?>
<document type="com.apple.InterfaceBuilder3.CocoaTouch.XIB" version="3.0" toolsVersion="13771" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES" colorMatched="YES">
<device id="ipad9_7" orientation="landscape">
<adaptation id="fullscreen"/>
</device>
<dependencies>
<deployment identifier="iOS"/>
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="13772"/>
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
</dependencies>
<objects>
<placeholder placeholderIdentifier="IBFilesOwner" id="-1" userLabel="File's Owner"/>
<placeholder placeholderIdentifier="IBFirstResponder" id="-2" customClass="UIResponder"/>
<view contentMode="scaleToFill" id="iN0-l3-epB">
<rect key="frame" x="0.0" y="0.0" width="480" height="480"/>
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
<subviews>
<stackView opaque="NO" contentMode="scaleToFill" axis="vertical" translatesAutoresizingMaskIntoConstraints="NO" id="T5s-XL-ebZ">
<rect key="frame" x="0.0" y="0.0" width="480" height="480"/>
<subviews>
<imageView userInteractionEnabled="NO" contentMode="scaleAspectFill" horizontalHuggingPriority="251" verticalHuggingPriority="251" image="Splash.png" translatesAutoresizingMaskIntoConstraints="NO" id="2fi-Vc-Q9h">
<rect key="frame" x="0.0" y="0.0" width="480" height="480"/>
</imageView>
</subviews>
</stackView>
</subviews>
<color key="backgroundColor" red="0.79560637474060059" green="0.036902293562889099" blue="0.41923826932907104" alpha="1" colorSpace="custom" customColorSpace="sRGB"/>
<constraints>
<constraint firstAttribute="bottom" secondItem="T5s-XL-ebZ" secondAttribute="bottom" id="3bL-dP-mli"/>
<constraint firstAttribute="trailing" secondItem="T5s-XL-ebZ" secondAttribute="trailing" id="JT9-wp-n6M"/>
<constraint firstItem="T5s-XL-ebZ" firstAttribute="leading" secondItem="iN0-l3-epB" secondAttribute="leading" id="hfz-ga-h8a"/>
<constraint firstItem="T5s-XL-ebZ" firstAttribute="top" secondItem="iN0-l3-epB" secondAttribute="top" id="kgT-bY-2hO"/>
<constraint firstItem="T5s-XL-ebZ" firstAttribute="centerY" secondItem="iN0-l3-epB" secondAttribute="centerY" id="lTF-oo-KJ7"/>
<constraint firstItem="T5s-XL-ebZ" firstAttribute="centerX" secondItem="iN0-l3-epB" secondAttribute="centerX" id="nUK-cu-cIE"/>
</constraints>
<nil key="simulatedStatusBarMetrics"/>
<freeformSimulatedSizeMetrics key="simulatedDestinationMetrics"/>
<point key="canvasLocation" x="404" y="445"/>
</view>
</objects>
<resources>
<image name="Splash.png" width="320" height="480"/>
</resources>
</document>

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Splash~ipad.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 63 KiB

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/burgericon.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 131 B

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/category.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 325 B

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/filter.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 338 B

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/message.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 950 B

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/plus.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 239 B

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/tick.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 476 B

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/trend.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 673 B

Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/user.png Normal file

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 839 B

Просмотреть файл

@ -0,0 +1,16 @@
// This file has been autogenerated from a class added in the UI designer.
using System;
using Foundation;
using AppKit;
namespace ExpenseAnalysis.MacOS
{
public partial class ViewController : NSViewController
{
public ViewController (IntPtr handle) : base (handle)
{
}
}
}

20
ExpenseAnalysis/ExpenseAnalysis.macOS/ViewController.designer.cs сгенерированный Normal file
Просмотреть файл

@ -0,0 +1,20 @@
// WARNING
//
// This file has been generated automatically by Visual Studio to store outlets and
// actions made in the UI designer. If it is removed, they will be lost.
// Manual changes to this file may not be handled correctly.
//
using Foundation;
using System.CodeDom.Compiler;
namespace ExpenseAnalysis.MacOS
{
[Register ("ViewController")]
partial class ViewController
{
void ReleaseDesignerOutlets ()
{
}
}
}

Просмотреть файл

@ -0,0 +1,15 @@
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="SQLitePCLRaw.core" publicKeyToken="1488e028ca7ab535" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-1.1.11.121" newVersion="1.1.11.121" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="SQLitePCLRaw.batteries_v2" publicKeyToken="8226ea5df37bcae9" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-1.1.11.121" newVersion="1.1.11.121" />
</dependentAssembly>
</assemblyBinding>
</runtime>
</configuration>

Просмотреть файл

@ -0,0 +1,21 @@
<?xml version="1.0" encoding="utf-8"?>
<packages>
<package id="Microsoft.NETCore.Platforms" version="1.1.0" targetFramework="xamarinmac20" />
<package id="NETStandard.Library" version="2.0.3" targetFramework="xamarinmac20" />
<package id="sqlite-net-pcl" version="1.4.118" targetFramework="xamarinmac20" />
<package id="SQLitePCLRaw.bundle_green" version="1.1.11" targetFramework="xamarinmac20" />
<package id="SQLitePCLRaw.core" version="1.1.11" targetFramework="xamarinmac20" />
<package id="SQLitePCLRaw.lib.e_sqlite3.osx" version="1.1.11" targetFramework="xamarinmac20" />
<package id="SQLitePCLRaw.provider.e_sqlite3.macos" version="1.1.11" targetFramework="xamarinmac20" />
<package id="SQLitePCLRaw.provider.sqlite3.macos" version="1.1.11" targetFramework="xamarinmac20" />
<package id="Syncfusion.Licensing" version="16.2.0.43" targetFramework="xamarinmac20" />
<package id="Syncfusion.Xamarin.Core" version="16.2.0.42" targetFramework="xamarinmac20" />
<package id="Syncfusion.Xamarin.DataSource" version="16.2.0.42" targetFramework="xamarinmac20" />
<package id="Syncfusion.Xamarin.GridCommon" version="16.2.0.42" targetFramework="xamarinmac20" />
<package id="Syncfusion.Xamarin.SfChart" version="16.2.0.42" targetFramework="xamarinmac20" />
<package id="Syncfusion.Xamarin.SfDataGrid" version="16.2.0.42" targetFramework="xamarinmac20" />
<package id="Syncfusion.Xamarin.SfListView" version="16.2.0.42" targetFramework="xamarinmac20" />
<package id="Syncfusion.Xamarin.SfNumericTextBox" version="16.2.0.42" targetFramework="xamarinmac20" />
<package id="Syncfusion.Xamarin.SfNumericUpDown" version="16.2.0.42" targetFramework="xamarinmac20" />
<package id="Xamarin.Forms" version="2.4.0.280" targetFramework="xamarinmac20" />
</packages>

Просмотреть файл

@ -0,0 +1,71 @@
using System;
using System.Reflection;
using System.Windows.Input;
using Syncfusion.XForms.DataForm;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class AutoGeneratingDataFormItemBehavior : Behavior<SfDataForm>
{
public static readonly BindableProperty CommandProperty =
BindableProperty.Create("Command", typeof(ICommand), typeof(AutoGeneratingDataFormItemBehavior), null);
public static readonly BindableProperty InputConverterProperty =
BindableProperty.Create("Converter", typeof(IValueConverter), typeof(AutoGeneratingDataFormItemBehavior), null);
public ICommand Command
{
get { return (ICommand)GetValue(CommandProperty); }
set { SetValue(CommandProperty, value); }
}
public IValueConverter Converter
{
get { return (IValueConverter)GetValue(InputConverterProperty); }
set { SetValue(InputConverterProperty, value); }
}
public SfDataForm AssociatedObject { get; private set; }
protected override void OnAttachedTo(SfDataForm bindable)
{
base.OnAttachedTo(bindable);
AssociatedObject = bindable;
bindable.BindingContextChanged += OnBindingContextChanged;
bindable.AutoGeneratingDataFormItem += Bindable_AutoGeneratingDataFormItem;
}
protected override void OnDetachingFrom(SfDataForm bindable)
{
base.OnDetachingFrom(bindable);
bindable.BindingContextChanged -= OnBindingContextChanged;
bindable.AutoGeneratingDataFormItem -= Bindable_AutoGeneratingDataFormItem;
AssociatedObject = null;
}
void OnBindingContextChanged(object sender, EventArgs e)
{
OnBindingContextChanged();
}
protected override void OnBindingContextChanged()
{
base.OnBindingContextChanged();
BindingContext = AssociatedObject.BindingContext;
}
void Bindable_AutoGeneratingDataFormItem(object sender, AutoGeneratingDataFormItemEventArgs e)
{
if (Command == null)
{
return;
}
object parameter = Converter.Convert(e, typeof(object), null, null);
if (Command.CanExecute(parameter))
{
Command.Execute(parameter);
}
}
}
}

Просмотреть файл

@ -0,0 +1,70 @@
using Syncfusion.SfChart.XForms;
using System;
using System.Windows.Input;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class ChartSelectionChangedBehavior : Behavior<SfChart>
{
public static readonly BindableProperty CommandProperty =
BindableProperty.Create("Command", typeof(ICommand), typeof(ChartSelectionChangedBehavior), null);
public static readonly BindableProperty InputConverterProperty =
BindableProperty.Create("Converter", typeof(IValueConverter), typeof(ChartSelectionChangedBehavior), null);
public ICommand Command
{
get { return (ICommand)GetValue(CommandProperty); }
set { SetValue(CommandProperty, value); }
}
public IValueConverter Converter
{
get { return (IValueConverter)GetValue(InputConverterProperty); }
set { SetValue(InputConverterProperty, value); }
}
public SfChart AssociatedObject { get; private set; }
protected override void OnAttachedTo(SfChart bindable)
{
base.OnAttachedTo(bindable);
AssociatedObject = bindable;
bindable.BindingContextChanged += OnBindingContextChanged;
bindable.SelectionChanged += Bindable_SelectionChanged;
}
protected override void OnDetachingFrom(SfChart bindable)
{
base.OnDetachingFrom(bindable);
bindable.BindingContextChanged -= OnBindingContextChanged;
AssociatedObject = null;
}
void OnBindingContextChanged(object sender, EventArgs e)
{
OnBindingContextChanged();
}
private void Bindable_SelectionChanged(object sender, ChartSelectionEventArgs e)
{
if (Command == null)
{
return;
}
object parameter = Converter.Convert(e, typeof(object), null, null);
if (Command.CanExecute(parameter))
{
Command.Execute(parameter);
}
}
protected override void OnBindingContextChanged()
{
base.OnBindingContextChanged();
BindingContext = AssociatedObject.BindingContext;
}
}
}

Просмотреть файл

@ -0,0 +1,32 @@
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class AutoCompleteConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
var transactionDetail = new List<string>();
var transactions = value as ObservableCollection<TransactionDetail>;
foreach (var transaction in transactions.Where(transaction => !transactionDetail.Contains(transaction.Name))
)
{
transactionDetail.Add(transaction.Name);
}
return transactionDetail;
}
public object ConvertBack(object value, Type targetType, object parameter,
System.Globalization.CultureInfo culture)
{
return value;
}
}
}

Просмотреть файл

@ -0,0 +1,34 @@
using Syncfusion.SfChart.XForms;
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class BudgetAvergeConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
double averageBudget = 0;
for (var i = 0; i < ((ObservableCollection<ExpenseCategory>)value).Count; i++)
averageBudget = averageBudget + ((ObservableCollection<ExpenseCategory>)value)[i].Budget;
averageBudget = averageBudget / 3;
var dataPoints = new ObservableCollection<ChartDataPoint>
{
new ChartDataPoint(1, averageBudget),
new ChartDataPoint(2, averageBudget)
};
return dataPoints;
}
public object ConvertBack(object value, Type targetType, object parameter,
System.Globalization.CultureInfo culture)
{
return value;
}
}
}

Просмотреть файл

@ -0,0 +1,25 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class CellBackgroundColorConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
if (double.Parse(value.ToString()) > 100)
return Color.FromHex("#BF4D43");
return double.Parse(value.ToString()) > 80 ? Color.FromHex("#DDA51E") : Color.White;
}
public object ConvertBack(object value, Type targetType, object parameter,
System.Globalization.CultureInfo culture)
{
return value;
}
}
}

Просмотреть файл

@ -0,0 +1,23 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class CellTextColorConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return double.Parse(value.ToString()) > 100 ? Color.White : Color.Black;
}
public object ConvertBack(object value, Type targetType, object parameter,
System.Globalization.CultureInfo culture)
{
return value;
}
}
}

Просмотреть файл

@ -24,6 +24,21 @@ namespace ExpenseAnalysis
}
}
public class SelectedItemConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return value;
}
public object ConvertBack(object value, Type targetType, object parameter,
System.Globalization.CultureInfo culture)
{
return value;
}
}
public class MonthExpenseConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
@ -57,8 +72,8 @@ namespace ExpenseAnalysis
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
if (double.Parse(value.ToString()) > 100)
return Color.FromHex("#FF3C24");
return double.Parse(value.ToString()) > 80 ? Color.FromHex("#FFF200") : Color.White;
return Color.FromHex("#BF4D43");
return double.Parse(value.ToString()) > 80 ? Color.FromHex("#DDA51E") : Color.White;
}
public object ConvertBack(object value, Type targetType, object parameter,
@ -79,7 +94,7 @@ namespace ExpenseAnalysis
foreach (var trans in groupedValue)
{
dataPoints.Add(new ChartDataPoint(new DateTime(trans.FirstOrDefault().Date.Year, trans.Key, 15),
dataPoints.Add(new ChartDataPoint(new DateTime(trans.FirstOrDefault().Date.Year, trans.Key, trans.Key),
trans.Sum(item => item.Spent)));
}
return dataPoints;

Просмотреть файл

@ -0,0 +1,25 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class ImageConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
if (value.ToString() == "Health & Wellness")
return "health.png";
return value.ToString().ToLower() + ".png";
}
public object ConvertBack(object value, Type targetType, object parameter,
System.Globalization.CultureInfo culture)
{
return value;
}
}
}

Просмотреть файл

@ -0,0 +1,24 @@
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class MonthExpenseConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return (value as ObservableCollection<TransactionDetail>)?.Where(j => j.Date.Month == 3);
}
public object ConvertBack(object value, Type targetType, object parameter,
System.Globalization.CultureInfo culture)
{
return value;
}
}
}

Просмотреть файл

@ -0,0 +1,35 @@
using Syncfusion.SfChart.XForms;
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class MonthSpentConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
var transactions = value as ObservableCollection<TransactionDetail>;
var groupedValue = transactions.GroupBy(item => item.Date.Month);
var dataPoints = new ObservableCollection<ChartDataPoint>();
foreach (var trans in groupedValue)
{
dataPoints.Add(new ChartDataPoint(new DateTime(trans.FirstOrDefault().Date.Year, trans.Key, trans.Key),
trans.Sum(item => item.Spent)));
}
return dataPoints;
}
public object ConvertBack(object value, Type targetType, object parameter,
System.Globalization.CultureInfo culture)
{
return value;
}
}
}

Просмотреть файл

@ -0,0 +1,24 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class SelectedItemConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return value;
}
public object ConvertBack(object value, Type targetType, object parameter,
System.Globalization.CultureInfo culture)
{
return value;
}
}
}

Просмотреть файл

@ -0,0 +1,30 @@
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class SelectedTrendsTitleConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
//Get the month number from anonymous class and return the month name using date time format.
if (((IList)value).Count != 0)
return
new DateTime(2000,
(int)char.GetNumericValue(((IList)value)[0].ToString().Split('=')[4].ToCharArray()[1]), 1)
.ToString("MMMM");
return 0;
}
public object ConvertBack(object value, Type targetType, object parameter,
System.Globalization.CultureInfo culture)
{
return value;
}
}
}

Просмотреть файл

@ -36,11 +36,32 @@
</PropertyGroup>
<ItemGroup>
<Compile Include="App.cs" />
<Compile Include="Behaviors\ChartSelectionBehaviorExt.cs" />
<Compile Include="Converters\Converters.cs" />
<Compile Include="Behaviors\AutoGeneratingDataFormItemBehavior.cs" />
<Compile Include="Behaviors\ChartSelectionChangedBehavior.cs" />
<Compile Include="Converters\AutoCompleteConverter.cs" />
<Compile Include="Converters\BudgetAvergeConverter.cs" />
<Compile Include="Converters\CellBackgroundColorConverter.cs" />
<Compile Include="Converters\CellTextColorConverter.cs" />
<Compile Include="Converters\ImageConverter.cs" />
<Compile Include="Converters\MonthExpenseConverter.cs" />
<Compile Include="Converters\MonthSpentConverter.cs" />
<Compile Include="Converters\SelectedItemConverter.cs" />
<Compile Include="Converters\SelectedTrendsTitleConverter.cs" />
<Compile Include="Model\ExpenseCategory.cs" />
<Compile Include="Model\MonthTransaction.cs" />
<Compile Include="Model\TransactionDetail.cs" />
<Compile Include="NavigationServices\INavigationService.cs" />
<Compile Include="NavigationServices\NavigationService.cs" />
<Compile Include="Triggers\NumericTriggerAction.cs" />
<Compile Include="ViewModel\AddTransactionsPageViewModel.cs" />
<Compile Include="ViewModel\CategoryBudgetPageViewModel.cs" />
<Compile Include="ViewModel\CategoryDetailPageViewModel.cs" />
<Compile Include="ViewModel\OverviewPageViewModel.cs" />
<Compile Include="ViewModel\TransactionsPageViewModel.cs" />
<Compile Include="ViewModel\TrendsPageViewModel.cs" />
<Compile Include="View\AddTransactionsPage_MacOS.xaml.cs">
<DependentUpon>AddTransactionsPage_MacOS.xaml</DependentUpon>
</Compile>
<Compile Include="View\AddTransactionsPage.xaml.cs">
<DependentUpon>AddTransactionsPage.xaml</DependentUpon>
</Compile>
@ -58,7 +79,7 @@
<Compile Include="View\MasterPage.xaml.cs">
<DependentUpon>MasterPage.xaml</DependentUpon>
</Compile>
<Compile Include="View\MasterPageItem.cs" />
<Compile Include="Model\MasterPageItem.cs" />
<Compile Include="View\OverviewPage.xaml.cs">
<DependentUpon>OverviewPage.xaml</DependentUpon>
</Compile>
@ -69,7 +90,7 @@
<Compile Include="View\TrendsPage.xaml.cs">
<DependentUpon>TrendsPage.xaml</DependentUpon>
</Compile>
<Compile Include="ViewModel\ExpenseViewModel.cs" />
<Compile Include="ViewModel\ExpenseViewModelBase.cs" />
</ItemGroup>
<ItemGroup>
<Reference Include="SQLite-net, Version=1.1.0.0, Culture=neutral, processorArchitecture=MSIL">
@ -92,45 +113,38 @@
<HintPath>..\..\packages\SQLitePCLRaw.core.1.1.2\lib\portable-net45+netcore45+wpa81+wp8+MonoAndroid10+MonoTouch10+Xamarin.iOS10\SQLitePCLRaw.core.dll</HintPath>
<Private>True</Private>
</Reference>
<Reference Include="Syncfusion.Core.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.Core.16.1.0.37\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.Core.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.Core.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.Core.16.2.0.42\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.Core.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.Data.Portable, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.1.0.37\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.Data.Portable.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.Data.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.Data.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.DataSource.Portable, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.DataSource.16.1.0.37\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.DataSource.Portable.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.DataSource.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.DataSource.16.2.0.42\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.DataSource.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.GridCommon.Portable, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.GridCommon.16.1.0.37\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.GridCommon.Portable.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.GridCommon.Portable, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.GridCommon.16.2.0.42\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.GridCommon.Portable.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfChart.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.1.0.37\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfChart.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.Licensing, Version=16.2.0.43, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Licensing.16.2.0.43\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.Licensing.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataForm.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataForm.16.1.0.37\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfDataForm.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfChart.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfChart.16.2.0.42\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfChart.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfDataGrid.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.1.0.37\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfDataGrid.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfDataForm.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataForm.16.2.0.42\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfDataForm.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfListView.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.1.0.37\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfListView.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfDataGrid.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfDataGrid.16.2.0.42\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfDataGrid.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericTextBox.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.1.0.37\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfNumericTextBox.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfListView.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfListView.16.2.0.42\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfListView.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.XForms, Version=16.1451.0.37, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.1.0.37\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfNumericUpDown.XForms.dll</HintPath>
<Private>True</Private>
<Reference Include="Syncfusion.SfNumericTextBox.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericTextBox.16.2.0.42\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfNumericTextBox.XForms.dll</HintPath>
</Reference>
<Reference Include="Syncfusion.SfNumericUpDown.XForms, Version=16.2451.0.42, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Syncfusion.Xamarin.SfNumericUpDown.16.2.0.42\lib\portable-win+net45+wp80+win81+wpa81\Syncfusion.SfNumericUpDown.XForms.dll</HintPath>
</Reference>
<Reference Include="Xamarin.Forms.Core, Version=2.0.0.0, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\packages\Xamarin.Forms.2.4.0.280\lib\portable-win+net45+wp80+win81+wpa81\Xamarin.Forms.Core.dll</HintPath>
@ -199,6 +213,12 @@
<SubType>Designer</SubType>
</EmbeddedResource>
</ItemGroup>
<ItemGroup>
<EmbeddedResource Include="View\AddTransactionsPage_MacOS.xaml">
<Generator>MSBuild:UpdateDesignTimeXaml</Generator>
<SubType>Designer</SubType>
</EmbeddedResource>
</ItemGroup>
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\Portable\$(TargetFrameworkVersion)\Microsoft.Portable.CSharp.targets" />
<Import Project="..\..\packages\Xamarin.Forms.2.4.0.280\build\portable-win+net45+wp80+win81+wpa81\Xamarin.Forms.targets" Condition="Exists('..\..\packages\Xamarin.Forms.2.4.0.280\build\portable-win+net45+wp80+win81+wpa81\Xamarin.Forms.targets')" />
<Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild">

Просмотреть файл

@ -0,0 +1,13 @@
using System;
namespace ExpenseAnalysis
{
public class MasterPageItem
{
public string Title { get; set; }
public string IconSource { get; set; }
public Type TargetType { get; set; }
}
}

Просмотреть файл

@ -0,0 +1,18 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public interface INavigationService
{
void NavigateToPage(MasterPageItem item);
void NavigateToPage(Type item, object parameter);
void NavigatePopToRoot();
}
}

Просмотреть файл

@ -0,0 +1,80 @@
using System;
using System.Collections;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Globalization;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class NavigationService : INavigationService
{
protected Page CurrentDetail
{
get { return (Application.Current.MainPage as MasterDetail).Detail; }
}
public void NavigateToPage(MasterPageItem item)
{
NavigationPage page = new NavigationPage((Page)Activator.CreateInstance((item as MasterPageItem).TargetType));
if (Device.RuntimePlatform != Device.macOS)
{
page.BarBackgroundColor = Color.FromHex("#3F539F");
page.BarTextColor = Color.White;
}
(Application.Current.MainPage as MasterDetail).Detail = page;
if (Device.RuntimePlatform == Device.Android || Device.RuntimePlatform == Device.iOS)
(Application.Current.MainPage as MasterDetail).IsPresented = false;
}
public void NavigateToPage(Type viewModelType, object parameter)
{
Page page = CreatePage(viewModelType);
if (page is AddTransactionsPage || page is AddTransactionsPage_MacOS)
(page.BindingContext as AddTransactionsPageViewModel).Transactions =
(parameter as ObservableCollection<TransactionDetail>);
else if (page is CategoryDetailPage)
(page.BindingContext as CategoryDetailPageViewModel).SelectedCategoryTransactions = parameter as IEnumerable;
CurrentDetail.Navigation.PushAsync(page);
}
public void NavigatePopToRoot()
{
CurrentDetail.Navigation.PopAsync();
}
private Type GetPageTypeForViewModel(Type viewModelType)
{
var viewName = viewModelType.FullName.Replace("ViewModel", string.Empty);
if (Device.RuntimePlatform == Device.macOS && viewModelType.Name == "AddTransactionsPageViewModel")
viewName = viewModelType.FullName.Replace("ViewModel", "_MacOS");
var viewModelAssemblyName = viewModelType.GetTypeInfo().Assembly.FullName;
var viewAssemblyName = string.Format(CultureInfo.InvariantCulture, "{0}, {1}", viewName, viewModelAssemblyName);
var viewType = Type.GetType(viewAssemblyName);
return viewType;
}
private Page CreatePage(Type viewModelType)
{
Type pageType = GetPageTypeForViewModel(viewModelType);
if (pageType == null)
{
throw new Exception($"Cannot locate page type for {viewModelType}");
}
Page page = Activator.CreateInstance(pageType) as Page;
return page;
}
}
}

Просмотреть файл

@ -0,0 +1,27 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public class NumericTriggerAction : TriggerAction<Entry>
{
string prevText = string.Empty;
protected override void Invoke(Entry entry)
{
var isNumeric = double.TryParse(entry.Text, out double value);
if (!string.IsNullOrWhiteSpace(entry.Text) && !isNumeric)
{
entry.Text = prevText;
return;
}
prevText = entry.Text;
}
}
}

Просмотреть файл

@ -0,0 +1,47 @@
<?xml version="1.0" encoding="UTF-8"?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="ExpenseAnalysis.AddTransactionPageForMacOS"
xmlns:local="clr-namespace:ExpenseAnalysis;assembly=ExpenseAnalysis"
Title="ADD TRANSACTION">
<ContentPage.ToolbarItems>
<ToolbarItem Command="{Binding AddNewData}" Text="Done" Icon="tick.png" />
</ContentPage.ToolbarItems>
<Grid Margin="20,23,0,0" HorizontalOptions="FillAndExpand" VerticalOptions="StartAndExpand">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="6*" />
<ColumnDefinition Width="4*" />
</Grid.ColumnDefinitions>
<StackLayout Orientation="Vertical" Grid.Column="0">
<Label Text="Spent" FontSize="Medium" HorizontalOptions="FillAndExpand" HorizontalTextAlignment="Start" VerticalOptions="FillAndExpand" VerticalTextAlignment="Center" />
<Entry x:Name="AmountSpent" Placeholder="$" HeightRequest="23" Margin="0,0,0,12" FontSize="Medium" Text="{Binding SpentOn}" HorizontalTextAlignment="Start" HorizontalOptions="FillAndExpand" VerticalOptions="FillAndExpand">
<Entry.Triggers>
<EventTrigger Event="TextChanged">
<local:NumericTriggerAction />
</EventTrigger>
</Entry.Triggers>
</Entry>
<Label Text="Category" FontSize="Medium" HorizontalOptions="FillAndExpand" HorizontalTextAlignment="Start" VerticalOptions="FillAndExpand" VerticalTextAlignment="Center" />
<Picker x:Name="CategoryPicker" SelectedItem="{Binding CategorySelected}" HeightRequest="23" Margin="0,0,0,12" HorizontalOptions="FillAndExpand" VerticalOptions="FillAndExpand">
<Picker.Items>
<x:String>Home</x:String>
<x:String>Entertainment</x:String>
<x:String>Food</x:String>
<x:String>Charity</x:String>
<x:String>Utilities</x:String>
<x:String>Auto</x:String>
<x:String>Education</x:String>
<x:String>HelathAndWellness</x:String>
<x:String>Shopping</x:String>
</Picker.Items>
</Picker>
<Label Text="Expense Description" FontSize="Medium" HorizontalOptions="FillAndExpand" HorizontalTextAlignment="Start" VerticalOptions="FillAndExpand" VerticalTextAlignment="Center" />
<Entry x:Name="Description" HorizontalTextAlignment="Start" HeightRequest="23" FontSize="Medium" Margin="0,0,0,12" Text="{Binding ExpenseDescription}" HorizontalOptions="FillAndExpand" VerticalOptions="FillAndExpand" />
<Label Text="Date" FontSize="Medium" HorizontalOptions="FillAndExpand" HorizontalTextAlignment="Start" VerticalOptions="FillAndExpand" VerticalTextAlignment="Center" />
<DatePicker x:Name="DateTimePicker" Date="{Binding Date}" HeightRequest="23" MinimumDate="01/01/2018" MaximumDate="03/31/2018" HorizontalOptions="FillAndExpand" VerticalOptions="FillAndExpand" />
</StackLayout>
</Grid>
</ContentPage>

Просмотреть файл

@ -0,0 +1,13 @@
using System;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public partial class AddTransactionPageForMacOS : ContentPage
{
public AddTransactionPageForMacOS()
{
InitializeComponent();
}
}
}

Просмотреть файл

@ -0,0 +1,49 @@
<?xml version="1.0" encoding="UTF-8"?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="ExpenseAnalysis.AddTransactionPage_MacOS"
xmlns:local="clr-namespace:ExpenseAnalysis;assembly=ExpenseAnalysis"
Title="ADD TRANSACTION">
<ContentPage.BindingContext>
<local:AddTransactionsPageViewModel/>
</ContentPage.BindingContext>
<ContentPage.ToolbarItems>
<ToolbarItem Command="{Binding AddNewData}" Text="Done" Icon="tick.png" />
</ContentPage.ToolbarItems>
<Grid Margin="20,23,0,0" HorizontalOptions="FillAndExpand" VerticalOptions="StartAndExpand">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="6*" />
<ColumnDefinition Width="4*" />
</Grid.ColumnDefinitions>
<StackLayout Orientation="Vertical" Grid.Column="0">
<Label Text="Spent" FontSize="Medium" HorizontalOptions="FillAndExpand" HorizontalTextAlignment="Start" VerticalOptions="FillAndExpand" VerticalTextAlignment="Center" />
<Entry x:Name="AmountSpent" Placeholder="$" HeightRequest="23" Margin="0,0,0,12" FontSize="Medium" Text="{Binding SpentOn}" HorizontalTextAlignment="Start" HorizontalOptions="FillAndExpand" VerticalOptions="FillAndExpand">
<Entry.Triggers>
<EventTrigger Event="TextChanged">
<local:NumericTriggerAction />
</EventTrigger>
</Entry.Triggers>
</Entry>
<Label Text="Category" FontSize="Medium" HorizontalOptions="FillAndExpand" HorizontalTextAlignment="Start" VerticalOptions="FillAndExpand" VerticalTextAlignment="Center" />
<Picker x:Name="CategoryPicker" SelectedItem="{Binding CategorySelected}" HeightRequest="23" Margin="0,0,0,12" HorizontalOptions="FillAndExpand" VerticalOptions="FillAndExpand">
<Picker.Items>
<x:String>Home</x:String>
<x:String>Entertainment</x:String>
<x:String>Food</x:String>
<x:String>Charity</x:String>
<x:String>Utilities</x:String>
<x:String>Auto</x:String>
<x:String>Education</x:String>
<x:String>HelathAndWellness</x:String>
<x:String>Shopping</x:String>
</Picker.Items>
</Picker>
<Label Text="Expense Description" FontSize="Medium" HorizontalOptions="FillAndExpand" HorizontalTextAlignment="Start" VerticalOptions="FillAndExpand" VerticalTextAlignment="Center" />
<Entry x:Name="Description" HorizontalTextAlignment="Start" HeightRequest="23" FontSize="Medium" Margin="0,0,0,12" Text="{Binding ExpenseDescription}" HorizontalOptions="FillAndExpand" VerticalOptions="FillAndExpand" />
<Label Text="Date" FontSize="Medium" HorizontalOptions="FillAndExpand" HorizontalTextAlignment="Start" VerticalOptions="FillAndExpand" VerticalTextAlignment="Center" />
<DatePicker x:Name="DateTimePicker" Date="{Binding Date}" HeightRequest="23" MinimumDate="01/01/2018" MaximumDate="03/31/2018" HorizontalOptions="FillAndExpand" VerticalOptions="FillAndExpand" />
</StackLayout>
</Grid>
</ContentPage>

Просмотреть файл

@ -0,0 +1,13 @@
using System;
using Xamarin.Forms;
namespace ExpenseAnalysis
{
public partial class AddTransactionPage_MacOS : ContentPage
{
public AddTransactionPage_MacOS()
{
InitializeComponent();
}
}
}

Просмотреть файл

@ -1,22 +1,42 @@
<?xml version="1.0" encoding="utf-8" ?>
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="ExpenseAnalysis.AddTransactionsPage" Title="ADD TRANSACTION"
xmlns:sys="clr-namespace:System;assembly=mscorlib"
xmlns:local="clr-namespace:ExpenseAnalysis;assembly=ExpenseAnalysis"
x:Class="ExpenseAnalysis.AddTransactionsPage" Title="ADD TRANSACTION"
xmlns:dataForm="clr-namespace:Syncfusion.XForms.DataForm;assembly=Syncfusion.SfDataForm.XForms">
<ContentPage.BindingContext>
<local:AddTransactionsPageViewModel/>
</ContentPage.BindingContext>
<ContentPage.ToolbarItems>
<ToolbarItem Order="Primary" Priority="0" Clicked="DoneButton_Clicked" Text="Done">
<ToolbarItem Order="Primary" Priority="0" Command="{Binding AddNewData}" Text="Done">
<ToolbarItem.Icon>
<OnPlatform x:TypeArguments="FileImageSource"
WinPhone="tick.png" />
</ToolbarItem.Icon>
</ToolbarItem>
</ContentPage.ToolbarItems>
<ContentPage.Resources>
<ResourceDictionary>
<local:SelectedItemConverter x:Key="SelectedItemConverter" />
</ResourceDictionary>
</ContentPage.Resources>
<ContentPage.Content>
<dataForm:SfDataForm x:Name="dataForm" Margin="15" ValidationMode="Explicit" LabelPosition="Top" AutoGeneratingDataFormItem="DataForm_AutoGeneratingDataFormItem" DataObject="{Binding SingleTransaction}">
<dataForm:SfDataForm x:Name="dataForm" Margin="15" ValidationMode="Explicit" LabelPosition="Top" WidthRequest="300"
DataObject="{Binding SingleTransaction}">
<dataForm:SfDataForm.Behaviors>
<local:AutoGeneratingDataFormItemBehavior Command="{Binding AutoGeneratingColumns}"
Converter="{StaticResource SelectedItemConverter}" />
</dataForm:SfDataForm.Behaviors>
<dataForm:SfDataForm.WidthRequest>
<OnPlatform x:TypeArguments="x:Double">
<On Platform="UWP">700</On>
</OnPlatform>
</dataForm:SfDataForm.WidthRequest>
<dataForm:SfDataForm.Margin>
<OnPlatform x:TypeArguments="Thickness">
<On Platform="UWP">30</On>
</OnPlatform>
</dataForm:SfDataForm.Margin>
</dataForm:SfDataForm>
</ContentPage.Content>
</ContentPage>

Некоторые файлы не были показаны из-за слишком большого количества измененных файлов Показать больше