diff options
author | Gehad elrobey <gehadelrobey@gmail.com> | 2014-05-23 21:49:49 +0300 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2014-05-29 07:24:17 -0700 |
commit | a3dbb5865cc3c1ba793f8a05d20a92c5131f4bae (patch) | |
tree | dbc9b3d7bb34c271aa8ed22c66db8fb60a55983a | |
parent | b37422c4478825f679e05cb19ed22184b6172d44 (diff) | |
download | subsurface-a3dbb5865cc3c1ba793f8a05d20a92c5131f4bae.tar.gz |
HTML list exporter
Exporting the raw dive list into JSON format for later viewing with html
and js files. Also some worldmap code organizations.
Signed-off-by: Gehad elrobey <gehadelrobey@gmail.com>
Signed-off-by: Miika Turkia <miika.turkia@gmail.com>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | qt-ui/divelogexportdialog.cpp | 10 | ||||
-rw-r--r-- | qt-ui/divelogexportdialog.ui | 50 | ||||
-rw-r--r-- | save-html.c | 154 | ||||
-rw-r--r-- | save-html.h | 26 | ||||
-rw-r--r-- | subsurface.pro | 2 | ||||
-rw-r--r-- | worldmap-save.c | 88 |
6 files changed, 232 insertions, 98 deletions
diff --git a/qt-ui/divelogexportdialog.cpp b/qt-ui/divelogexportdialog.cpp index 28f343257..a3193d5ce 100644 --- a/qt-ui/divelogexportdialog.cpp +++ b/qt-ui/divelogexportdialog.cpp @@ -2,7 +2,6 @@ #include <QString> #include <QShortcut> #include <QAbstractButton> -#include <QDebug> #include <QSettings> #include "mainwindow.h" @@ -10,6 +9,7 @@ #include "ui_divelogexportdialog.h" #include "subsurfacewebservices.h" #include "worldmap-save.h" +#include "save-html.h" DiveLogExportDialog::DiveLogExportDialog(QWidget *parent) : QDialog(parent), ui(new Ui::DiveLogExportDialog) @@ -39,6 +39,8 @@ void DiveLogExportDialog::showExplanation() ui->description->setText("HTML export of the dive locations, visualized on a world map."); } else if (ui->exportSubsurfaceXML->isChecked()) { ui->description->setText("Subsurface native XML format."); + } else if (ui->exportHtml->isChecked()) { + ui->description->setText("Html export of dive list can be viewed in any web browser."); } } @@ -84,7 +86,13 @@ void DiveLogExportDialog::on_buttonBox_accepted() QByteArray bt = QFile::encodeName(filename); save_dives_logic(bt.data(), true); } + } else if (ui->exportHtml->isChecked()) { + filename = QFileDialog::getSaveFileName(this, tr("Export HTML"), lastDir, + tr("HTML files (*.html)")); + if (!filename.isNull() && !filename.isEmpty()) + export_HTML(filename.toUtf8().data(), ui->exportSelected->isChecked()); } + if (!filename.isNull() && !filename.isEmpty()) { // remember the last export path QFileInfo fileInfo(filename); diff --git a/qt-ui/divelogexportdialog.ui b/qt-ui/divelogexportdialog.ui index 72e373127..09143f0d9 100644 --- a/qt-ui/divelogexportdialog.ui +++ b/qt-ui/divelogexportdialog.ui @@ -7,7 +7,7 @@ <x>0</x> <y>0</y> <width>448</width> - <height>473</height> + <height>522</height> </rect> </property> <property name="windowTitle"> @@ -17,7 +17,7 @@ <property name="geometry"> <rect> <x>20</x> - <y>420</y> + <y>450</y> <width>341</width> <height>32</height> </rect> @@ -62,7 +62,7 @@ <x>20</x> <y>70</y> <width>201</width> - <height>211</height> + <height>241</height> </rect> </property> <property name="title"> @@ -166,6 +166,35 @@ <string notr="true">exportGroup</string> </attribute> </widget> + <widget class="QRadioButton" name="exportHtml"> + <property name="geometry"> + <rect> + <x>10</x> + <y>190</y> + <width>117</width> + <height>22</height> + </rect> + </property> + <property name="text"> + <string>HTML</string> + </property> + <attribute name="buttonGroup"> + <string notr="true">exportGroup</string> + </attribute> + </widget> + <widget class="Line" name="line"> + <property name="geometry"> + <rect> + <x>40</x> + <y>230</y> + <width>231</width> + <height>16</height> + </rect> + </property> + <property name="orientation"> + <enum>Qt::Horizontal</enum> + </property> + </widget> </widget> <widget class="QGroupBox" name="exportSelection"> <property name="geometry"> @@ -212,24 +241,11 @@ </property> </widget> </widget> - <widget class="Line" name="line"> - <property name="geometry"> - <rect> - <x>60</x> - <y>280</y> - <width>231</width> - <height>16</height> - </rect> - </property> - <property name="orientation"> - <enum>Qt::Horizontal</enum> - </property> - </widget> <widget class="QLabel" name="description"> <property name="geometry"> <rect> <x>30</x> - <y>310</y> + <y>330</y> <width>341</width> <height>91</height> </rect> diff --git a/save-html.c b/save-html.c new file mode 100644 index 000000000..a9b48fcc7 --- /dev/null +++ b/save-html.c @@ -0,0 +1,154 @@ +#include "save-html.h" +#include "gettext.h" + +void put_HTML_date(struct membuffer *b, struct dive *dive, const char *pre, const char *post) +{ + struct tm tm; + utc_mkdate(dive->when, &tm); + put_format(b, "%s%04u-%02u-%02u%s", pre, tm.tm_year + 1900, tm.tm_mon + 1, tm.tm_mday, post); +} + +char *replace_char(char *str, char replace, char *replace_by) +{ + /* + this function can't replace a character with a substring + where the substring contains the character, infinite loop. + */ + + if (!str) + return 0; + + int i = 0, char_count = 0, new_size; + + while (str[i] != '\0') { + if (str[i] == replace) + char_count++; + i++; + } + + new_size = strlen(str) + char_count * strlen(replace_by) + 1; + char *result = malloc(new_size); + char *temp = strdup(str); + char *p0, *p1; + if (!result || !temp) + return 0; + result[0] = '\0'; + p0 = temp; + p1 = strchr(temp, replace); + while (p1) { + *p1 = '\0'; + strcat(result, p0); + strcat(result, replace_by); + p0 = p1 + 1; + p1 = strchr(p0, replace); + } + strcat(result, p0); /*concat the rest of the string*/ + free(temp); + return result; +} + +char *quote(char *string) +{ + char *new_line_removed = replace_char(string, '\n', "<br>"); + char *single_quotes_removed = replace_char(new_line_removed, '\'', "'"); + free(new_line_removed); + return single_quotes_removed; +} + +void put_HTML_notes(struct membuffer *b, struct dive *dive, const char *pre, const char *post) +{ + if (dive->notes) { + char *notes = quote(dive->notes); + put_format(b, "%s: %s %s", pre, notes, post); + free(notes); + } +} + +void put_HTML_time(struct membuffer *b, struct dive *dive, const char *pre, const char *post) +{ + struct tm tm; + utc_mkdate(dive->when, &tm); + put_format(b, "%s%02u:%02u:%02u%s", pre, tm.tm_hour, tm.tm_min, tm.tm_sec, post); +} + +void put_HTML_airtemp(struct membuffer *b, struct dive *dive, const char *pre, const char *post) +{ + const char *unit; + double value; + + value = get_temp_units(dive->airtemp.mkelvin, &unit); + put_format(b, "%s%.1f %s%s",pre, value, unit, post); +} + +void put_HTML_watertemp(struct membuffer *b, struct dive *dive, const char *pre, const char *post) +{ + const char *unit; + double value; + + value = get_temp_units(dive->watertemp.mkelvin, &unit); + put_format(b, "%s%.1f %s%s",pre, value, unit, post); +} + +void put_HTML_tags(struct membuffer *b, struct dive *dive, const char *pre, const char *post) +{ + put_string(b, pre); + struct tag_entry *tag = dive->tag_list; + while(tag){ + put_format(b, "%s ", tag->tag->name); + tag = tag->next; + } + put_string(b, post); +} + +void write_dives(struct membuffer *b,bool selected_only) +{ + int i, dive_no = 0; + struct dive *dive; + + for_each_dive(i, dive) { + if (selected_only) { + if (!dive->selected) + continue; + } + put_string(b, "{"); + put_format(b, "\"number\":%d,", dive_no); + put_HTML_date(b, dive, "\"date\":\"", "\","); + put_HTML_time(b, dive, "\"time\":\"", "\","); + put_format(b, "\"location\":\"%s\",", dive->location); + put_format(b, "\"rating\":%d,", dive->rating); + put_format(b, "\"visibility\":%d,", dive->visibility); + put_string(b, "\"temperature\":{"); + put_HTML_airtemp(b, dive, "\"air\":\"", "\","); + put_HTML_watertemp(b, dive, "\"water\":\"", "\","); + put_string(b, " },"); + put_format(b, "\"buddy\":\"%s\",", dive->buddy); + put_format(b, "\"divemaster\":\"%s\",", dive->divemaster); + put_format(b, "\"suit\":\"%s\",", dive->suit); + put_HTML_tags(b, dive, "\"tags\":\"", "\","); + put_HTML_notes(b, dive ,"\"notes\":\"" ,"\","); + put_string(b, "},\n"); + dive_no++; + } +} + +void export_dives(struct membuffer *b,bool selected_only){ + put_string(b, "items=["); + write_dives(b, selected_only); + put_string(b, "]"); +} + +void export_HTML(const char *file_name, const bool selected_only) +{ + FILE *f; + + struct membuffer buf = { 0 }; + export_dives(&buf, selected_only); + + f = fopen(file_name, "w+"); + if (!f) + printf("error"); /*report error*/ + + flush_buffer(&buf, f); /*check for writing errors? */ + free_buffer(&buf); + fclose(f); +} diff --git a/save-html.h b/save-html.h new file mode 100644 index 000000000..47f6d218d --- /dev/null +++ b/save-html.h @@ -0,0 +1,26 @@ +#ifndef HTML_SAVE_H +#define HTML_SAVE_H + +#ifdef __cplusplus +extern "C" { +#endif + +#include "dive.h" +#include "membuffer.h" + +void put_HTML_date(struct membuffer *b, struct dive *dive, const char *pre, const char *post); +void put_HTML_airtemp(struct membuffer *b, struct dive *dive, const char *pre, const char *post); +void put_HTML_watertemp(struct membuffer *b, struct dive *dive, const char *pre, const char *post); +void put_HTML_time(struct membuffer *b, struct dive *dive, const char *pre, const char *post); +void put_HTML_notes(struct membuffer *b, struct dive *dive, const char *pre, const char *post); + +char *replace_char(char *str, char replace, char *replace_by); +char *quote(char *string); + +void export_HTML(const char *file_name, const bool selected_only); + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/subsurface.pro b/subsurface.pro index d7189377a..6eb2bc879 100644 --- a/subsurface.pro +++ b/subsurface.pro @@ -28,6 +28,7 @@ HEADERS = \ helpers.h \ libdivecomputer.h \ planner.h \ + save-html.h \ worldmap-save.h \ worldmap-options.h \ pref.h \ @@ -104,6 +105,7 @@ SOURCES = \ profile.c \ divecomputer.cpp \ worldmap-save.c \ + save-html.c \ qt-gui.cpp \ qthelper.cpp \ qt-ui/about.cpp \ diff --git a/worldmap-save.c b/worldmap-save.c index b82ccd3eb..3892014e1 100644 --- a/worldmap-save.c +++ b/worldmap-save.c @@ -2,8 +2,10 @@ #include <stdlib.h> #include <string.h> #include <stdio.h> + #include "dive.h" #include "membuffer.h" +#include "save-html.h" #include "worldmap-save.h" #include "worldmap-options.h" #include "gettext.h" @@ -14,82 +16,6 @@ char *getGoogleApi() return "https://maps.googleapis.com/maps/api/js?key=AIzaSyDzo9PWsqYDDSddVswg_13rpD9oH_dLuoQ"; } -void put_HTML_date(struct membuffer *b, struct dive *dive) -{ - struct tm tm; - utc_mkdate(dive->when, &tm); - put_format(b, "<p>%s: %04u-%02u-%02u</p>", translate("gettextFromC", "Date"), tm.tm_year + 1900, tm.tm_mon + 1, tm.tm_mday); - put_format(b, "<p>%s: %02u:%02u:%02u</p>", translate("gettextFromC", "Time"), tm.tm_hour, tm.tm_min, tm.tm_sec); -} - -void put_HTML_temp(struct membuffer *b, struct dive *dive) -{ - const char *unit; - double value; - - value = get_temp_units(dive->airtemp.mkelvin, &unit); - put_format(b, "<p>%s: %.1f %s</p>", translate("gettextFromC", "Air Temp"), value, unit); - - value = get_temp_units(dive->watertemp.mkelvin, &unit); - put_format(b, "<p>%s: %.1f %s</p>", translate("gettextFromC", "Water Temp"), value, unit); -} - -char *replace_char(char *str, char replace, char *replace_by) -{ - /* - this fumction can't replace a character with a substring - where the substring contains the character, infinte loop. - */ - - if (!str) - return 0; - - int i = 0, char_count = 0, new_size; - - while (str[i] != '\0') { - if (str[i] == replace) - char_count++; - i++; - } - - new_size = strlen(str) + char_count * strlen(replace_by) + 1; - char *result = malloc(new_size); - char *temp = strdup(str); - char *p0, *p1; - if (!result || !temp) - return 0; - result[0] = '\0'; - p0 = temp; - p1 = strchr(temp, replace); - while (p1) { - *p1 = '\0'; - strcat(result, p0); - strcat(result, replace_by); - p0 = p1 + 1; - p1 = strchr(p0, replace); - } - strcat(result, p0); /*concat the rest of the string*/ - free(temp); - return result; -} - -char *quote(char *string) -{ - char *new_line_removed = replace_char(string, '\n', "<br>"); - char *single_quotes_removed = replace_char(new_line_removed, '\'', "'"); - free(new_line_removed); - return single_quotes_removed; -} - -void put_HTML_notes(struct membuffer *b, struct dive *dive) -{ - if (dive->notes) { - char *notes = quote(dive->notes); - put_format(b, "<p>%s: %s </p>", translate("gettextFromC", "Notes"), notes); - free(notes); - } -} - void writeMarkers(struct membuffer *b, const bool selected_only) { int i, dive_no = 0; @@ -106,12 +32,14 @@ void writeMarkers(struct membuffer *b, const bool selected_only) put_degrees(b, dive->latitude, "temp = new google.maps.Marker({position: new google.maps.LatLng(", ""); put_degrees(b, dive->longitude, ",", ")});\n"); put_string(b, "markers.push(temp);\ntempinfowindow = new google.maps.InfoWindow({content: '<div id=\"content\">'+'<div id=\"siteNotice\">'+'</div>'+'<div id=\"bodyContent\">"); - put_format(b, "<p><b>%s</b></p>", quote(dive->location)); - put_HTML_date(b, dive); + put_HTML_date(b, dive, translate("gettextFromC", "<p>Date:"), "</p>"); + put_HTML_time(b, dive, translate("gettextFromC", "<p>Time:"), "</p>"); put_duration(b, dive->duration, translate("gettextFromC", "<p>Duration: "), translate("gettextFromC", " min</p>")); put_depth(b, dive->maxdepth, translate("gettextFromC", "<p>Max Depth: "), translate("gettextFromC", " m</p>")); - put_HTML_temp(b, dive); - put_HTML_notes(b, dive); + put_HTML_airtemp(b, dive, translate("gettextFromC", "<p>Air Temp: "), "</p>"); + put_HTML_watertemp(b, dive,translate("gettextFromC", "<p>Water Temp : ") , "</p>"); + put_format(b, "<p>Location : <b>%s</b></p>", quote(dive->location)); + put_HTML_notes(b, dive, translate("gettextFromC", "<p> Notes"), " </p>"); put_string(b, "</p>'+'</div>'+'</div>'});\ninfowindows.push(tempinfowindow);\n"); put_format(b, "google.maps.event.addListener(markers[%d], 'mouseover', function() {\ninfowindows[%d].open(map,markers[%d]);}", dive_no, dive_no, dive_no); put_format(b, ");google.maps.event.addListener(markers[%d], 'mouseout', function() {\ninfowindows[%d].close();});\n", dive_no, dive_no); |