// JavaScript Document
  
  function ESSOX_aktualizuj(typ) {
    return eval("ESSOX_splatkyJS_" + typ + "(ESSOX_get('ESSOX_" + typ + "_cena'),ESSOX_get('ESSOX_" + typ + "_akontace'),ESSOX_get('ESSOX_" + typ + "_pocetSplatek'))");
  }

  function ESSOX_get(el) {
  return (document.getElementById(el).type=="select") ? document.getElementById(el).options[document.getElementById(el).selectedIndex].value : document.getElementById(el).value;
  }
  
  function ESSOX_maxCastka(typZbozi,akontace) {
  akontace *= 1; typZbozi *= 1; 
  switch (typZbozi) {
    case 1: switch (akontace) {case 0: max = 40000; break; case 10: max = 60000; break; case 20: max = 80000; break; case 30: case 40: case 50: case 60: case 70: max = 500000; break; default: max = false;} break;

    default: max = false;
  }
  return max;
  }
  
function setContent(el,res) {
if (document.getElementById(el).textContent) document.getElementById(el).textContent = res;
else document.getElementById(el).innerText = res;
}

function rozdilDnu(pujcDen,pujcMes,pujcRok,splDen,splMes,splRok)
{
    pujcDen = parseInt(pujcDen);
	pujcMes = parseInt(pujcMes);
	pujcRok = parseInt(pujcRok);
    splDen = parseInt(splDen);
	splMes = parseInt(splMes);
	splRok = parseInt(splRok);
    if (pujcMes <= 2) { pujcRok -=1; pujcMes +=12; }
	a = Math.floor( pujcRok/100 );
	b = 2 - a + Math.floor( a/4 );
	JulianDayPujcka = Math.floor( 365.25 * ( pujcRok + 4716 )) + Math.floor( 30.6001 * ( pujcMes + 1 )) + pujcDen + b;
	if (splMes <= 2) { splRok -=1; splMes +=12; }
	a = Math.floor( splRok/100 );
	b = 2 - a + Math.floor( a/4 );
	JulianDaySplatka = Math.floor( 365.25 * ( splRok + 4716 )) + Math.floor( 30.6001 * ( splMes + 1 )) + splDen + b;  		 
    return ( JulianDaySplatka - JulianDayPujcka );  
} 

function fhodnota(pujcka,rok,tsplatka,tcas,sazba)
{
	soucet = 0;
    for (i=0; i<tsplatka.length; i++)
    {
       soucet += (tsplatka[i])/Math.pow((1+sazba),tcas[i]/rok);        
    }
    return(soucet - pujcka);
}

function ESSOXpocitejRPSN(pocetSplatek,pujcka,splatka) 
{  
	rok = 365;
  pujcDen = 1;
  pujcMes = new Date(); pujcMes = parseInt(pujcMes.getMonth()+1);
  pujcRok = new Date(); pujcRok = parseInt(pujcRok.getFullYear());
	
	aSplatka = new Array();
	cas = new Array();
	for (i=(pujcMes+1); i<pocetSplatek+(pujcMes+1); i++)
	{
	  aSplatka[(i-(pujcMes+1))] = splatka;
    splDen = 15;
    splMes = (i%12) ? i%12 : 12;
    splRok = pujcRok;
    splRok += (i>12) ? Math.floor((i-1)/12) : 0;
    cas[(i-(pujcMes+1))] = rozdilDnu(pujcDen,pujcMes,pujcRok,splDen,splMes,splRok); 
    } 
		
    rozdilstr = 0;
    odhad1 = 0; 
    odhad2 = 10.001;  // i.e. predpoklada se, ze koren lezi mezi 0% a 1000%
    fhodnota1 = fhodnota(pujcka,rok,aSplatka,cas,odhad1);
    fhodnota2 = fhodnota(pujcka,rok,aSplatka,cas,odhad2);
    if (fhodnota1*fhodnota2<0) 
    {
	        odhadstr = (odhad1 + odhad2)/2;
        	fhodnotastr = fhodnota(pujcka,rok,aSplatka,cas,odhadstr);
        
        	do {
			   if ((fhodnota1*fhodnotastr)>0) odhad1 = odhadstr;
   		       if ((fhodnota2*fhodnotastr)>0) odhad2 = odhadstr;
        	   fhodnota1 = fhodnota(pujcka,rok,aSplatka,cas,odhad1);
        	   fhodnota2 = fhodnota(pujcka,rok,aSplatka,cas,odhad2);
        	   rozdilstr = Math.abs(odhadstr - (odhad1 + odhad2)/2);
               odhadstr = (odhad1 + odhad2)/2;
               fhodnotastr = fhodnota(pujcka,rok,aSplatka,cas,odhadstr);
        	} 
        	while (rozdilstr>0.000001);    
            rpsn2 =Math.round(odhadstr*10000)/100; 
    }
    else if (fhodnota1 == 0) rpsn2 = "0";
		 else rpsn2 = "0"; 
		 
	return rpsn2;
	
}

  ESSOX_typZbozi = 1; // 1 - kola, VT, nábytek, bílá el., zahr.mechanizace; 3 - mobilní telefony; 2 - ostatní
  
  function ESSOX_splatky_standard4(castka,akontace,pocetSplatek) {
  castka = (parseInt(castka)) ? parseInt(castka) : 0; akontace = parseInt(akontace); pocetSplatek = parseInt(pocetSplatek); 
    switch (akontace) {
    case 0:
      switch (pocetSplatek) {
      case  5: koef =21.01; break; case 10: koef =10.84; break; case 15: koef = 7.49; break; case 20: koef = 5.82; break;
      case 25: koef = 4.83; break; case 30: koef = 4.16; break; case 35: koef = 3.69; break; case 40: koef = 3.34; break; 
      case 45: koef = 3.07; break; default: koef = 0; 
      } break;
    case 10:
      switch (pocetSplatek) {
      case  5: koef =18.91; break; case 10: koef = 9.76; break; case 15: koef = 6.74; break; case 20: koef = 5.24; break;
      case 25: koef = 4.34; break; case 30: koef = 3.75; break; case 35: koef = 3.32; break; case 40: koef = 3.01; break; 
      case 45: koef = 2.76; break; default: koef = 0; 
      } break; 
    case 20:
      switch (pocetSplatek) {
      case  5: koef =16.81; break; case 10: koef = 8.67; break; case 15: koef = 6.00; break; case 20: koef = 4.66; break;
      case 25: koef = 3.86; break; case 30: koef = 3.33; break; case 35: koef = 2.95; break; case 40: koef = 2.67; break; 
      case 45: koef = 2.46; break; default: koef = 0; 
      } break; 
    case 30:
      switch (pocetSplatek) {
      case  5: koef =14.71; break; case 10: koef = 7.59; break; case 15: koef = 5.25; break; case 20: koef = 4.08; break;
      case 25: koef = 3.38; break; case 30: koef = 2.91; break; case 35: koef = 2.59; break; case 40: koef = 2.34; break; 
      case 45: koef = 2.15; break; default: koef = 0; 
      } break; 
    case 40:
      switch (pocetSplatek) {
      case  5: koef =12.61; break; case 10: koef = 6.51; break; case 15: koef = 4.50; break; case 20: koef = 3.49; break;
      case 25: koef = 2.90; break; case 30: koef = 2.50; break; case 35: koef = 2.22; break; case 40: koef = 2.01; break; 
      case 45: koef = 1.84; break; default: koef = 0; 
      } break; 
    case 50:
      switch (pocetSplatek) {
      case  5: koef =10.51; break; case 10: koef = 5.42; break; case 15: koef = 3.75; break; case 20: koef = 2.91; break;
      case 25: koef = 2.41; break; case 30: koef = 2.08; break; case 35: koef = 1.85; break; case 40: koef = 1.67; break; 
      case 45: koef = 1.54; break; default: koef = 0; 
      } break; 
    case 60:
      switch (pocetSplatek) {
      case  5: koef = 8.40; break; case 10: koef = 4.34; break; case 15: koef = 3.00; break; case 20: koef = 2.33; break;
      case 25: koef = 1.93; break; case 30: koef = 1.67; break; case 35: koef = 1.48; break; case 40: koef = 1.34; break; 
      case 45: koef = 1.23; break; default: koef = 0; 
      } break; 
    case 70:
      switch (pocetSplatek) {
      case  5: koef = 6.30; break; case 10: koef = 3.25; break; case 15: koef = 2.25; break; case 20: koef = 1.75; break;
      case 25: koef = 1.45; break; case 30: koef = 1.25; break; case 35: koef = 1.11; break; case 40: koef = 1.00; break; 
      case 45: koef = 0.92; break; default: koef = 0; 
      } break; 
    default: koef = 0;
    }

		predem = Math.round(parseInt(akontace)*parseInt(castka)/100);
    pojisteni = 0;
    cena = document.getElementById("ESSOX_standard4_cena").value;
    if (document.getElementById("ESSOX_pojisteniA").checked) pojisteni = Math.round((cena-predem)*0.0016);
    if (document.getElementById("ESSOX_pojisteniB").checked) pojisteni = Math.round((cena-predem)*0.002);
    splatka = Math.ceil((castka*koef/100)+pojisteni);
    navyseni = Math.round((((splatka - ((castka*((100-akontace)/100))/pocetSplatek))*pocetSplatek) / castka) * 10000)/100;
    rpsn = ESSOXpocitejRPSN(pocetSplatek,(castka - (castka*akontace*0.01)),(castka*koef/100));
    return new Array(splatka,rpsn,castka,predem,pojisteni);
  }
  
  function ESSOX_splatkyJS_standard4(castka,akontace,pocetSplatek) {
    max = ESSOX_maxCastka(ESSOX_typZbozi,akontace);
    chyba = "";
    if (akontace < 30 && ESSOX_typZbozi == 3) chyba = "U mobilních telefonů je minimální záloha 30 %.";
    if (max < (castka-(castka*(akontace/100)))) chyba = "Maximální výše úvěru pro zadanou zálohu je " + max + " Kč.";
    if ((castka-(castka*(akontace/100))) < 2000) chyba = "Minimální výše úvěru je 2000 Kč.  Pokud je to možné, zkuste zadat nižší zálohu.";
    if (chyba!="") { retVal = new Array(0,0,0,0); window.alert(chyba); } 
    else 
      retVal = ESSOX_splatky_standard4(castka,akontace,pocetSplatek);
    setContent('ESSOX_kalkulacka_standard4',(retVal[0]) ? retVal[0] +  ",- Kč/měs." : "CHYBA !!!");
    setContent('ESSOX_standard4_RPSN',(retVal[0]) ? "od " + retVal[1] +  " %" : "-");
    setContent('ESSOX_standard4_akontace_kc',(retVal[3]) ? retVal[3] + ",- Kč" : "-");
    setContent('ESSOX_standard4_pojisteni_kc',(retVal[4]) ? retVal[4] + ",- Kč/měs." : "-");
    document.getElementById('ESSOX_standard4_tRPSN').value = retVal[1];
    document.getElementById('ESSOX_standard4_cena').value = retVal[2];
    document.getElementById('ESSOX_standard4_splatka').value = retVal[0];
    document.getElementById('ESSOX_standard4_predem').value = retVal[3];
  }
  
  function ESSOX_poj(typ) {
    if (typ == "A") document.getElementById("ESSOX_pojisteniB").checked = false;
    else if (typ == "B") document.getElementById("ESSOX_pojisteniA").checked = false;
     
  }

