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 /worldmap-save.c | |
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>
Diffstat (limited to 'worldmap-save.c')
-rw-r--r-- | worldmap-save.c | 88 |
1 files changed, 8 insertions, 80 deletions
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); |