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
        }// end button elimina

        // evento in cui viene premuto il bottone con "applica modifiche"
        private void ButtonApplica_Click(object sender, EventArgs e)
        {
            // caso in cui sono stati modificati entrambi gli elementio modificabili
            if (this.comboBoxNomeVino.Text != "" && this.numericUpDownNrBottiglie.Value != 0)
            {
                DbVino v = new DbVino();

                // conversione di valori da string a int e da decimal a int per eseguire la sottrazione delle bottilgie vendute dal totale
                int nrbottiglie      = int.Parse(v.SelectElement(this.id, "nrbottiglie"));
                int BottiglieVendute = decimal.ToInt32(this.numericUpDownNrBottiglie.Value);
                int NuovoNrBottiglie = nrbottiglie - BottiglieVendute;

                // metodo chiamato 2 volte per apportare tutte le modifiche
                v.ModifyItem(this.comboBoxNomeVino.Text, "nome", this.id);
                v.ModifyItem(NuovoNrBottiglie, "nrbottiglie", this.id);

                // chiudo e riarpo i il form recedente in modo da visualizzare le modifiche
                this.formvino.Dispose();
                FormVino frm = new FormVino(this.home);
                frm.Show();
                this.Dispose();
            }
            // caso in cui l'utente desideri modificare solo il nome
            else if (this.comboBoxNomeVino.Text != "" && this.numericUpDownNrBottiglie.Value == 0)
            {
                // metodo per modifacare un elemento nel db
                DbVino v = new DbVino();
                v.ModifyItem(this.comboBoxNomeVino.Text, "nome", this.id);

                // chiudo e riarpo i il form recedente in modo da visualizzare le modifiche
                this.formvino.Dispose();
                FormVino frm = new FormVino(this.home);
                frm.Show();
                this.Dispose();
            }
            // caso in cui l'utente deisideri modificare solo il numero di bottiglie
            else if (this.comboBoxNomeVino.Text == "" && this.numericUpDownNrBottiglie.Value != 0)
            {
                DbVino v = new DbVino();
                Console.WriteLine("if3");

                // conversione di valori da string a int e da decimal a int per eseguire la sottrazione delle bottilgie vendute dal totale
                int nrbottiglie      = int.Parse(v.SelectElement(this.id, "nrbottiglie"));
                int BottiglieVendute = decimal.ToInt32(this.numericUpDownNrBottiglie.Value);
                int NuovoNrBottiglie = nrbottiglie - BottiglieVendute;

                // metodo per modifacare un elemento nel db
                v.ModifyItem(NuovoNrBottiglie, "nrbottiglie", this.id);

                // chiudo e riarpo i il form recedente in modo da visualizzare le modifiche
                this.formvino.Dispose();
                FormVino frm = new FormVino(this.home);
                frm.Show();
                this.Dispose();
            }

            // nel caso in cui non è stato modificato nessun valore non succede nulla
        }// end applica modifiche
        public FormModificaVino(ListViewItem.ListViewSubItem id, FormVino formvino, FormHome home)
        {
            InitializeComponent();

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

            DbVino v = new DbVino();

            // lettura dal databese dei dati necessari e passaggio ai vari textbox che li stamperanno a video
            textBox1.Text = v.SelectElement(id, "nome");

            textBox2.Text = v.SelectElement(id, "anno");

            textBox3.Text = v.SelectElement(id, "tipologia");

            textBox4.Text = v.SelectElement(id, "vigneto");

            textBox5.Text = v.SelectElement(id, "nrbottiglie");
        }// end form