require 'cgi'
module DocParser
  # The XLSXOutput class generates an HTML file containing a table
  # @see Output
  class HTMLOutput < Output
    # @!visibility private
    HTMLHEADER = <<-EOS
  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
   "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
  <html>
  <head>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
  <title>HTML output "#FILENAME#"</title>
  <style type="text/css">
  body {
    font-family:"Helvetica Neue", Helvetica, Sans-Serif;
    font-size:12px;
  }
  table {
  border:1px solid #69c;
  border-collapse:collapse;
  font-size:12px;
  text-align:left;
  width:480px;
  }
  th {
  border-bottom:1px dashed #69c;
  color:#039;
  font-size:14px;
  font-weight:normal;
  padding:12px 17px;
  }
  td {
  color:#669;
  padding:7px 17px;
  white-space: pre;
  }
  tbody tr:hover td {
  background:#d0dafd;
  color:#339;
  }
  tbody tr:nth-child(even) {
    background:#e0eaff;
  }
  </style>
  </head>
  <body>
  <table>
  EOS
    # @!visibility private
    HTMLFOOTER = <<-EOS
    </tbody>
    </table>
    <p>#COUNT# rows</p>
    </body>
    </html>
    EOS
    def open_file
      @file << HTMLHEADER.gsub('#FILENAME#', @filename)
    end

    def header
      @file << '<thead><tr>'
      @file << @header.map { |f| '<th>' + f + '</th>' }.join
      @file << "</tr></thead>\n<tbody>\n"
    end

    def write_row(row)
      @file << '<tr>'
      @file << row.map { |f| '<td>' + CGI.escapeHTML(f.to_s) + '</td>' }.join
      @file << "</tr>\n"
    end

    def footer
      @file << HTMLFOOTER.gsub('#COUNT#', @rowcount.to_s)
    end
  end
end