#!/usr/bin/env python


import os
import sys
import getpass  # just to get user login
import shutil
import datetime
import glob


#===============================================================================
#  Choix
#===============================================================================
#var1='thetao'; Klev2=14;  lev2="lev 14 (26m)"
#var1='uo';     Klev2=14;  lev2="lev 14 (26m)"
var1='o2';  Klev2=24;  lev2="lev 24 (97m)"
#var1='no3'; Klev2=24;  lev2="lev 24 (97m)"
#var1='so';     Klev2=14;  lev2="lev 14 (26m)"


#project_list=['woa2009', 'GLORYS', 'soda3', 'cmip5','cmip6', 'trop']      #    cmip5, cmip6, GLORYS, trop, soda3, woa2009
project_list=['woa2009', 'GLORYS', 'soda3', 'cmip5','cmip6', 'trop']
#project_list=['cmip5','cmip6'] 

num_col=4   #   nombre de colonnes pour répéter le nom de l'expérience

# là où se fait la liste des exp...
img_root_dir='../../images/'
suffix="_mean.PRE-PROCESS.gif"
initial_dir=img_root_dir+'02_pre-processing'

#===============================================================================
#  Definitions
#===============================================================================
local_time1=datetime.datetime.strftime(datetime.datetime.now(), '%Y-%m-%d')    #  '2018-09-19'
local_time2=datetime.datetime.strftime(datetime.datetime.now(), '%d-%b-%Y')    #  '19-Sep-2018'
local_time3=datetime.datetime.strftime(datetime.datetime.now(), 'the %d %b %Y at %H:%M:%S')    #  '20-Jun-2019 at 16:27:43'
local_time4=datetime.datetime.strftime(datetime.datetime.now(), '%Y_%m_%d-%H_%M_%S')    #  '2019_08_12-18_33_13'

script_name=os.path.basename(sys.argv[0])
if 'remake' in os.path.basename(sys.argv[0]) : script_name='atlas-data_processing_3D.py' 

script_name_root=script_name.split('_3D')[0]

script_dir=os.getcwd()



#===============================================================================
#  Main
#===============================================================================

# to open/create a new html file in the write mode
f1 = open(script_name_root+'_'+var1+'.html', 'w')
  
# the html code which will go in the file GFG.html

html_template_begin1 = """
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml">

  <head>
"""
f1.write(html_template_begin1)

f1.write('   <title>Data Processing '+var1+' </title>\n')

html_template_begin2 = """
    <link type="text/css" rel="stylesheet" href="./css/chris_EUC_Upwelling.css" title="feuille de style EUC_Upwelling" />

  <meta charset="UTF-8" /></head>



<!--========================================================================-->
<!--                      Javascript (Open Windows)                         -->
<!--========================================================================-->
  <script type="text/javascript">
    // initialise the visibility check
    function affCache(idDiv) {
    var div = document.getElementById(idDiv);
    if (div.style.display == "none")
    div.style.display = "";
    else
    div.style.display = "none";
    }

    // Chargement images dans window.open
    function ChargeImage1(img1) {
    window.open(img1,img1,'width=1000, height=700, status=no').focus();return false;
    }
  </script>


<!--========================================================================-->
<!--                              BODY                                      -->
<!--========================================================================-->
  <body>
"""
f1.write(html_template_begin2)

f1.write('    <h1>CMIP '+var1+' (X Y)</h1>\n')


html_template_begin3 = """
<!--========================================================================-->
<!--                              TABLE                                     -->
<!--========================================================================-->
<table border="1px">
  <tbody>
"""
f1.write(html_template_begin3)


str1='<tr>\n\
<td align="center" rowspan="1" colspan="1" style="background-color: #ffffff">ORIG</td>\n\
<td align="center" rowspan="1" colspan="1" style="background-color: #ffffff">PRE_PROCESS</td>\n\
<td align="center" rowspan="1" colspan="1" style="background-color: #ffffff">grid_reg1x1-lev_natif</td>\n\
<td align="center" rowspan="1" colspan="1" style="background-color: #ffffff">grid_tr025-lev_natif</td>\n\
<td align="center" rowspan="1" colspan="1" style="background-color: #ffffff">grid_tr025</td>\n\
<td align="center" rowspan="1" colspan="1" style="background-color: #ffffff">-woa2009</td>\n\
<td align="center" rowspan="1" colspan="1" style="background-color: #ffffff">-woa2009</td>\n\
<td align="center" rowspan="1" colspan="1" style="background-color: #ffffff">grid_tr025-lev1_orig</td>\n\
<td align="center" rowspan="1" colspan="1" style="background-color: #ffffff">-woa2009</td>\n\
<td align="center" rowspan="1" colspan="1" style="background-color: #ffffff">-woa2009</td>\n\
</tr>\n'

f1.write(str1)

str2='<tr>\n\
<td align="center" rowspan="1" colspan="1">lev 1</td>\n\
<td align="center" rowspan="1" colspan="1">lev 1</td>\n\
<td align="center" rowspan="1" colspan="1">lev 1</td>\n\
<td align="center" rowspan="1" colspan="1">lev 1</td>\n\
<td align="center" rowspan="1" colspan="1">'+lev2+'</td>\n\
<td align="center" rowspan="1" colspan="1">'+lev2+'</td>\n\
<td align="center" rowspan="1" colspan="1">'+lev2+'</td>\n\
<td align="center" rowspan="1" colspan="1">lev 1 natif</td>\n\
<td align="center" rowspan="1" colspan="1">lev 1 natif</td>\n\
<td align="center" rowspan="1" colspan="1">lev 1 natif</td>\n\
</tr>\n'

num_col_total=str2.count('\n')-2

f1.write(str2)



os.chdir(initial_dir)
#-------------------------------------------------------------------------------
#   For each project...
#-------------------------------------------------------------------------------
for project in project_list :
   ii=1
   if project == 'GLORYS' : color1='#f8e3ff'
   if project == 'soda3' : color1='#f8e3ff'
   if project == 'woa2009' : color1='#f8e3ff'
   if project == 'cmip5' : color1='#e2ffd7'
   if project == 'cmip6' : color1='#d7fffb'
   if project == 'trop' : color1='#fffed7'
   

   #-------------------------------------------------------------------------------
   #   For each exp_file...
   #-------------------------------------------------------------------------------
#  for exp_file in eval(exp_list) :
   for exp_file in sorted(glob.glob(project+'*'+var1+suffix)) :

      print(exp_file,':')
      if ii%4 == 0 : f1.write(str1);  f1.write(str2)
      f1.write('<tr>\n')

      exp_name=exp_file.split('_'+var1+'_')[0]

      for jj in range(num_col_total) :
#        print(jj, num_col, jj%num_col)
         if (jj%num_col == 00) : 
            if (num_col_total-jj) >= num_col : 
               f1.write('<td align="center" rowspan="1" colspan="'+str(num_col)+'" style="background-color: #ffffff">n°'+str(ii)+': <span class="stabilo2">'+exp_file.replace(suffix,'')+'</span></td>\n')
   
      f1.write('</tr>\n')
      f1.write('<tr>\n')
   
#     exp_file1=exp_file.replace('PRE-PROCESS','ORIG')
      exp_file1=exp_name+'_'+var1+'_mean.ORIG.gif'
      f1.write('<td style="background-color: '+color1+'"><a href="javascript:;" onclick="ChargeImage1(\''+img_root_dir+'01_extract/'+exp_file1+'\');">\n')
      f1.write('    <img class="image1" src=\''+img_root_dir+'01_extract/'+exp_file1+'\' /></a></td>\n')
   
      f1.write('<td style="background-color: '+color1+'"><a href="javascript:;" onclick="ChargeImage1(\''+img_root_dir+'02_pre-processing/'+exp_file+'\');">\n')
      f1.write('    <img class="image1" src=\''+img_root_dir+'02_pre-processing/'+exp_file+'\' /></a></td>\n')
   
      exp_file3=exp_name+'_'+var1+'_mean.grid_reg1x1-lev_natif_xy.gif'
#     exp_file3=exp_file.replace('PRE-PROCESS','grid_reg1x1-lev_natif_xy')
      f1.write('<td style="background-color: '+color1+'"><a href="javascript:;" onclick="ChargeImage1(\''+img_root_dir+'03_interp-horiz/'+exp_file3+'\');">\n')
      f1.write('    <img class="image1" src=\''+img_root_dir+'03_interp-horiz/'+exp_file3+'\' /></a></td>\n')
   
      exp_file4=exp_name+'_'+var1+'_mean.grid_tr025-lev_natif_xy.gif'
#     exp_file4=exp_file.replace('PRE-PROCESS','grid_tr025-lev_natif_xy')
      f1.write('<td style="background-color: '+color1+'"><a href="javascript:;" onclick="ChargeImage1(\''+img_root_dir+'03_interp-horiz/'+exp_file4+'\');">\n')
      f1.write('    <img class="image1" src=\''+img_root_dir+'03_interp-horiz/'+exp_file4+'\' /></a></td>\n')
   
      exp_file5=exp_name+'_'+var1+'_mean.grid_tr025.gif'
#     exp_file5=exp_file.replace('PRE-PROCESS','grid_tr025')
      f1.write('<td style="background-color: '+color1+'"><a href="javascript:;" onclick="ChargeImage1(\''+img_root_dir+'04_interp-vert/'+exp_file5+'\');">\n')
      f1.write('    <img class="image1" src=\''+img_root_dir+'04_interp-vert/'+exp_file5+'\' /></a></td>\n')
   
      exp_file51=exp_name+'_'+var1+'_mean.grid_tr025-lev1_orig_lonlat-woa2009_K_'+str(Klev2)+'.gif'
#     exp_file51=exp_file.replace('PRE-PROCESS','grid_tr025-lev1_orig_lonlat-woa2009_K_'+str(Klev2))
      f1.write('<td style="background-color: '+color1+'"><a href="javascript:;" onclick="ChargeImage1(\''+img_root_dir+'05_lev1_orig/'+exp_file51+'\');">\n')
      f1.write('    <img class="image1" src=\''+img_root_dir+'05_lev1_orig/'+exp_file51+'\' /></a></td>\n')
   
      exp_file53=exp_name+'_'+var1+'_mean.grid_tr025-lev1_orig.PERU_lonlat-woa2009_K_'+str(Klev2)+'.gif'
#     exp_file53=exp_file.replace('PRE-PROCESS','grid_tr025-lev1_orig.PERU_lonlat-woa2009_K_'+str(Klev2))
      f1.write('<td style="background-color: '+color1+'"><a href="javascript:;" onclick="ChargeImage1(\''+img_root_dir+'05_lev1_orig/'+exp_file53+'\');">\n')
      f1.write('    <img class="image1" src=\''+img_root_dir+'05_lev1_orig/'+exp_file53+'\' /></a></td>\n')
   
      exp_file6=exp_name+'_'+var1+'_mean.grid_tr025-lev1_orig_xy_K_1.gif'
#     exp_file6=exp_file.replace('PRE-PROCESS','grid_tr025-lev1_orig_xy_K_1')
      f1.write('<td style="background-color: '+color1+'"><a href="javascript:;" onclick="ChargeImage1(\''+img_root_dir+'05_lev1_orig/'+exp_file6+'\');">\n')
      f1.write('    <img class="image1" src=\''+img_root_dir+'05_lev1_orig/'+exp_file6+'\' /></a></td>\n')
   
      exp_file61=exp_name+'_'+var1+'_mean.grid_tr025-lev1_orig_lonlat-woa2009_K_1.gif'
#     exp_file61=exp_file.replace('PRE-PROCESS','grid_tr025-lev1_orig_lonlat-woa2009_K_1')
      f1.write('<td style="background-color: '+color1+'"><a href="javascript:;" onclick="ChargeImage1(\''+img_root_dir+'05_lev1_orig/'+exp_file61+'\');">\n')
      f1.write('    <img class="image1" src=\''+img_root_dir+'05_lev1_orig/'+exp_file61+'\' /></a></td>\n')
   
      exp_file63=exp_name+'_'+var1+'_mean.grid_tr025-lev1_orig.PERU_lonlat-woa2009_K_1.gif'
#     exp_file63=exp_file.replace('PRE-PROCESS','grid_tr025-lev1_orig.PERU_lonlat-woa2009_K_1')
      f1.write('<td style="background-color: '+color1+'"><a href="javascript:;" onclick="ChargeImage1(\''+img_root_dir+'05_lev1_orig/'+exp_file63+'\');">\n')
      f1.write('    <img class="image1" src=\''+img_root_dir+'05_lev1_orig/'+exp_file63+'\' /></a></td>\n')
   
      f1.write('</tr>\n')
      ii=ii+1

os.chdir(script_dir)
#########




html_template_end = """
  <tr>
  </tr>
  </tbody>
</table>

   <!--=================================== Pied de page  ===================================-->
   <br />
   <br />
   <br />

   <table width="100%" border="1px">
      <tbody>
         <tr>
            <td align="center">Webmaster: christophe.hourdin @ locean-ipsl.upmc.fr</td>
         </tr>
         <tr>
            <td align="center">Croco-Agrif-Pisces Projects - <a href="https://pagesperso.locean-ipsl.upmc.fr/cholod/EUC_Upwelling/index.xhtml">Home</a></td>
         </tr>
      </tbody>
   </table>
</body>
</html>
"""


f1.write(html_template_end)
  
# close the file
f1.close()

shutil.copy2(script_name,script_name_root+'_'+var1+'.html-remake.py')








