public static Tuple <string, decimal, string> NaplatiParking(string grad, _Opazanje opazanje, int idStavke, int idVrstePlacanja, int kolicina, string poziv, int tipPrintera, int idAplikacije) { decimal iznos; try { using (PazigradDataContext db = new PazigradDataContext(Sistem.ConnectionString(grad, idAplikacije))) { //todo zone RACUNI_STAVKE_OPI st = db.RACUNI_STAVKE_OPIs.First(i => i.IDOpisaStavke == idStavke && i.IDRedarstva == 4); if (st == null) { return(new Tuple <string, decimal, string>("", 0, "Ne postoji opis stavke računa!")); } iznos = (decimal)st.Iznos * kolicina; bool uplatnica; string vrsta = Naplata.VrstaPlacanja(grad, idVrstePlacanja, idAplikacije, out uplatnica); _PoslovniProstor pp = PoslovniProstor.DohvatiPoslovniProstor(grad, 4, idAplikacije); if (pp == null) { return(new Tuple <string, decimal, string>("", 0, "Niste definirali poslovni prostor!")); } //provjera poziva if (!string.IsNullOrEmpty(poziv)) { Tuple <string, string> kontrola = Sustav.ProvjeraPoziva(grad, poziv, st.Iznos.Value, 4, idAplikacije); if (!string.IsNullOrEmpty(kontrola.Item1)) { return(new Tuple <string, decimal, string>("", 0, kontrola.Item1)); } poziv = kontrola.Item2; } _Djelatnik djel = Korisnici.DohvatiDjelatnika(grad, (int)opazanje.IDDjelatnika, idAplikacije); List <_Stavka> stavke = new List <_Stavka>(); decimal ukupno = (decimal)(kolicina * st.Iznos); decimal osnovica = Math.Round(ukupno / ((decimal)(100 + pp.PDV) / 100), 2); decimal pdv = Math.Round(osnovica * pp.PDV / 100, 2); _Stavka nova = new _Stavka(0, 0, st.IDOpisaStavke, st.NazivOpisaStavke, st.Lezarina, kolicina, (decimal)st.Iznos, pdv, osnovica, ukupno, pp.PDV, ""); stavke.Add(nova); int blagajna = 1; _Racun novi = new _Racun(0, -1, null, idVrstePlacanja, null, null, vrsta, "", (int)opazanje.IDDjelatnika, djel.ImeNaRacunu, 4, DateTime.Now, 0, 0, pdv, osnovica, ukupno, pp.PDV, djel.OIB ?? "", blagajna, "", false, "", string.IsNullOrEmpty(opazanje.Registracija)? "":opazanje.Registracija + " (" + opazanje.Drzava + ")", true, "", "", "", DateTime.Now, pp.Oznaka, poziv, "", "", opazanje.Registracija + " (" + opazanje.Drzava + ")", false, false, false, false, "", stavke, new List <_Osoba>()); if (opazanje.IDOpazanja == 0) { return(new Tuple <string, decimal, string>(Naplata.NaplatiParking(grad, novi, uplatnica, idAplikacije, tipPrintera), iznos, "")); } PARKING_OPAZANJA op = db.PARKING_OPAZANJAs.First(i => i.IDOpazanja == opazanje.IDOpazanja); opazanje.IDLokacije = op.IDLokacije; op.IDStatusa = st.IDStatusa; op.Kaznjen = true; op.Iznos = st.Iznos; opazanje.IDStatusa = st.IDStatusa; //ako je naplata (0) po satu preskoči ovo if (st.IDStatusa != 0) { // TODO izbacio jer je suvišno nakon promjene? /* * int idPrekrsaja = DodajPostupanje(grad, opazanje, iznos, idAplikacije);//todo iznos kazne * * if (idPrekrsaja == -1) * { * iznos = 0; * return ""; * } */ novi.IDReference = op.IDOpazanja; } db.SubmitChanges(); return(new Tuple <string, decimal, string>(Naplata.NaplatiParking(grad, novi, uplatnica, idAplikacije, tipPrintera), iznos, "")); //;Naplata.NaplatiParking(grad, novi, uplatnica, idAplikacije, tipPrintera); //todo dodati record u akcije } } catch (Exception ex) { Sustav.SpremiGresku(grad, ex, idAplikacije, "NAPLATA PARKINGA"); iznos = 0; return(new Tuple <string, decimal, string>("", 0, ex.Message)); } }