diff options
author | ​ | 1970-01-01 00:00:00 +0000 |
---|---|---|
committer | ​ | 2025-01-08 04:44:56 +0000 |
commit | 716b60826bd7ca82dd70ed8ceb524528f86b8edf (patch) | |
tree | d94a2c0b7c4a65474d53a7b91a12345f7e13d223 | |
parent | future value 2 (diff) | |
download | cs-716b60826bd7ca82dd70ed8ceb524528f86b8edf.tar cs-716b60826bd7ca82dd70ed8ceb524528f86b8edf.tar.gz cs-716b60826bd7ca82dd70ed8ceb524528f86b8edf.tar.bz2 cs-716b60826bd7ca82dd70ed8ceb524528f86b8edf.tar.xz cs-716b60826bd7ca82dd70ed8ceb524528f86b8edf.zip |
invoice total 3
27 files changed, 839 insertions, 0 deletions
diff --git a/invoice_total3/.vs/InvoiceTotal/FileContentIndex/6282f27b-7607-4e9d-b849-e9231febefe9.vsidx b/invoice_total3/.vs/InvoiceTotal/FileContentIndex/6282f27b-7607-4e9d-b849-e9231febefe9.vsidx new file mode 100644 index 0000000..f9b60f5 --- /dev/null +++ b/invoice_total3/.vs/InvoiceTotal/FileContentIndex/6282f27b-7607-4e9d-b849-e9231febefe9.vsidx Binary files differdiff --git a/invoice_total3/.vs/InvoiceTotal/v17/.suo b/invoice_total3/.vs/InvoiceTotal/v17/.suo new file mode 100644 index 0000000..a39a77a --- /dev/null +++ b/invoice_total3/.vs/InvoiceTotal/v17/.suo Binary files differdiff --git a/invoice_total3/InvoiceTotal.sln b/invoice_total3/InvoiceTotal.sln new file mode 100644 index 0000000..ced1066 --- /dev/null +++ b/invoice_total3/InvoiceTotal.sln @@ -0,0 +1,22 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 14 +VisualStudioVersion = 14.0.23107.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "InvoiceTotal", "InvoiceTotal\InvoiceTotal.csproj", "{ABFE3FFD-56CF-4B23-8ED5-EBBBAF6EFD39}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {ABFE3FFD-56CF-4B23-8ED5-EBBBAF6EFD39}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {ABFE3FFD-56CF-4B23-8ED5-EBBBAF6EFD39}.Debug|Any CPU.Build.0 = Debug|Any CPU + {ABFE3FFD-56CF-4B23-8ED5-EBBBAF6EFD39}.Release|Any CPU.ActiveCfg = Release|Any CPU + {ABFE3FFD-56CF-4B23-8ED5-EBBBAF6EFD39}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/invoice_total3/InvoiceTotal/InvoiceTotal.csproj b/invoice_total3/InvoiceTotal/InvoiceTotal.csproj new file mode 100644 index 0000000..c67214c --- /dev/null +++ b/invoice_total3/InvoiceTotal/InvoiceTotal.csproj @@ -0,0 +1,138 @@ +<?xml version="1.0" encoding="utf-8"?> +<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003" ToolsVersion="12.0"> + <PropertyGroup> + <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration> + <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform> + <ProductVersion>9.0.21022</ProductVersion> + <SchemaVersion>2.0</SchemaVersion> + <ProjectGuid>{ABFE3FFD-56CF-4B23-8ED5-EBBBAF6EFD39}</ProjectGuid> + <OutputType>WinExe</OutputType> + <AppDesignerFolder>Properties</AppDesignerFolder> + <RootNamespace>InvoiceTotal</RootNamespace> + <AssemblyName>InvoiceTotal</AssemblyName> + <FileUpgradeFlags> + </FileUpgradeFlags> + <OldToolsVersion>3.5</OldToolsVersion> + <UpgradeBackupLocation> + </UpgradeBackupLocation> + <IsWebBootstrapper>true</IsWebBootstrapper> + <TargetFrameworkVersion>v4.8</TargetFrameworkVersion> + <PublishUrl>http://localhost/InvoiceTotal/</PublishUrl> + <Install>true</Install> + <InstallFrom>Web</InstallFrom> + <UpdateEnabled>true</UpdateEnabled> + <UpdateMode>Foreground</UpdateMode> + <UpdateInterval>7</UpdateInterval> + <UpdateIntervalUnits>Days</UpdateIntervalUnits> + <UpdatePeriodically>false</UpdatePeriodically> + <UpdateRequired>false</UpdateRequired> + <MapFileExtensions>true</MapFileExtensions> + <ApplicationRevision>0</ApplicationRevision> + <ApplicationVersion>1.0.0.%2a</ApplicationVersion> + <UseApplicationTrust>false</UseApplicationTrust> + <BootstrapperEnabled>true</BootstrapperEnabled> + <TargetFrameworkProfile> + </TargetFrameworkProfile> + </PropertyGroup> + <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "> + <DebugSymbols>true</DebugSymbols> + <DebugType>full</DebugType> + <Optimize>false</Optimize> + <OutputPath>bin\Debug\</OutputPath> + <DefineConstants>DEBUG;TRACE</DefineConstants> + <ErrorReport>prompt</ErrorReport> + <WarningLevel>4</WarningLevel> + <Prefer32Bit>false</Prefer32Bit> + <LangVersion>8.0</LangVersion> + </PropertyGroup> + <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> + <DebugType>pdbonly</DebugType> + <Optimize>true</Optimize> + <OutputPath>bin\Release\</OutputPath> + <DefineConstants>TRACE</DefineConstants> + <ErrorReport>prompt</ErrorReport> + <WarningLevel>4</WarningLevel> + <Prefer32Bit>false</Prefer32Bit> + </PropertyGroup> + <ItemGroup> + <Reference Include="Microsoft.CSharp" /> + <Reference Include="System" /> + <Reference Include="System.Core"> + <RequiredTargetFramework>3.5</RequiredTargetFramework> + </Reference> + <Reference Include="System.Data" /> + <Reference Include="System.Data.DataSetExtensions"> + <RequiredTargetFramework>3.5</RequiredTargetFramework> + </Reference> + <Reference Include="System.Deployment" /> + <Reference Include="System.Drawing" /> + <Reference Include="System.Net.Http" /> + <Reference Include="System.Windows.Forms" /> + <Reference Include="System.Xml" /> + <Reference Include="System.Xml.Linq"> + <RequiredTargetFramework>3.5</RequiredTargetFramework> + </Reference> + </ItemGroup> + <ItemGroup> + <Compile Include="frmInvoiceTotal.cs"> + <SubType>Form</SubType> + </Compile> + <Compile Include="frmInvoiceTotal.Designer.cs"> + <DependentUpon>frmInvoiceTotal.cs</DependentUpon> + </Compile> + <Compile Include="Program.cs" /> + <Compile Include="Properties\AssemblyInfo.cs" /> + <EmbeddedResource Include="frmInvoiceTotal.resx"> + <DependentUpon>frmInvoiceTotal.cs</DependentUpon> + <SubType>Designer</SubType> + </EmbeddedResource> + <EmbeddedResource Include="Properties\Resources.resx"> + <Generator>ResXFileCodeGenerator</Generator> + <LastGenOutput>Resources.Designer.cs</LastGenOutput> + <SubType>Designer</SubType> + </EmbeddedResource> + <Compile Include="Properties\Resources.Designer.cs"> + <AutoGen>True</AutoGen> + <DependentUpon>Resources.resx</DependentUpon> + <DesignTime>True</DesignTime> + </Compile> + <None Include="app.config" /> + <None Include="Properties\Settings.settings"> + <Generator>SettingsSingleFileGenerator</Generator> + <LastGenOutput>Settings.Designer.cs</LastGenOutput> + </None> + <Compile Include="Properties\Settings.Designer.cs"> + <AutoGen>True</AutoGen> + <DependentUpon>Settings.settings</DependentUpon> + <DesignTimeSharedInput>True</DesignTimeSharedInput> + </Compile> + </ItemGroup> + <ItemGroup> + <BootstrapperPackage Include="Microsoft.Net.Client.3.5"> + <Visible>False</Visible> + <ProductName>.NET Framework 3.5 SP1 Client Profile</ProductName> + <Install>false</Install> + </BootstrapperPackage> + <BootstrapperPackage Include="Microsoft.Net.Framework.2.0"> + <Visible>False</Visible> + <ProductName>.NET Framework 2.0 %28x86%29</ProductName> + <Install>true</Install> + </BootstrapperPackage> + <BootstrapperPackage Include="Microsoft.Net.Framework.3.0"> + <Visible>False</Visible> + <ProductName>.NET Framework 3.0 %28x86%29</ProductName> + <Install>false</Install> + </BootstrapperPackage> + <BootstrapperPackage Include="Microsoft.Net.Framework.3.5"> + <Visible>False</Visible> + <ProductName>.NET Framework 3.5</ProductName> + <Install>false</Install> + </BootstrapperPackage> + <BootstrapperPackage Include="Microsoft.Net.Framework.3.5.SP1"> + <Visible>False</Visible> + <ProductName>.NET Framework 3.5 SP1</ProductName> + <Install>false</Install> + </BootstrapperPackage> + </ItemGroup> + <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" /> +</Project> \ No newline at end of file diff --git a/invoice_total3/InvoiceTotal/Program.cs b/invoice_total3/InvoiceTotal/Program.cs new file mode 100644 index 0000000..7f14579 --- /dev/null +++ b/invoice_total3/InvoiceTotal/Program.cs @@ -0,0 +1,22 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Threading.Tasks; +using System.Windows.Forms; + +namespace InvoiceTotal +{ + static class Program + { + /// <summary> + /// The main entry point for the application. + /// </summary> + [STAThread] + static void Main() + { + Application.EnableVisualStyles(); + Application.SetCompatibleTextRenderingDefault(false); + Application.Run(new frmInvoiceTotal()); + } + } +} \ No newline at end of file diff --git a/invoice_total3/InvoiceTotal/Properties/AssemblyInfo.cs b/invoice_total3/InvoiceTotal/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..1d4eb9a --- /dev/null +++ b/invoice_total3/InvoiceTotal/Properties/AssemblyInfo.cs @@ -0,0 +1,33 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// General Information about an assembly is controlled through the following +// set of attributes. Change these attribute values to modify the information +// associated with an assembly. +[assembly: AssemblyTitle("InvoiceTotal")] +[assembly: AssemblyDescription("The solution to exercise 4-1 from 'Murach's C# 2005' by Joel Murach")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("Mike Murach & Associates, Inc.")] +[assembly: AssemblyProduct("InvoiceTotal")] +[assembly: AssemblyCopyright("Copyright © 2006")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Setting ComVisible to false makes the types in this assembly not visible +// to COM componenets. If you need to access a type in this assembly from +// COM, set the ComVisible attribute to true on that type. +[assembly: ComVisible(false)] + +// The following GUID is for the ID of the typelib if this project is exposed to COM +[assembly: Guid("d7e81a3a-db10-47e8-9d34-9338f490ba9d")] + +// Version information for an assembly consists of the following four values: +// +// Major Version +// Minor Version +// Build Number +// Revision +// +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/invoice_total3/InvoiceTotal/Properties/Resources.Designer.cs b/invoice_total3/InvoiceTotal/Properties/Resources.Designer.cs new file mode 100644 index 0000000..1021f4b --- /dev/null +++ b/invoice_total3/InvoiceTotal/Properties/Resources.Designer.cs @@ -0,0 +1,63 @@ +//------------------------------------------------------------------------------ +// <auto-generated> +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// </auto-generated> +//------------------------------------------------------------------------------ + +namespace InvoiceTotal.Properties { + using System; + + + /// <summary> + /// A strongly-typed resource class, for looking up localized strings, etc. + /// </summary> + // This class was auto-generated by the StronglyTypedResourceBuilder + // class via a tool like ResGen or Visual Studio. + // To add or remove a member, edit your .ResX file then rerun ResGen + // with the /str option, or rebuild your VS project. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "16.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + internal class Resources { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal Resources() { + } + + /// <summary> + /// Returns the cached ResourceManager instance used by this class. + /// </summary> + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Resources.ResourceManager ResourceManager { + get { + if (object.ReferenceEquals(resourceMan, null)) { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("InvoiceTotal.Properties.Resources", typeof(Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// <summary> + /// Overrides the current thread's CurrentUICulture property for all + /// resource lookups using this strongly typed resource class. + /// </summary> + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Globalization.CultureInfo Culture { + get { + return resourceCulture; + } + set { + resourceCulture = value; + } + } + } +} diff --git a/invoice_total3/InvoiceTotal/Properties/Resources.resx b/invoice_total3/InvoiceTotal/Properties/Resources.resx new file mode 100644 index 0000000..ffecec8 --- /dev/null +++ b/invoice_total3/InvoiceTotal/Properties/Resources.resx @@ -0,0 +1,117 @@ +<?xml version="1.0" encoding="utf-8"?> +<root> + <!-- + Microsoft ResX Schema + + Version 2.0 + + The primary goals of this format is to allow a simple XML format + that is mostly human readable. The generation and parsing of the + various data types are done through the TypeConverter classes + associated with the data types. + + Example: + + ... ado.net/XML headers & schema ... + <resheader name="resmimetype">text/microsoft-resx</resheader> + <resheader name="version">2.0</resheader> + <resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader> + <resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader> + <data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data> + <data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data> + <data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64"> + <value>[base64 mime encoded serialized .NET Framework object]</value> + </data> + <data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> + <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value> + <comment>This is a comment</comment> + </data> + + There are any number of "resheader" rows that contain simple + name/value pairs. + + Each data row contains a name, and value. The row also contains a + type or mimetype. Type corresponds to a .NET class that support + text/value conversion through the TypeConverter architecture. + Classes that don't support this are serialized and stored with the + mimetype set. + + The mimetype is used for serialized objects, and tells the + ResXResourceReader how to depersist the object. This is currently not + extensible. For a given mimetype the value must be set accordingly: + + Note - application/x-microsoft.net.object.binary.base64 is the format + that the ResXResourceWriter will generate, however the reader can + read any of the formats listed below. + + mimetype: application/x-microsoft.net.object.binary.base64 + value : The object must be serialized with + : System.Serialization.Formatters.Binary.BinaryFormatter + : and then encoded with base64 encoding. + + mimetype: application/x-microsoft.net.object.soap.base64 + value : The object must be serialized with + : System.Runtime.Serialization.Formatters.Soap.SoapFormatter + : and then encoded with base64 encoding. + + mimetype: application/x-microsoft.net.object.bytearray.base64 + value : The object must be serialized into a byte array + : using a System.ComponentModel.TypeConverter + : and then encoded with base64 encoding. + --> + <xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"> + <xsd:element name="root" msdata:IsDataSet="true"> + <xsd:complexType> + <xsd:choice maxOccurs="unbounded"> + <xsd:element name="metadata"> + <xsd:complexType> + <xsd:sequence> + <xsd:element name="value" type="xsd:string" minOccurs="0" /> + </xsd:sequence> + <xsd:attribute name="name" type="xsd:string" /> + <xsd:attribute name="type" type="xsd:string" /> + <xsd:attribute name="mimetype" type="xsd:string" /> + </xsd:complexType> + </xsd:element> + <xsd:element name="assembly"> + <xsd:complexType> + <xsd:attribute name="alias" type="xsd:string" /> + <xsd:attribute name="name" type="xsd:string" /> + </xsd:complexType> + </xsd:element> + <xsd:element name="data"> + <xsd:complexType> + <xsd:sequence> + <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> + <xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" /> + </xsd:sequence> + <xsd:attribute name="name" type="xsd:string" msdata:Ordinal="1" /> + <xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" /> + <xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" /> + </xsd:complexType> + </xsd:element> + <xsd:element name="resheader"> + <xsd:complexType> + <xsd:sequence> + <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> + </xsd:sequence> + <xsd:attribute name="name" type="xsd:string" use="required" /> + </xsd:complexType> + </xsd:element> + </xsd:choice> + </xsd:complexType> + </xsd:element> + </xsd:schema> + <resheader name="resmimetype"> + <value>text/microsoft-resx</value> + </resheader> + <resheader name="version"> + <value>2.0</value> + </resheader> + <resheader name="reader"> + <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> + </resheader> + <resheader name="writer"> + <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> + </resheader> +</root> \ No newline at end of file diff --git a/invoice_total3/InvoiceTotal/Properties/Settings.Designer.cs b/invoice_total3/InvoiceTotal/Properties/Settings.Designer.cs new file mode 100644 index 0000000..8525954 --- /dev/null +++ b/invoice_total3/InvoiceTotal/Properties/Settings.Designer.cs @@ -0,0 +1,26 @@ +//------------------------------------------------------------------------------ +// <auto-generated> +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// </auto-generated> +//------------------------------------------------------------------------------ + +namespace InvoiceTotal.Properties { + + + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "16.0.0.0")] + internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase { + + private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings()))); + + public static Settings Default { + get { + return defaultInstance; + } + } + } +} diff --git a/invoice_total3/InvoiceTotal/Properties/Settings.settings b/invoice_total3/InvoiceTotal/Properties/Settings.settings new file mode 100644 index 0000000..abf36c5 --- /dev/null +++ b/invoice_total3/InvoiceTotal/Properties/Settings.settings @@ -0,0 +1,7 @@ +<?xml version='1.0' encoding='utf-8'?> +<SettingsFile xmlns="http://schemas.microsoft.com/VisualStudio/2004/01/settings" CurrentProfile="(Default)"> + <Profiles> + <Profile Name="(Default)" /> + </Profiles> + <Settings /> +</SettingsFile> diff --git a/invoice_total3/InvoiceTotal/app.config b/invoice_total3/InvoiceTotal/app.config new file mode 100644 index 0000000..99dca75 --- /dev/null +++ b/invoice_total3/InvoiceTotal/app.config @@ -0,0 +1,3 @@ +<?xml version="1.0"?> +<configuration> +<startup><supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.8"/></startup></configuration> diff --git a/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe new file mode 100644 index 0000000..d59aa71 --- /dev/null +++ b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe Binary files differdiff --git a/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe.config b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe.config new file mode 100644 index 0000000..99dca75 --- /dev/null +++ b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe.config @@ -0,0 +1,3 @@ +<?xml version="1.0"?> +<configuration> +<startup><supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.8"/></startup></configuration> diff --git a/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.pdb b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.pdb new file mode 100644 index 0000000..32609a8 --- /dev/null +++ b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.pdb Binary files differdiff --git a/invoice_total3/InvoiceTotal/frmInvoiceTotal.Designer.cs b/invoice_total3/InvoiceTotal/frmInvoiceTotal.Designer.cs new file mode 100644 index 0000000..04a8425 --- /dev/null +++ b/invoice_total3/InvoiceTotal/frmInvoiceTotal.Designer.cs @@ -0,0 +1,211 @@ +namespace InvoiceTotal +{ + partial class frmInvoiceTotal + { + /// <summary> + /// Required designer variable. + /// </summary> + private System.ComponentModel.IContainer components = null; + + /// <summary> + /// Clean up any resources being used. + /// </summary> + /// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param> + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// <summary> + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// </summary> + private void InitializeComponent() + { + this.label1 = new System.Windows.Forms.Label(); + this.label2 = new System.Windows.Forms.Label(); + this.label3 = new System.Windows.Forms.Label(); + this.label4 = new System.Windows.Forms.Label(); + this.label5 = new System.Windows.Forms.Label(); + this.label6 = new System.Windows.Forms.Label(); + this.label7 = new System.Windows.Forms.Label(); + this.txtSubtotal = new System.Windows.Forms.TextBox(); + this.btnCalculate = new System.Windows.Forms.Button(); + this.btnExit = new System.Windows.Forms.Button(); + this.txtDiscountPercent = new System.Windows.Forms.TextBox(); + this.txtDiscountAmount = new System.Windows.Forms.TextBox(); + this.txtTotal = new System.Windows.Forms.TextBox(); + this.SuspendLayout(); + // + // label1 + // + this.label1.AutoSize = true; + this.label1.Location = new System.Drawing.Point(20, 12); + this.label1.Name = "label1"; + this.label1.Size = new System.Drawing.Size(49, 13); + this.label1.TabIndex = 0; + this.label1.Text = "&Subtotal:"; + this.label1.TextAlign = System.Drawing.ContentAlignment.MiddleLeft; + // + // label2 + // + this.label2.AutoSize = true; + this.label2.Location = new System.Drawing.Point(20, 38); + this.label2.Name = "label2"; + this.label2.Size = new System.Drawing.Size(92, 13); + this.label2.TabIndex = 1; + this.label2.Text = "Discount Percent:"; + this.label2.TextAlign = System.Drawing.ContentAlignment.MiddleLeft; + // + // label3 + // + this.label3.AutoSize = true; + this.label3.Location = new System.Drawing.Point(21, 65); + this.label3.Name = "label3"; + this.label3.Size = new System.Drawing.Size(91, 13); + this.label3.TabIndex = 2; + this.label3.Text = "Discount Amount:"; + this.label3.TextAlign = System.Drawing.ContentAlignment.MiddleLeft; + // + // label4 + // + this.label4.AutoSize = true; + this.label4.Location = new System.Drawing.Point(21, 91); + this.label4.Name = "label4"; + this.label4.Size = new System.Drawing.Size(34, 13); + this.label4.TabIndex = 3; + this.label4.Text = "Total:"; + this.label4.TextAlign = System.Drawing.ContentAlignment.MiddleLeft; + // + // label5 + // + this.label5.AutoSize = true; + this.label5.Location = new System.Drawing.Point(128, 40); + this.label5.Name = "label5"; + this.label5.Size = new System.Drawing.Size(0, 13); + this.label5.TabIndex = 4; + this.label5.TextAlign = System.Drawing.ContentAlignment.MiddleLeft; + // + // label6 + // + this.label6.AutoSize = true; + this.label6.Location = new System.Drawing.Point(128, 70); + this.label6.Name = "label6"; + this.label6.Size = new System.Drawing.Size(0, 13); + this.label6.TabIndex = 5; + this.label6.TextAlign = System.Drawing.ContentAlignment.MiddleLeft; + // + // label7 + // + this.label7.AutoSize = true; + this.label7.Location = new System.Drawing.Point(128, 101); + this.label7.Name = "label7"; + this.label7.Size = new System.Drawing.Size(0, 13); + this.label7.TabIndex = 6; + this.label7.TextAlign = System.Drawing.ContentAlignment.MiddleLeft; + // + // txtSubtotal + // + this.txtSubtotal.Location = new System.Drawing.Point(115, 9); + this.txtSubtotal.Name = "txtSubtotal"; + this.txtSubtotal.Size = new System.Drawing.Size(100, 20); + this.txtSubtotal.TabIndex = 1; + // + // btnCalculate + // + this.btnCalculate.Location = new System.Drawing.Point(53, 122); + this.btnCalculate.Name = "btnCalculate"; + this.btnCalculate.Size = new System.Drawing.Size(75, 23); + this.btnCalculate.TabIndex = 2; + this.btnCalculate.Text = "&Calculate"; + this.btnCalculate.Click += new System.EventHandler(this.btnCalculate_Click); + // + // btnExit + // + this.btnExit.DialogResult = System.Windows.Forms.DialogResult.Cancel; + this.btnExit.Location = new System.Drawing.Point(140, 122); + this.btnExit.Name = "btnExit"; + this.btnExit.Size = new System.Drawing.Size(75, 23); + this.btnExit.TabIndex = 3; + this.btnExit.Text = "E&xit"; + this.btnExit.Click += new System.EventHandler(this.btnExit_Click); + // + // txtDiscountPercent + // + this.txtDiscountPercent.Location = new System.Drawing.Point(115, 35); + this.txtDiscountPercent.Name = "txtDiscountPercent"; + this.txtDiscountPercent.ReadOnly = true; + this.txtDiscountPercent.Size = new System.Drawing.Size(100, 20); + this.txtDiscountPercent.TabIndex = 10; + this.txtDiscountPercent.TabStop = false; + // + // txtDiscountAmount + // + this.txtDiscountAmount.Location = new System.Drawing.Point(115, 62); + this.txtDiscountAmount.Name = "txtDiscountAmount"; + this.txtDiscountAmount.ReadOnly = true; + this.txtDiscountAmount.Size = new System.Drawing.Size(100, 20); + this.txtDiscountAmount.TabIndex = 11; + this.txtDiscountAmount.TabStop = false; + // + // txtTotal + // + this.txtTotal.Location = new System.Drawing.Point(115, 88); + this.txtTotal.Name = "txtTotal"; + this.txtTotal.ReadOnly = true; + this.txtTotal.Size = new System.Drawing.Size(100, 20); + this.txtTotal.TabIndex = 12; + this.txtTotal.TabStop = false; + // + // frmInvoiceTotal + // + this.AcceptButton = this.btnCalculate; + this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); + this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; + this.CancelButton = this.btnExit; + this.ClientSize = new System.Drawing.Size(237, 159); + this.Controls.Add(this.txtTotal); + this.Controls.Add(this.txtDiscountAmount); + this.Controls.Add(this.txtDiscountPercent); + this.Controls.Add(this.btnExit); + this.Controls.Add(this.btnCalculate); + this.Controls.Add(this.txtSubtotal); + this.Controls.Add(this.label7); + this.Controls.Add(this.label6); + this.Controls.Add(this.label5); + this.Controls.Add(this.label4); + this.Controls.Add(this.label3); + this.Controls.Add(this.label2); + this.Controls.Add(this.label1); + this.Name = "frmInvoiceTotal"; + this.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen; + this.Text = "Invoice Total"; + this.ResumeLayout(false); + this.PerformLayout(); + + } + + #endregion + + private System.Windows.Forms.Label label1; + private System.Windows.Forms.Label label2; + private System.Windows.Forms.Label label3; + private System.Windows.Forms.Label label4; + private System.Windows.Forms.Label label5; + private System.Windows.Forms.Label label6; + private System.Windows.Forms.Label label7; + private System.Windows.Forms.TextBox txtSubtotal; + private System.Windows.Forms.Button btnCalculate; + private System.Windows.Forms.Button btnExit; + private System.Windows.Forms.TextBox txtDiscountPercent; + private System.Windows.Forms.TextBox txtDiscountAmount; + private System.Windows.Forms.TextBox txtTotal; + } +} + diff --git a/invoice_total3/InvoiceTotal/frmInvoiceTotal.cs b/invoice_total3/InvoiceTotal/frmInvoiceTotal.cs new file mode 100644 index 0000000..94edf91 --- /dev/null +++ b/invoice_total3/InvoiceTotal/frmInvoiceTotal.cs @@ -0,0 +1,59 @@ +using System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Data; +using System.Drawing; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Windows.Forms; + +namespace InvoiceTotal +{ + public partial class frmInvoiceTotal : Form + { + public frmInvoiceTotal() + { + InitializeComponent(); + } + + private void btnCalculate_Click(object sender, EventArgs e) + { + try { + if (txtSubtotal.Text == "") { + MessageBox.Show("Please enter a subtotal", + "Entry Error"); + return; + } + decimal subtotal = Decimal.Parse(txtSubtotal.Text); + if (subtotal <= 0 || subtotal >= 10000) { + MessageBox.Show("The subtotal must be in the " + + "range of 1 to 9999", "Entry Error"); + return; + } + decimal discountPercent = .25m; + decimal discountAmount = subtotal * discountPercent; + decimal invoiceTotal = subtotal - discountAmount; + + discountAmount = Math.Round(discountAmount, 2); + invoiceTotal = Math.Round(invoiceTotal, 2); + + txtDiscountPercent.Text = discountPercent.ToString("p1"); + txtDiscountAmount.Text = discountAmount.ToString(); + txtTotal.Text = invoiceTotal.ToString(); + txtSubtotal.Focus(); + } + catch { + MessageBox.Show( + "Please enter a valid subtotal for the " + + "subtotal field.", "Entry Error"); + } + + } + + private void btnExit_Click(object sender, EventArgs e) + { + this.Close(); + } + } +} \ No newline at end of file diff --git a/invoice_total3/InvoiceTotal/frmInvoiceTotal.resx b/invoice_total3/InvoiceTotal/frmInvoiceTotal.resx new file mode 100644 index 0000000..c7e0d4b --- /dev/null +++ b/invoice_total3/InvoiceTotal/frmInvoiceTotal.resx @@ -0,0 +1,120 @@ +<?xml version="1.0" encoding="utf-8"?> +<root> + <!-- + Microsoft ResX Schema + + Version 2.0 + + The primary goals of this format is to allow a simple XML format + that is mostly human readable. The generation and parsing of the + various data types are done through the TypeConverter classes + associated with the data types. + + Example: + + ... ado.net/XML headers & schema ... + <resheader name="resmimetype">text/microsoft-resx</resheader> + <resheader name="version">2.0</resheader> + <resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader> + <resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader> + <data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data> + <data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data> + <data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64"> + <value>[base64 mime encoded serialized .NET Framework object]</value> + </data> + <data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> + <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value> + <comment>This is a comment</comment> + </data> + + There are any number of "resheader" rows that contain simple + name/value pairs. + + Each data row contains a name, and value. The row also contains a + type or mimetype. Type corresponds to a .NET class that support + text/value conversion through the TypeConverter architecture. + Classes that don't support this are serialized and stored with the + mimetype set. + + The mimetype is used for serialized objects, and tells the + ResXResourceReader how to depersist the object. This is currently not + extensible. For a given mimetype the value must be set accordingly: + + Note - application/x-microsoft.net.object.binary.base64 is the format + that the ResXResourceWriter will generate, however the reader can + read any of the formats listed below. + + mimetype: application/x-microsoft.net.object.binary.base64 + value : The object must be serialized with + : System.Runtime.Serialization.Formatters.Binary.BinaryFormatter + : and then encoded with base64 encoding. + + mimetype: application/x-microsoft.net.object.soap.base64 + value : The object must be serialized with + : System.Runtime.Serialization.Formatters.Soap.SoapFormatter + : and then encoded with base64 encoding. + + mimetype: application/x-microsoft.net.object.bytearray.base64 + value : The object must be serialized into a byte array + : using a System.ComponentModel.TypeConverter + : and then encoded with base64 encoding. + --> + <xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"> + <xsd:import namespace="http://www.w3.org/XML/1998/namespace" /> + <xsd:element name="root" msdata:IsDataSet="true"> + <xsd:complexType> + <xsd:choice maxOccurs="unbounded"> + <xsd:element name="metadata"> + <xsd:complexType> + <xsd:sequence> + <xsd:element name="value" type="xsd:string" minOccurs="0" /> + </xsd:sequence> + <xsd:attribute name="name" use="required" type="xsd:string" /> + <xsd:attribute name="type" type="xsd:string" /> + <xsd:attribute name="mimetype" type="xsd:string" /> + <xsd:attribute ref="xml:space" /> + </xsd:complexType> + </xsd:element> + <xsd:element name="assembly"> + <xsd:complexType> + <xsd:attribute name="alias" type="xsd:string" /> + <xsd:attribute name="name" type="xsd:string" /> + </xsd:complexType> + </xsd:element> + <xsd:element name="data"> + <xsd:complexType> + <xsd:sequence> + <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> + <xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" /> + </xsd:sequence> + <xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" /> + <xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" /> + <xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" /> + <xsd:attribute ref="xml:space" /> + </xsd:complexType> + </xsd:element> + <xsd:element name="resheader"> + <xsd:complexType> + <xsd:sequence> + <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" /> + </xsd:sequence> + <xsd:attribute name="name" type="xsd:string" use="required" /> + </xsd:complexType> + </xsd:element> + </xsd:choice> + </xsd:complexType> + </xsd:element> + </xsd:schema> + <resheader name="resmimetype"> + <value>text/microsoft-resx</value> + </resheader> + <resheader name="version"> + <value>2.0</value> + </resheader> + <resheader name="reader"> + <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> + </resheader> + <resheader name="writer"> + <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> + </resheader> +</root> \ No newline at end of file diff --git a/invoice_total3/InvoiceTotal/obj/Debug/.NETFramework,Version=v4.8.AssemblyAttributes.cs b/invoice_total3/InvoiceTotal/obj/Debug/.NETFramework,Version=v4.8.AssemblyAttributes.cs new file mode 100644 index 0000000..3cf0af3 --- /dev/null +++ b/invoice_total3/InvoiceTotal/obj/Debug/.NETFramework,Version=v4.8.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// <autogenerated /> +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETFramework,Version=v4.8", FrameworkDisplayName = ".NET Framework 4.8")] diff --git a/invoice_total3/InvoiceTotal/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache b/invoice_total3/InvoiceTotal/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache new file mode 100644 index 0000000..4ea7442 --- /dev/null +++ b/invoice_total3/InvoiceTotal/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache Binary files differdiff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.Properties.Resources.resources b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.Properties.Resources.resources new file mode 100644 index 0000000..6c05a97 --- /dev/null +++ b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.Properties.Resources.resources Binary files differdiff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.AssemblyReference.cache b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.AssemblyReference.cache new file mode 100644 index 0000000..b3072eb --- /dev/null +++ b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.AssemblyReference.cache Binary files differdiff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.CoreCompileInputs.cache b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..6621da8 --- /dev/null +++ b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +ddd884c7cc4fbc526b3c79f739672bb101481755939ee83704695fd42ac85f71 diff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.FileListAbsolute.txt b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..e18563a --- /dev/null +++ b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.FileListAbsolute.txt @@ -0,0 +1,10 @@ +C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.csproj.AssemblyReference.cache +C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.frmInvoiceTotal.resources +C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.Properties.Resources.resources +C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.csproj.GenerateResource.cache +C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.csproj.CoreCompileInputs.cache +C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\bin\Debug\InvoiceTotal.exe.config +C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\bin\Debug\InvoiceTotal.exe +C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\bin\Debug\InvoiceTotal.pdb +C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.exe +C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.pdb diff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.GenerateResource.cache b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.GenerateResource.cache new file mode 100644 index 0000000..2f304b5 --- /dev/null +++ b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.GenerateResource.cache Binary files differdiff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.exe b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.exe new file mode 100644 index 0000000..d59aa71 --- /dev/null +++ b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.exe Binary files differdiff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.frmInvoiceTotal.resources b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.frmInvoiceTotal.resources new file mode 100644 index 0000000..6c05a97 --- /dev/null +++ b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.frmInvoiceTotal.resources Binary files differdiff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.pdb b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.pdb new file mode 100644 index 0000000..32609a8 --- /dev/null +++ b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.pdb Binary files differ |