diff options
Diffstat (limited to 'templates/cave.html')
-rw-r--r-- | templates/cave.html | 532 |
1 files changed, 267 insertions, 265 deletions
diff --git a/templates/cave.html b/templates/cave.html index 7e8e09e..d7ceb13 100644 --- a/templates/cave.html +++ b/templates/cave.html @@ -1,413 +1,415 @@ {% extends "cavebase.html" %} - +<!-- cave.html - this text visible because this template has been included --> {% block extraheaders %} {% if cave.survex_file %} -<style> -# This is presumably very similar caveview.css but why is it copied here ? -# Because it is NOT the same as the distrubuted CaveView code. -# Needs to be separated out into JSLIB local. (PMS 3/4/2021) +<!--# This is presumably very similar caveview.css but why is it copied here ? +# Because it is NOT exactly the same as the distrubuted CaveView code. +#e.g. the body {} bit in Caveview/css/caveview.css is missing here: +# Needs to be separated out into JSLIB local. (PMS 27/4/2021) +--> +<style> div.cv-panel { - position: absolute; - top: 0; - left: 0; - z-index: 100; - background-color: rgba(50,50,50,0.5); - color: yellowgreen; - border: 1px solid black; - border-radius: 5px; + position: absolute; + top: 0; + left: 0; + z-index: 100; + background-color: rgba(50,50,50,0.5); + color: yellowgreen; + border: 1px solid black; + border-radius: 5px; } div.cv-compass, div.cv-ahi { - position: absolute; - bottom: 95px; - right: 5px; - margin: 0; - padding-top: 2px; - /* border: 1px solid white; */ - text-align: center; - width: 78px; - height: 19px; - z-index: 50; - background-color: rgba(50,50,50,0.5); - background-color: black; - color: white; -} - + position: absolute; + bottom: 95px; + right: 5px; + margin: 0; + padding-top: 2px; + /* border: 1px solid white; */ + text-align: center; + width: 78px; + height: 19px; + z-index: 50; + background-color: rgba(50,50,50,0.5); + background-color: black; + color: white; +} + div.cv-ahi { - right: 95px; + right: 95px; } div.scale-legend { - position: absolute; - color: white; - background-color: black; - bottom: 30px; + position: absolute; + color: white; + background-color: black; + bottom: 30px; } div.linear-scale { - position: absolute; - color: white; - background-color: black; - right: 30px; - width: 40px; - padding: 2px 0; - text-align: right; - border: 1px solid black; - font-size: 14px; + position: absolute; + color: white; + background-color: black; + right: 30px; + width: 40px; + padding: 2px 0; + text-align: right; + border: 1px solid black; + font-size: 14px; } div.linear-scale-caption { - position: absolute; - color: white; - background-color: black; - right: 5px; - width: 65px; - padding: 2px 0 5px 0; - text-align: left; - border: 1px solid black; - font-size: 14px; + position: absolute; + color: white; + background-color: black; + right: 5px; + width: 65px; + padding: 2px 0 5px 0; + text-align: left; + border: 1px solid black; + font-size: 14px; } #min-div { - border-bottom: 1px solid white; + border-bottom: 1px solid white; } #max-div { - border-top: 1px solid white; + border-top: 1px solid white; } #angle-legend { - position: absolute; - width: 80px; - right: 5px; - bottom: 180px; - color: white; - background-color: black; - font-size: 14px; - text-align: center; + position: absolute; + width: 80px; + right: 5px; + bottom: 180px; + color: white; + background-color: black; + font-size: 14px; + text-align: center; } #scene { - width: 100%; - height: 700px; - position: relative; + width: 100%; + height: 700px; + position: relative; } #progress-bar { - position: absolute; - top: 55%; - height: 20px; - border: 1px solid white; - z-index: 100; + position: absolute; + top: 55%; + height: 20px; + border: 1px solid white; + z-index: 100; } #status-text { - position: absolute; - top: 50%; - height: 20px; - padding-left: 4px; - background-color: black; - color: white; - z-index: 100; + position: absolute; + top: 50%; + height: 20px; + padding-left: 4px; + background-color: black; + color: white; + z-index: 100; } #frame div.page ul { - list-style-type: none; - margin: 8px 0 0 0; - padding: 0; - width: 200px; - height: 100%; - cursor: default; - font-size: 12px; - overflow-y: auto; - overflow-x: hidden; + list-style-type: none; + margin: 8px 0 0 0; + padding: 0; + width: 200px; + height: 100%; + cursor: default; + font-size: 12px; + overflow-y: auto; + overflow-x: hidden; } #frame div.page li { - position: relative; - margin-left: 16px; - border-bottom: 1px solid #444444; + position: relative; + margin-left: 16px; + border-bottom: 1px solid #444444; } #frame div.page li.selected { - color: #1ab4e5; + color: #1ab4e5; } #frame div.page li:hover { - color: yellow; + color: yellow; } #frame div.page div#ui-path { - font-size: 12px; - border-top: 1px solid grey; - border-bottom: 1px solid grey; - margin-top: 8px; - padding: 2px 0 2px 12px; + font-size: 12px; + border-top: 1px solid grey; + border-bottom: 1px solid grey; + margin-top: 8px; + padding: 2px 0 2px 12px; } #frame div.page div#ui-path span { - color: #1ab4e5; + color: #1ab4e5; } #frame div.page div.slide { - position: absolute; - top: 64px; - left: 0px; - height: auto; - margin-top:0; - bottom: 44px; - background-color: #222222; - transition: transform 0.25s ease-in; + position: absolute; + top: 64px; + left: 0px; + height: auto; + margin-top:0; + bottom: 44px; + background-color: #222222; + transition: transform 0.25s ease-in; } #frame div.slide-out { - border-right: 1px grey solid; - transform: translateX(-100%); + border-right: 1px grey solid; + transform: translateX(-100%); } #frame div.page div.descend-tree { - position: absolute; - top: 0px; - right: 0px; - margin: 0; - color: #1ab4e5; - z-index: 110; + position: absolute; + top: 0px; + right: 0px; + margin: 0; + color: #1ab4e5; + z-index: 110; } #frame { - position: absolute; - top: 0px; - left: 0px; - width: 240px; - height: 100%; - background-color: transparent; - transform: translateX(-200px); - transition: transform 0.25s ease-in; + position: absolute; + top: 0px; + left: 0px; + width: 240px; + height: 100%; + background-color: transparent; + transform: translateX(-200px); + transition: transform 0.25s ease-in; } #frame.onscreen { - transform: none; - transition: transform 0.25s ease-out; + transform: none; + transition: transform 0.25s ease-out; } #frame a.download { - border: 1px solid green; - display: block; - width: 180px; - box-sizing: border-box; - margin-top: 6px; - margin-bottom: 4px; - margin-left: 8px; - border: none; - border-bottom: 4px solid #1ab4e5; - color: #dddddd; - background-color: black; - padding-bottom: 4px; - box-shadow: 1px 1px 8px 0px #888888; - outline: nonlass="cavedisplay"e; - text-decoration: none; - text-align: center; + border: 1px solid green; + display: block; + width: 180px; + box-sizing: border-box; + margin-top: 6px; + margin-bottom: 4px; + margin-left: 8px; + border: none; + border-bottom: 4px solid #1ab4e5; + color: #dddddd; + background-color: black; + padding-bottom: 4px; + box-shadow: 1px 1px 8px 0px #888888; + outline: nonlass="cavedisplay"e; + text-decoration: none; + text-align: center; } #frame a.download:hover { - color: white; + color: white; } #frame a.download:active { - color: #dddddd; - border-bottom: 4px solid #0c536a; - box-shadow: none; - box-shadow: inset 1px 1px 8px 0px #888888; + color: #dddddd; + border-bottom: 4px solid #0c536a; + box-shadow: none; + box-shadow: inset 1px 1px 8px 0px #888888; } #frame .tab { - position: absolute; - right: 0px;lass="cavedisplay" - width: 40px; - height: 40px; - box-sizing: border-box; - background-color: #444444; - border-left: 1px solid black; - background-position: center; - border-top: 1px solid black; + position: absolute; + right: 0px;lass="cavedisplay" + width: 40px; + height: 40px; + box-sizing: border-box; + background-color: #444444; + border-left: 1px solid black; + background-position: center; + border-top: 1px solid black; } #frame #close { - position: absolute; - right: 40px; - bottom: 0px; - width: 40px; - height: 40px; - box-sizing: border-box; - z-index: 150; - background-image: url(../images/ic_remove.png); - background-position: center; + position: absolute; + right: 40px; + bottom: 0px; + width: 40px; + height: 40px; + box-sizing: border-box; + z-index: 150; + background-image: url(../images/ic_remove.png); + background-position: center; } #icon_settings { - background-image: url(../images/ic_settings.png); + background-image: url(../images/ic_settings.png); } #icon_terrain { - background-image: url(../images/ic_terrain.png); + background-image: url(../images/ic_terrain.png); } #icon_explore { - background-image: url(../images/ic_explore.png); + background-image: url(../images/ic_explore.png); } #icon_info { - background-image: url(../images/ic_info.png); + background-image: url(../images/ic_info.png); } #icon_route { - background-image: url(../images/ic_route.png); + background-image: url(../images/ic_route.png); } #icon_help { - background-image: url(../images/ic_help.png); + background-image: url(../images/ic_help.png); } #frame div.toptab { - background-color: #222222; - border-left: none; - border-right: 1px solid grey; - border-top: 1px solid grey; + background-color: #222222; + border-left: none; + border-right: 1px solid grey; + border-top: 1px solid grey; } #frame div.page { - position: absolute; - top: 0px; - bottom: 40px; - left: 0px; - width: 200px; - height: 100%; - color: white; - background-color: #222222; - padding: 0 4px; - box-sizing: border-box; - cursor: default; - padding-bottom: 40px; + position: absolute; + top: 0px; + bottom: 40px; + left: 0px; + width: 200px; + height: 100%; + color: white; + background-color: #222222; + padding: 0 4px; + box-sizing: border-box; + cursor: default; + padding-bottom: 40px; } #frame div.page div.header { - margin: 16px 0px 8px 0px; - font-weight: bold; - height: 16px; - box-sizing: border-box; - padding-left: 2px; + margin: 16px 0px 8px 0px; + font-weight: bold; + height: 16px; + box-sizing: border-box; + padding-left: 2px; } #frame div.page div.control { - margin: 2px 0 2px 0; - padding-top: 2px; + margin: 2px 0 2px 0; + padding-top: 2px; } #frame div.page label { - display: block; - border-top: 1px solid grey; - padding: 2px 0 2px 8px; - font-size: 12px; + display: block; + border-top: 1px solid grey; + padding: 2px 0 2px 8px; + font-size: 12px; } #frame div.page select { - display: block; - width: 180px; - box-sizing: border-box; - padding-top: 2px; - margin: 2px 0 4px 8px; + display: block; + width: 180px; + box-sizing: border-box; + padding-top: 2px; + margin: 2px 0 4px 8px; } #frame div.page select:empty { - background-color: #888888; + background-color: #888888; } #frame div.page button { - display: block; - width: 180px; - box-sizing: border-box; - margin-top: 4px; - margin-bottom: 4px; - margin-left: 8px; - border: none; - border-bottom: 4px solid #1ab4e5; - color: #dddddd; - background-color: black; - padding-bottom: 4px; - box-shadow: 1px 1px 8px 0px #888888; - outline: none; + display: block; + width: 180px; + box-sizing: border-box; + margin-top: 4px; + margin-bottom: 4px; + margin-left: 8px; + border: none; + border-bottom: 4px solid #1ab4e5; + color: #dddddd; + background-color: black; + padding-bottom: 4px; + box-shadow: 1px 1px 8px 0px #888888; + outline: none; } #frame div.page button:hover { - color: white; + color: white; } #frame div.page button:active { - color: #dddddd; - border-bottom: 4px solid #0c536a; - box-shadow: none; - box-shadow: inset 1px 1px 8px 0px #888888; + color: #dddddd; + border-bottom: 4px solid #0c536a; + box-shadow: none; + box-shadow: inset 1px 1px 8px 0px #888888; } #frame div.page input[type="text"] { - display: block; - width: 180px; - box-sizing: border-box; - margin-top: 2px; - margin-left: 8px; + display: block; + width: 180px; + box-sizing: border-box; + margin-top: 2px; + margin-left: 8px; } #frame div.page input[type="checkbox"] { - position: absolute; - right: 0px; + position: absolute; + right: 0px; } #frame div.page input[type="range"] { - display: block; - width: 180px; - margin-left: 8px; + display: block; + width: 180px; + margin-left: 8px; } #frame dt, #frame dd { - font-size: 12px; + font-size: 12px; } #frame dt { - clear: both; - float: left; - padding-left: 16px; + clear: both; + float: left; + padding-left: 16px; } #frame dd { - margin-left: 40px; + margin-left: 40px; } #frame p { - font-size: 12px; - line-height: 18px; + font-size: 12px; + line-height: 18px; } div.station-info { - position: absolute; - border: 1px solid white; - background-color: #222222; - color: white; - padding: 4px; - z-index: 200; + position: absolute; + border: 1px solid white; + background-color: #222222; + color: white; + padding: 4px; + z-index: 200; } .overlay-branding { - color: white; - margin: 4px; - position: absolute; - right: 0; - top: 0; + color: white; + margin: 4px; + position: absolute; + right: 0; + top: 0; } div#scene { - width: 100%; - height: 90%; } + width: 100%; + height: 90%; } </style> @@ -417,20 +419,20 @@ div#scene { <script type="text/javascript" > - function onLoad () { + function onLoad () { - // display the user interface - and a blank canvas - // the configuration object specifies the location of CaveView, surveys and terrain files - CV.UI.init( 'scene', { - home: '/javascript/CaveView/', - surveyDirectory: '/expowebcache/3d/', - terrainDirectory: '/loser/surface/terrain/' - } ); + // display the user interface - and a blank canvas + // the configuration object specifies the location of CaveView, surveys and terrain files + CV.UI.init( 'scene', { + home: '/javascript/CaveView/', + surveyDirectory: '/expowebcache/3d/', + terrainDirectory: '/loser/surface/terrain/' // cannot work, apache not handling this + } ); - // load a single survey to display + // load a single survey to display // Note the special code in views.caves.py to do this. The appropriate .svx/.3d file may not be simply the cave name +.3d - CV.UI.loadCave('{{svx3d}}.3d'); - } + CV.UI.loadCave('{{svx3d}}.3d'); + } window.onload = onLoad; </script> {% endif %} <!-- all the above only loads if cave.survex_file is not empty--> @@ -500,7 +502,7 @@ div#scene { {% endif %} {% if cave.survex_file %} <h2>Survex File</h2> - <a href="{% url "survexcavessingle" cave.kataster_number %}">All survex files</a> + <a href="/survexfile">All survex files</a> <a href="{% if cave.kataster_number %}{% url "cave3d" cave.kataster_number %}{% else %}{% url "cave3d" cave.unofficial_number %}{% endif %}">3d file download</a> <a href="{% url "svx" svxstem %}">This survex file</a> @@ -513,7 +515,7 @@ div#scene { </div> <div id="entrances"> - <p>{% if cave.entrances %} + <p>{% if cave.entrances %} <h2>Entrances</h2> <ul> {% for ent in cave.entrances %} @@ -570,10 +572,10 @@ div#scene { {% endif %} {% if ent.entrance.other_station %} <dt>Other Station</dt><dd>{{ ent.entrance.other_station|safe }} - {% if ent.entrance.other_description %} - - {{ ent.entrance.other_description|safe }} - {% endif %} {{ ent.entrance.other_location.y|safe }}, {{ ent.entrance.other_location.x|safe }}, {{ ent.entrance.other_location.z|safe }}m - </dd> + {% if ent.entrance.other_description %} + - {{ ent.entrance.other_description|safe }} + {% endif %} {{ ent.entrance.other_location.y|safe }}, {{ ent.entrance.other_location.x|safe }}, {{ ent.entrance.other_location.z|safe }}m + </dd> {% endif %} </dl> </li> |