Example #1
0
        private void button1_Click_1(object sender, EventArgs e)
        {
            //bind datagrid with datatable
            var table = DeskQuote.getAllQuotes();

            if (table.Rows.Count > 0)
            {
                ViewAllQuotes viewQuotes = new ViewAllQuotes(table);
                viewQuotes.Tag = this;
                viewQuotes.Show(this);
                Hide();
            }
            else
            {
                MessageBox.Show("Not records found", "Warning", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }
Example #2
0
        private void save_Click(object sender, EventArgs e)
        {
            try
            {
                double    width        = double.Parse(txtWidth.Text);
                double    depth        = double.Parse(txtDepth.Text);
                int       drawers      = Convert.ToInt32(numDrawers.Value);
                string    material     = cboMaterial.Text;
                string    customerName = txtCustomerName.Text;
                DateTime  dateQuote    = DateTime.Now;
                int       rushDays     = int.Parse(cboRushOption.Text.Split(' ')[1]);
                Desk      desktop      = new Desk(width, depth, drawers, material);
                DeskQuote quote        = new DeskQuote(rushDays, customerName, dateQuote, desktop);

                // Results
                double deskSize = quote.getDeskSize();

                string totalSize = quote.getDeskSize().ToString();
                string overage   = "";
                if (deskSize > 1000)
                {
                    overage = (deskSize - 1000).ToString();
                }
                string sizeCost       = quote.getSizeCost().ToString();
                string drawerCost     = quote.getDrawersPrice().ToString();
                string materialCost   = quote.getMaterialPrice().ToString();
                string shippingCost   = quote.getRushDaysPrice().ToString();
                string total          = quote.getTotalPrice().ToString();
                string materialUsed   = desktop.getMaterial();
                string shippingMethod = cboRushOption.Text;
                string customer       = quote.getCustomerName();
                string strDateQuote   = quote.getQuoteDate().ToString();

                DisplayQuote displayQuote = new DisplayQuote(totalSize, overage, sizeCost, drawerCost, materialCost, shippingCost, total, materialUsed, shippingMethod, customer, strDateQuote);


                displayQuote.Tag = quote;

                displayQuote.Show(this);
                Hide();
            }catch (Exception ex)
            {
            }
        }
Example #3
0
        private void save_Click(object sender, EventArgs e)
        {
            try
            {
                double width        = double.Parse(txtWidth.Text);
                double depth        = double.Parse(txtDepth.Text);
                int    drawers      = Convert.ToInt32(numDrawers.Value);
                string material     = cboMaterial.Text;
                string customerName = txtCustomerName.Text;

                DateTime  dateQuote = DateTime.Now;
                int       rushDays  = int.Parse(cboRushOption.Text.Split(' ')[1]);
                Desk      desktop   = new Desk(width, depth, drawers, material);
                DeskQuote quote     = new DeskQuote(rushDays, customerName, dateQuote, desktop);

                // Results
                double deskSize = quote.getDeskSize();

                string totalSize = quote.getDeskSize().ToString();
                string overage   = "";
                if (deskSize > 1000)
                {
                    overage = (deskSize - 1000).ToString();
                }
                string sizeCost       = quote.getSizeCost().ToString();
                string drawerCost     = quote.getDrawersPrice().ToString();
                string materialCost   = quote.getMaterialPrice().ToString();
                string shippingCost   = quote.getRushDaysPrice().ToString();
                string total          = quote.getTotalPrice().ToString();
                string materialUsed   = desktop.getMaterial();
                string shippingMethod = cboRushOption.Text;
                string customer       = quote.getCustomerName();
                string strDateQuote   = quote.getQuoteDate().ToString();


                string pathSave = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, @"data\quotes.json");
                string path     = Path.Combine(Path.GetDirectoryName(Application.ExecutablePath), @"data\quotes.json");
                string json     = File.ReadAllText(path);
                var    jsonObj  = JObject.Parse(json);

                //Count how many quotes are in the file and create Array with existing quotes
                var quoteArray = jsonObj.GetValue("quotes") as JArray;
                int count      = quoteArray.Count;

                //Add new quote to Dictionary
                Dictionary <string, Object> quoteData = new Dictionary <string, Object>();
                quoteData.Add("id", count + 1);
                quoteData.Add("customer", customer);

                string jsonIsoDate = JsonConvert.SerializeObject(quote.getQuoteDate());

                quoteData.Add("dateQuote", jsonIsoDate);
                quoteData.Add("costSize", sizeCost);
                quoteData.Add("totalSize", totalSize);
                quoteData.Add("sizeOverage", overage);
                quoteData.Add("drawerCost", drawerCost);
                quoteData.Add("material", materialUsed);
                quoteData.Add("materialCost", materialCost);
                quoteData.Add("shippingMethod", shippingMethod);
                quoteData.Add("shippingCost", shippingCost);
                quoteData.Add("total", total);
                List <Dictionary <String, Object> > _data = new List <Dictionary <String, Object> >();
                _data.Add(new Dictionary <String, Object>(quoteData));


                //Convert Dictionary to JsonObject
                var newJsonQuote = JsonConvert.SerializeObject(_data[0], Formatting.Indented);
                var newQuote     = JObject.Parse(newJsonQuote);
                //Add new quote to array
                quoteArray.Add(newQuote);
                jsonObj["quotes"] = quoteArray;
                //Saving file with new Json
                string newJsonResult = JsonConvert.SerializeObject(jsonObj, Formatting.Indented);
                File.WriteAllText(pathSave, newJsonResult);
                //Display quote
                DisplayQuote displayQuote = new DisplayQuote(totalSize, overage, sizeCost, drawerCost, materialCost, shippingCost, total, materialUsed, shippingMethod, customer, strDateQuote);
                displayQuote.Tag = quote;
                displayQuote.Show(this);
                Hide();
            } catch (DirectoryNotFoundException)
            {                // Let the user know that the directory did not exist.
                MessageBox.Show("Directory not found", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }catch (FormatException)
            {
                // Let the user know that the data is incorrect
                MessageBox.Show("Format error, register all data correctly", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            catch (IndexOutOfRangeException)
            {
                // Let the user know that the data is incorrect
                MessageBox.Show("Select a valid option for shipping", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            catch (JsonReaderException)
            {
                // Let the user know that the json is corrupted
                MessageBox.Show("The Json file is corrupted", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }
 private void search_Click(object sender, EventArgs e)
 {
     //bind datagrid with datatable
     dataGridSearchQuotes.DataSource = DeskQuote.getAllQuotesMaterial(desktopMaterialComboBox.Text);
 }