Example #1
0
        public FormVigneto(FormHome home)
        {
            InitializeComponent();
            this.home = home;

            DbVigneto w = new DbVigneto();

            // dichiarazione e definizione di variabili ( list<string> e array[int])
            List <string> NomiVigneti = new List <string>();

            NomiVigneti = w.Select("nome");

            List <string> NrVitiMorte = new List <string>();

            NrVitiMorte = w.Select("nrvitimorte");

            List <string> Id = new List <string>();

            Id = w.Select("id");

            // ciclo per aggiungere tutti gli item e i subitem alla listview
            for (int i = 0; i < Id.Count; i++)
            {
                ListViewItem entryListItem = listViewDettagli.Items.Add(NomiVigneti[i]);
                entryListItem.UseItemStyleForSubItems = true;
                ListViewItem.ListViewSubItem nrvitmorteItem = entryListItem.SubItems.Add(NrVitiMorte[i]);
                ListViewItem.ListViewSubItem id             = entryListItem.SubItems.Add(Id[i]);
            }
        }// end form
        }// end button elemina

        // evento che applica le modifiche effettuate dall'utente
        private void ButtonApplica_Click(object sender, EventArgs e)
        {
            // caso in cui l'utente voglia moidifcare entrambi gli elementi
            if (this.comboBoxNomeVigneto.Text != "" && this.numericUpDownNrViti.Value != 0)
            {
                DbVigneto w = new DbVigneto();

                // conversione dei valori da decimal a int per eseguire la sottrazione dei valori
                int nrvitimorte    = int.Parse(w.SelectElement(this.id, "nrvitimorte"));
                int vitisostituite = decimal.ToInt32(this.numericUpDownNrViti.Value);
                int viti           = nrvitimorte - vitisostituite;

                // metodo chiamato 2 volte per apportare tutte le modifiche
                w.ModifyItem(this.comboBoxNomeVigneto.Text, "nome", this.id);
                w.ModifyItem(viti, "nrvitimorte", this.id);

                // chiusura del form attuale a apertura del form precedente
                this.formvigneto.Dispose();
                FormVigneto frm = new FormVigneto(this.home);
                frm.Show();
                this.Dispose();
            }
            // caso in cui l'utente voglia modificare solo il numero di viti
            else if (this.comboBoxNomeVigneto.Text == "" && this.numericUpDownNrViti.Value != 0)
            {
                DbVigneto w = new DbVigneto();

                // conversione dei valori da decimal a int per eseguire la sottrazione dei valori
                int nrvitimorte    = int.Parse(w.SelectElement(this.id, "nrvitimorte"));
                int vitisostituite = decimal.ToInt32(this.numericUpDownNrViti.Value);
                int viti           = nrvitimorte - vitisostituite;

                // chiamata del metodo per modificare un elemento
                w.ModifyItem(viti, "nrvitimorte", this.id);

                // chiusura del form attuale a apertura del form precedente
                this.formvigneto.Dispose();
                FormVigneto frm = new FormVigneto(this.home);
                frm.Show();
                this.Dispose();
            }
            // caso in cui l'utente voglia moidifcare solo il nome del vigneto
            else if (this.comboBoxNomeVigneto.Text != "" && this.numericUpDownNrViti.Value == 0)
            {
                DbVigneto w = new DbVigneto();

                // metodo chiamato 2 volte per apportare tutte le modifiche
                w.ModifyItem(this.comboBoxNomeVigneto.Text, "nome", this.id);

                // chiusura del form attuale a apertura del form precedente
                this.formvigneto.Dispose();
                FormVigneto frm = new FormVigneto(this.home);
                frm.Show();
                this.Dispose();
            }

            // se l'utente scegli di non modificare nulla e preme il  pulsante non succede nulla
        }// end applica
        public FormHome()
        {
            InitializeComponent();

            // inizializzo una stringa che andrà a contenere i nomi dei vari elementi da poter cercare
            List <string> righe = new List <string>();

            // aggiungo i vari nomi degli elementi alla stringa
            DbVino       v = new DbVino();
            DbVigneto    w = new DbVigneto();
            DbMarmellata m = new DbMarmellata();

            righe.Add(v.NameTable());
            righe.Add(w.NameTable());
            righe.Add(m.NameTable());


            // ciclo che aggiunge al menu di scelta i vari nomi inseriti nella stringa 'righe'
            for (int i = 0; i < righe.Count; i++)
            {
                VisualizzaTabella.Items.Add(righe[i]);
            }


            //---------------------------------------------------------------------//
            // sezione per la stampa dei prodotti con maggiore priorità di vendita //
            //---------------------------------------------------------------------//

            // implementazione del visitor pattern, chiamata ai metodi che restituiranno delle liste di id ordinate in base al numero di prodotti in magazzino
            PrinterVisitor p            = new PrinterVisitor();
            List <string>  vini_p       = p.VisitVini(v);
            List <string>  marmellate_p = p.VisitMarmellate(m);
            List <string>  vigneti_p    = p.VisitVigneti(w);

            Console.WriteLine(vini_p.Count);
            // ciclo che aggiunge i 5 vini con maggiore priorità di vendita alla listview
            for (int i = 0; (i < 5) & (i < vini_p.Count); i++)
            {
                ListViewItem entryListItem = listViewPriorita.Items.Add(v.SelectElement(vini_p[i].ToString(), "nome"));
                entryListItem.UseItemStyleForSubItems = true;
                ListViewItem.ListViewSubItem quantita = entryListItem.SubItems.Add(v.SelectElement(vini_p[i].ToString(), "nrbottiglie"));
            }
            // ciclo che aggiunge i 3 vigneti con maggiore priorità di vendita alla listview
            for (int i = 0; (i < 3) & (i < vigneti_p.Count); i++)
            {
                ListViewItem entryListItem = listViewPriorita.Items.Add(w.SelectElement(vigneti_p[i].ToString(), "nome"));
                entryListItem.UseItemStyleForSubItems = true;
                ListViewItem.ListViewSubItem quantita = entryListItem.SubItems.Add(w.SelectElement(vigneti_p[i].ToString(), "nrvitimorte"));
            }
            // ciclo che aggiunge i 3 marmellate con maggiore priorità di vendita alla listview
            for (int i = 0; (i < 3) & (i < marmellate_p.Count); i++)
            {
                ListViewItem entryListItem = listViewPriorita.Items.Add(m.SelectElement(marmellate_p[i].ToString(), "frutto"));
                entryListItem.UseItemStyleForSubItems = true;
                ListViewItem.ListViewSubItem quantita = entryListItem.SubItems.Add(m.SelectElement(marmellate_p[i].ToString(), "nrbarattoli"));
            }
        }// end form
Example #4
0
        public FormAggiungiVino(FormVino formvino, FormHome home)
        {
            InitializeComponent();

            this.formvino = formvino;
            this.home     = home;

            DbVino    v = new DbVino();
            DbVigneto w = new DbVigneto();

            // liste di stringhe per inserire nei vari combobox valori già esistenti
            List <string> NomiVini = new List <string>();

            NomiVini = v.SelectDistinct("nome");

            List <string> TipologiaVini = new List <string>();

            TipologiaVini = v.SelectDistinct("tipologia");

            List <string> VignetoVini = new List <string>();

            VignetoVini = w.SelectDistinct("nome");

            List <string> NrBottiglieVini = new List <string>();

            NrBottiglieVini = v.SelectDistinct("nrbottiglie");

            // ciclo che aggiunge i nomi già presenti nel db nel combobox nome
            for (int i = 0; i < NomiVini.Count; i++)
            {
                comboBoxNome.Items.Add(NomiVini[i]);
            }

            // ciclo che aggiunge le tipologie già presenti nel db nel combobox tipologia
            for (int i = 0; i < TipologiaVini.Count; i++)
            {
                comboBoxTipologia.Items.Add(TipologiaVini[i]);
            }

            // ciclo che aggiunge i vari vigneti presenti nel db nel combobox vigneti
            for (int i = 0; i < VignetoVini.Count; i++)
            {
                comboBoxVigneto.Items.Add(VignetoVini[i]);
            }

            // ciclo che aggiunge i vari numeri di bottiglie al combobox
            // anche se numerico viene utilizzato un combobox perchè spesso si produce lo stesso quantitativo
            // di bottiglie per vini diversi e il numeric updown non permette di selezionare quantità già presenti
            for (int i = 0; i < NrBottiglieVini.Count; i++)
            {
                comboBoxBottiglie.Items.Add(NrBottiglieVini[i]);
            }
        }// end FormAggiungiVino
        }// end form

        private void ButtonElimina_Click(object sender, EventArgs e)
        {
            // metodo per eliminare un elemento dal database
            DbVigneto w = new DbVigneto();

            w.DeleteItem(this.id);

            // chiusura del form attuale a apertura del form precedente
            this.formvigneto.Dispose();
            FormVigneto frm = new FormVigneto(this.home);

            frm.Show();
            this.Dispose();
        }// end button elemina
        public FormModificaVigneto(ListViewItem.ListViewSubItem id, FormVigneto formvigneto, FormHome home)
        {
            InitializeComponent();
            this.id          = id;
            this.formvigneto = formvigneto;
            this.home        = home;

            DbVigneto w = new DbVigneto();

            // lettura dal db dei dati necessari
            // stampa dei dati tramite textbox
            textBox1.Text = w.SelectElement(id, "nome");

            textBox2.Text = w.SelectElement(id, "nrvitimorte");
        }// end form
Example #7
0
        public List <string> VisitVigneti(DbVigneto v)
        {
            List <string> NrViti = new List <string>();

            NrViti = v.Select("nrvitimorte");


            List <string> Id = new List <string>();

            Id = v.Select("id");

            OrdinaLista(NrViti, Id);

            // da modificare. messo solamente per togliere l'errore
            return(Id);
        }
        }// end form

        // salva le modifiche e chiude il form attuale andando a riaprire il form precedente
        private void ButtonAggiungi_Click(object sender, EventArgs e)
        {
            if (this.comboBoxNome.Text != "")
            {
                // creazione di un oggetto di tipo vigneto in modo da passare alla query un singolo oggetto e non
                // più valori
                Vigneto vigneto = new Vigneto();
                vigneto.SetNome(this.comboBoxNome.Text);
                vigneto.SetNrVitiMorte(decimal.ToInt16(this.numericUpDownNrVitiMorte.Value));

                DbVigneto w = new DbVigneto();
                w.AddItem(vigneto);

                // chiusura del form attuale a apertura del form precedente
                this.formvigneto.Dispose();
                FormVigneto frm = new FormVigneto(this.formhome);
                frm.Show();
                this.Dispose();
            } // end if
        }     // end Button aggiungi click
        public FormAggiungiVigneto(FormVigneto formvigneto, FormHome formhome)
        {
            InitializeComponent();
            this.formvigneto = formvigneto;
            this.formhome    = formhome;

            DbVigneto w = new DbVigneto();

            // dichiarazione e definizione di variabili ( list<string> e array[int])
            List <string> NomiVigneti = new List <string>();

            NomiVigneti = w.SelectDistinct("nome");

            List <string> NrVitiMorte = new List <string>();

            NrVitiMorte = w.SelectDistinct("nrvitimorte");

            // ciclo che aggiunge al combobox i vari nomi dei vigneti
            for (int i = 0; i < NomiVigneti.Count; i++)
            {
                comboBoxNome.Items.Add(NomiVigneti[i]);
            }
        }// end form