Added support for macOS.
|
@ -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());
|
||||
}
|
||||
|
|
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.Droid/Resources/drawable-land-xhdpi/icon.png
Normal file
После Ширина: | Высота: | Размер: 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>
|
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.UWP/ExpenseAnalysis.UWP_TemporaryKey.pfx
Normal file
|
@ -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" />
|
||||
|
|
|
@ -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)
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Assets.xcassets/AppIcon.appiconset/AppIcon-128.png
Normal file
После Ширина: | Высота: | Размер: 7.9 KiB |
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Assets.xcassets/AppIcon.appiconset/AppIcon-128@2x.png
Normal file
После Ширина: | Высота: | Размер: 20 KiB |
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Assets.xcassets/AppIcon.appiconset/AppIcon-16.png
Normal file
После Ширина: | Высота: | Размер: 711 B |
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Assets.xcassets/AppIcon.appiconset/AppIcon-16@2x.png
Normal file
После Ширина: | Высота: | Размер: 1.4 KiB |
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Assets.xcassets/AppIcon.appiconset/AppIcon-256.png
Normal file
После Ширина: | Высота: | Размер: 20 KiB |
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Assets.xcassets/AppIcon.appiconset/AppIcon-256@2x.png
Normal file
После Ширина: | Высота: | Размер: 58 KiB |
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Assets.xcassets/AppIcon.appiconset/AppIcon-32.png
Normal file
После Ширина: | Высота: | Размер: 1.4 KiB |
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Assets.xcassets/AppIcon.appiconset/AppIcon-32@2x.png
Normal file
После Ширина: | Высота: | Размер: 3.3 KiB |
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Assets.xcassets/AppIcon.appiconset/AppIcon-512.png
Normal file
После Ширина: | Высота: | Размер: 58 KiB |
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Assets.xcassets/AppIcon.appiconset/AppIcon-512@2x.png
Normal file
После Ширина: | Высота: | Размер: 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/Default-Portrait - 768 x 1024.png
Normal file
После Ширина: | Высота: | Размер: 88 KiB |
Двоичные данные
ExpenseAnalysis/ExpenseAnalysis.macOS/Resources/Default-Portrait@2x - 1536 x 2048.png
Normal file
После Ширина: | Высота: | Размер: 221 KiB |
После Ширина: | Высота: | Размер: 11 KiB |
После Ширина: | Высота: | Размер: 3.4 KiB |
После Ширина: | Высота: | Размер: 1.5 KiB |
После Ширина: | Высота: | Размер: 854 B |
После Ширина: | Высота: | Размер: 1.7 KiB |
После Ширина: | Высота: | Размер: 1.3 KiB |
После Ширина: | Высота: | Размер: 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>
|
После Ширина: | Высота: | Размер: 33 KiB |
После Ширина: | Высота: | Размер: 32 KiB |
После Ширина: | Высота: | Размер: 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>
|
После Ширина: | Высота: | Размер: 63 KiB |
После Ширина: | Высота: | Размер: 131 B |
После Ширина: | Высота: | Размер: 325 B |
После Ширина: | Высота: | Размер: 338 B |
После Ширина: | Высота: | Размер: 950 B |
После Ширина: | Высота: | Размер: 239 B |
После Ширина: | Высота: | Размер: 476 B |
После Ширина: | Высота: | Размер: 673 B |
После Ширина: | Высота: | Размер: 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)
|
||||
{
|
||||
}
|
||||
}
|
||||
}
|
|
@ -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>
|