diff --git a/examples/html/edit-style.css b/examples/html/edit-style.css new file mode 100644 index 0000000000..02a3ba3cab --- /dev/null +++ b/examples/html/edit-style.css @@ -0,0 +1,883 @@ +/* +// edit-style.css +// +// Created by Ryan Huffman on 13 Nov 2014 +// Copyright 2014 High Fidelity, Inc. +// +// Distributed under the Apache License, Version 2.0. +// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html +*/ + +@font-face { + font-family: Raleway-Regular; + src: url(../../resources/fonts/Raleway-Regular.ttf), /* Production */ + url(../../interface/resources/fonts/Raleway-Regular.ttf); /* Development */ +} + +@font-face { + font-family: Raleway-Light; + src: url(../../resources/fonts/Raleway-Light.ttf), + url(../../interface/resources/fonts/Raleway-Light.ttf); +} + +@font-face { + font-family: Raleway-Bold; + src: url(../../resources/fonts/Raleway-Bold.ttf), + url(../../interface/resources/fonts/Raleway-Bold.ttf); +} + +@font-face { + font-family: Raleway-SemiBold; + src: url(../../resources/fonts/Raleway-SemiBold.ttf), + url(../../interface/resources/fonts/Raleway-SemiBold.ttf); +} + +@font-face { + font-family: FiraSans-SemiBold; + src: url(../../resources/fonts/FiraSans-SemiBold.ttf), + url(../../interface/resources/fonts/FiraSans-SemiBold.ttf); +} + +@font-face { + font-family: AnonymousPro-Regular; + src: url(../../resources/fonts/AnonymousPro-Regular.ttf), + url(../../interface/resources/fonts/AnonymousPro-Regular.ttf); +} + +@font-face { + font-family: HiFi-Glyphs; + src: url(../../resources/fonts/hifi-glyphs.ttf), + url(../../interface/resources/fonts/hifi-glyphs.ttf); +} + +* { + margin: 0; + padding: 0; +} + +body { + padding: 24px 12px 24px 12px; + + color: #afafaf; + background-color: #404040; + font-family: Raleway-Regular; + font-size: 15px; + + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + + +table { + font-family: FiraSans-SemiBold; + font-size: 15px; + color: #afafaf; + border-collapse: collapse; + width: 100%; + border: 2px solid #575757; + border-radius: 7px; +} + +thead { + font-family: Raleway-Regular; + font-size: 12px; + text-transform: uppercase; + background-color: #1c1c1c; + padding: 1px 0px; + border-bottom: 1px solid #575757; + width: 100%; +} + +tbody { + width: 100%; +} + +tfoot { + font-family: Raleway-Light; + font-size: 13px; + background-color: #1c1c1c; + border-top: 1px solid #575757; + width: 100%; +} + +tfoot tr { + background-color: #1c1cff; +} + +thead tr { + height: 26px; /* 28px with thead padding */ +} + +thead th { + height: 26px; + background-color: #1c1c1c; + border-right: 1px solid #575757; +} + +thead th:last-child { + border: none; +} + +tbody td { + height: 26px; +} + +tfoot td { + height: 18px; + width: 100%; + background-color: #1c1c1c; + margin-left: 12px; +} + +tr { + width: 100%; + cursor: pointer; +} + +tr:nth-child(odd) { + background-color: #2e2e2e; +} + +tr:nth-child(even) { + background-color: #1c1c1c; +} + +tr:focus { + outline: none; +} + +tr.selected { + color: #000000; + background-color: #00b4ef; +} + +th { + text-align: center; + word-wrap: nowrap; + white-space: nowrap; + padding-left: 12px; + padding-right: 12px; +} + +td { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + word-wrap: nowrap; + padding-left: 12px; + padding-right: 12px; +} + +td.url { + white-space: nowrap; + overflow: hidden; +} + + +input[type="text"], input[type="number"], textarea { + margin: 0; + padding: 0 12px; + color: #afafaf; + background-color: #252525; + border: none; + font-family: FiraSans-SemiBold; + font-size: 15px; +} + +textarea { + font-family: AnonymousPro-Regular; + font-size: 16px; + padding-top: 5px; + padding-bottom: 5px; + min-height: 64px; + width: 100%; + resize: vertical; +} + +input::-webkit-input-placeholder { + font-style: italic; +} + +input:focus, textarea:focus { + color: #fff; + background-color: #000; + outline: 1px solid #00b4ef; + outline-offset: -1px; +} + +input::selection, textarea::selection { + color: #000000; + background-color: #00b4ef; +} + +input.search { + border-radius: 14px; +} + +input:disabled, textarea:disabled { + background-color: #383838; + color: #afafaf; +} + +input[type="text"] { + height: 28px; + width: 100%; +} + +input[type="number"] { + position: relative; + height: 28px; + width: 120px; +} + +input[type=number] { + padding-right: 6px; +} +input[type=number]::-webkit-inner-spin-button { + -webkit-appearance: none; + opacity: 1.0; + display: block; + position: relative; + width: 10px; + overflow: hidden; + font-family: hifi-glyphs; + font-size: 50px; + color: #afafaf; + cursor: pointer; + /*background-color: #000000;*/ +} +input[type=number]::-webkit-inner-spin-button:before, +input[type=number]::-webkit-inner-spin-button:after { + position:absolute; + left: -21px; + line-height: 8px; + text-align: center; +} +input[type=number]::-webkit-inner-spin-button:before { + content: "6"; + top: 5px; +} +input[type=number]::-webkit-inner-spin-button:after { + content: "5"; + bottom: 6px; +} +input[type="number"]::-webkit-inner-spin-button:hover { + color: #ffffff; +} + +input.no-spin::-webkit-outer-spin-button, +input.no-spin::-webkit-inner-spin-button { + display: none; + -webkit-appearance: none; + margin: 0; /* <-- Apparently some margin are still there even though it's hidden */ + padding-right: 12px; +} + +input[type=button] { + font-family: Raleway-Bold; + font-size: 13px; + text-transform: uppercase; + vertical-align: top; + height: 28px; + min-width: 120px; + padding: 0px 12px; + margin-right: 8px; + border-radius: 5px; + border: none; + color: #fff; + background-color: #000; + background: linear-gradient(#343434 20%, #000 100%); + cursor: pointer; +} + +input[type=button].glyph { + font-family: HiFi-Glyphs; + font-size: 20px; + text-transform: none; + min-width: 32px; + padding: 0; +} + +input[type=button].red { + color: #fff; + background-color: #94132e; + background: linear-gradient(#d42043 20%, #94132e 100%); +} +input[type=button].blue { + color: #fff; + background-color: #94132e; + background: linear-gradient(#00b4ef 20%, #1080b8 100%); +} + +input[type=button]:enabled:hover { + background: linear-gradient(#000, #000); + border: none; +} +input[type=button].red:enabled:hover { + background: linear-gradient(#d42043, #d42043); + border: none; +} +input[type=button].blue:enabled:hover { + background: linear-gradient(#00b4ef, #00b4ef); + border: none; +} + +input[type=button]:active { + background: linear-gradient(#343434, #343434); +} +input[type=button].red:active { + background: linear-gradient(#94132e, #94132e); +} +input[type=button].blue:active { + background: linear-gradient(#1080b8, #1080b8); +} + +input[type=button]:disabled { + color: #252525; + background: linear-gradient(#575757 20%, #252525 100%); +} + +input[type=checkbox] { + display: none; +} +input[type=checkbox] + label { + padding-left: 24px; + background-position-y: 6px; + background-repeat: no-repeat; + background-image: url(); +} +input[type=checkbox]:enabled + label:hover { + background-image: url(); +} +input[type=checkbox]:checked + label { + background-image: url(); +} +input[type=checkbox]:checked + label:hover { + background-image: url(); +} + +.selectable { + -webkit-touch-callout: text; + -webkit-user-select: text; + -khtml-user-select: text; + -moz-user-select: text; + -ms-user-select: text; + user-select: text; + cursor: text; +} + +.color-box { + display: inline-block; + width: 15pt; + height: 15pt; + border: 0.75pt solid black; + margin: 1.5pt; + cursor: pointer; +} + +.color-box.highlight { + width: 13.5pt; + height: 13.5pt; + border: 1.5pt solid black; +} + + +.section-header, .sub-section-header { + display: table; + width: 100%; + margin: 22px -12px 0 -12px; + padding: 14px 12px 0 12px; + font-family: Raleway-Regular; + font-size: 12px; + color: #afafaf; + height: 28px; + text-transform: uppercase; + outline: none; +} + +.section-header { + position: relative; + background: #404040 url() repeat-x top left; +} + +.sub-section-header, .no-collapse { + background: #404040 url() repeat-x top left; +} + +.section-header:first-child { + margin-top: 0; + padding-top: 0; + background: none; + height: auto; +} + +.sub-section-header { + margin-bottom: -10px; +} + +.section-header span { + font-family: HiFi-Glyphs; + font-size: 30px; + float: right; + position: absolute; + top: 4px; + right: 6px; +} + +.section-header[collapsed="true"] { + margin-bottom: -22px; +} + +.text-group[collapsed="true"] ~ .text-group, +.zone-group[collapsed="true"] ~ .zone-group, +.web-group[collapsed="true"] ~ .web-group, +.hyperlink-group[collapsed="true"] ~ .hyperlink-group, +.spatial-group[collapsed="true"] ~ .spatial-group, +.physical-group[collapsed="true"] ~ .physical-group, +.behavior-group[collapsed="true"] ~ .behavior-group, +.model-group[collapsed="true"] ~ .model-group, +.light-group[collapsed="true"] ~ .light-group { + display: none !important; +} + + +.property { + display: table; + width: 100%; + margin-top: 22px; + min-height: 29px; +} + +.property label { + display: table-cell; + vertical-align: middle; + font-family: Raleway-SemiBold; + font-size: 14px; +} + +.value { + display: block; + min-height: 18px; +} +.value label { + display: inline-block; + vertical-align: top; + width: 48px; +} +.value span { + font-family: FiraSans-SemiBold; + font-size: 15px; +} + +.checkbox + .checkbox { + margin-top: 0; +} + +.checkbox-sub-props { + margin-top: 18px; +} + +.property .number { + float: left; +} +.property .number + .number { + margin-left: 12px; +} + +.text label, .url label, .number label, .textarea label, .rgb label, .xyz label, .pyr label, .dropdown label, .gen label { + float: left; + margin-bottom: 4px; +} + +.number > input { + clear: both; + float: left; +} +.number > span { + clear: both; + float: left; +} +.xyz > div, .pyr > div, .gen > div { + clear: both; +} + +.unit { + padding-left: 4px; + vertical-align: top; + position: relative; + top: 5px; +} + +.dropdown { + position: relative; + margin-bottom: -17px; +} + +.dropdown select { + clear: both; +} + +.dropdown dl { + clear: both; +} +.dropdown dl { + font-family: FiraSans-SemiBold; + font-size: 15px; + width: 172px; + height: 28px; + padding: 0 28px 0 12px; + + color: #afafaf; + background: linear-gradient(#7d7d7d 20%, #686a68 100%); + + position: relative; +} +.dropdown dl[dropped="true"] { + color: #404040; + background: linear-gradient(#afafaf, #afafaf); +} + +.dropdown dt { + height: 100%; + box-sizing: border-box; + border-right: 1px solid #121212; + width: 100%; +} +.dropdown dt:hover { + color: #404040; +} +.dropdown dt:focus { + outline: none; +} +.dropdown dt span:first-child { + display: inline-block; + position: relative; + top: 5px; +} +.dropdown dt span:last-child { + font-family: HiFi-Glyphs; + font-size: 42px; + float: right; + margin-right: -48px; + position: relative; + left: -12px; + top: -11px; +} + +.dropdown dd { + position: absolute; + top: 28px; + left: 3px; + display: none; +} +.dropdown dl[dropped="true"] dd { + display: block; +} + +.dropdown li { + list-style-type: none; + padding: 3px 0 1px 12px; + width: 200px; + height: auto; + font-family: FiraSans-SemiBold; + font-size: 15px; + color: #404040; + background-color: #afafaf +} +.dropdown li:hover { + background-color: #00b4ef; +} + + +div.refresh { + box-sizing: border-box; + padding-right: 44px; +} +div.refresh input[type="button"] { + float: right; + margin-right: -44px; +} + +.color-picker { + box-sizing: border-box; + float: left; + margin-bottom: 12px; + width: 36px; + height: 36px; + border: 4px solid #afafaf; + border-radius: 4px; + background-image: url(); + background-position: bottom right; + background-repeat: no-repeat; +} +.color-picker:focus { + outline: none; +} +.color-picker[active="true"] { + border-color: #000; + background-image: url(); +} + +.rgb label { + float: left; + margin-top: 10px; + margin-left: 12px; +} +.rgb label + * { + clear: both; +} + +.tuple { + width: 100%; + text-align: center; +} +.tuple div { + display: inline-block; + position: relative; + min-width: 120px; + min-height: 1px; +} +.tuple div:nth-child(1) { + float: left; +} +.tuple div:nth-child(2) { +} +.tuple div:nth-child(3) { + float: right; +} + +.rgb .tuple input { + padding-left: 65px; +} +.xyz .tuple input { + padding-left: 25px; +} +.pyr .tuple input { + padding-left: 45px; +} + +.tuple div > label:first-child { + float: left; +} +.tuple div > label + input { + clear: both; + float: left; +} +.tuple div input + label { + display: inline !important; + float: none !important; + position: absolute; + margin-top: 8px; + margin-left: 6px; + left: 0; + font-family: FiraSans-SemiBold; + font-size: 12px; +} +.tuple .red + label, .tuple .x + label, .tuple .pitch + label { + color: #e2334d; +} +.tuple .green + label, .tuple .y + label, .tuple .yaw + label { + color: #1ac567; +} +.tuple .blue + label, .tuple .z + label, .tuple .roll + label { + color: #1080b8; +} + +.tuple .red:focus, .tuple .x:focus, .tuple .pitch:focus { + outline-color: #e2334d; +} +.tuple .green:focus, .tuple .y:focus, .tuple .yaw:focus { + outline-color: #1ac567; +} +tuple, .blue:focus, .tuple .z:focus, .tuple .roll:focus { + outline-color: #1080b8; +} + +.xyz .buttons input { + margin-top: 12px; +} +.xyz .buttons span { + word-wrap: nowrap; + white-space: nowrap; +} + +.row input { + float: left; +} +.row input[type=button] { + margin-left: 8px; + margin-right: 0; +} + + +::-webkit-scrollbar { + width: 10px; + height: 10px; +} + +::-webkit-scrollbar-track { + background-color: #2e2e2e; +} + +::-webkit-scrollbar-thumb { + background-color: #696969; + border: 2px solid #2e2e2e; + border-radius: 8px; +} + +/* FIXME: Revisit textarea resizer/corner when move to Qt 5.6 or later: see if can get resizer/corner to always be visible and +have correct background color with and without scrollbars. */ +textarea:enabled::-webkit-resizer { + background-size: 10px 10px; + background: #252525 url() no-repeat bottom right; +} +textarea:focus::-webkit-resizer { + background-size: 10px 10px; + background: #000000 url() no-repeat bottom right; +} +textarea:enabled[scrolling="true"]::-webkit-resizer { + background-size: 10px 10px; + background: #2e2e2e url() no-repeat bottom right; +} + + +#entity-list-header { + margin-bottom: 24px; +} + +#delete { + float: right; + margin-right: 0; + background-color: #ff0000; +} + +#entity-list { + position: relative; /* New positioning context. */ +} + +#search-area { + padding-right: 148px; + padding-bottom: 24px; +} + +#filter { + width: 98%; +} + +#radius-and-unit { + float: right; + margin-right: -148px; +} + + +#entity-table-scroll { + /* Height is set by JavaScript. */ + width: 100%; + overflow-x: hidden; + overflow-y: auto; + padding-top: 28px; /* Space for header and footer outside of scroll region. */ + margin-top: 28px; + border-left: 2px solid #575757; + border-right: 2px solid #575757; +} + +#entity-table-scroll, #entity-table { + background-color: #1c1c1c; +} + +#entity-table { + margin-top: -28px; + margin-bottom: -18px; + table-layout: fixed; + border: none; +} + +#entity-table thead { + border: 2px solid #575757; + border-top-left-radius: 7px; + border-top-right-radius: 7px; + border-bottom: 1px solid #575757; +} + +#entity-table tfoot { + border: 2px solid #575757; + border-bottom-left-radius: 7px; + border-bottom-right-radius: 7px; + border-top: 1px solid #575757; +} + +#entity-table thead tr, #entity-table thead tr th, +#entity-table tfoot tr, #entity-table tfoot tr td { + background: none; +} + +#entity-table th:focus { + outline: none; +} + +#col-type { + width: 16%; +} +#col-name { + width: 42%; +} +#col-url { + width: 42%; +} + +#entity-table thead { + position: absolute; + top: 49px; + left: 0; + width: 100%; +} + +#entity-table thead th { + padding: 0; +} + +#entity-table tfoot { + position: absolute; + bottom: -21px; + left: 0; + width: 100%; +} + +#no-entities { + display: none; + position: absolute; + top: 80px; + padding: 12px; + font-family: FiraSans-SemiBold; + font-size: 15px; + font-style: italic; + color: #afafaf; +} + + +#properties-list .property:first-child { + margin-top: 0; +} + +#property-id::selection { + color: #000000; + background-color: #00b4ef; +} + + +input#dimension-rescale-button { + min-width: 50px; + margin-left: 6px; +} + + +.color-set label, .color-set span { + display: block; +} +.color-set span { + padding-top: 2px; +} diff --git a/examples/html/entityList.html b/examples/html/entityList.html index ad10a50c01..532b18bb97 100644 --- a/examples/html/entityList.html +++ b/examples/html/entityList.html @@ -1,6 +1,16 @@ + + - + @@ -26,8 +36,10 @@ elDelete = document.getElementById("delete"); elTeleport = document.getElementById("teleport"); elRadius = document.getElementById("radius"); + elFooter = document.getElementById("footer-text"); elNoEntitiesMessage = document.getElementById("no-entities"); elNoEntitiesRadius = document.getElementById("no-entities-radius"); + elEntityTableScroll = document.getElementById("entity-table-scroll"); document.getElementById("entity-name").onclick = function() { setSortColumn('name'); @@ -168,6 +180,17 @@ notFound = true; } } + + if (selectedEntities.length > 1) { + elFooter.firstChild.nodeValue = selectedEntities.length + " entities selected"; + } else if (selectedEntities.length === 1) { + elFooter.firstChild.nodeValue = "1 entity selected"; + } else if (entityList.visibleItems.length === 1) { + elFooter.firstChild.nodeValue = "1 entity found"; + } else { + elFooter.firstChild.nodeValue = entityList.visibleItems.length + " entities found"; + } + return notFound; } @@ -214,57 +237,90 @@ } else if (data.type == "update") { var newEntities = data.entities; if (newEntities.length == 0) { - elEntityTable.style.display = "none"; elNoEntitiesMessage.style.display = "block"; } else { - elEntityTable.style.display = "table"; elNoEntitiesMessage.style.display = "none"; for (var i = 0; i < newEntities.length; i++) { var id = newEntities[i].id; addEntity(id, newEntities[i].name, newEntities[i].type, newEntities[i].url); } updateSelectedEntities(data.selectedIDs); + resize(); } } }); setTimeout(refreshEntities, 1000); } + + function resize() { + // Take up available window space + elEntityTableScroll.style.height = window.innerHeight - 232; + + // Update the widths of the header cells to match the body + var tds = document.querySelectorAll("#entity-table-body tr:first-child td"); + var ths = document.querySelectorAll("#entity-table thead th"); + if (tds.length >= ths.length) { + for (var i = 0; i < ths.length; i++) { + ths[i].style.width = tds[i].offsetWidth; + } + } + }; + + window.onresize = resize; + resize(); }); - } + + // Disable right-click context menu which is not visible in the HMD and makes it seem like the app has locked + document.addEventListener("contextmenu", function (event) { + event.preventDefault(); + }, false); + }
- - - + + +
-  m + m +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
Type  ▾Name File
TypeName
URL
+
+ No entities found within a 100 meter radius. Try moving to a different location and refreshing. +
- - - - - - - - - - - - - - - - -
Type  ▾Name  ▾URL
TypeName
URL
-
-
- No entities found within a 100 meter radius. Try moving to a different location and refreshing.
diff --git a/examples/html/entityProperties.html b/examples/html/entityProperties.html index 225a1d7957..bd8abb9a91 100644 --- a/examples/html/entityProperties.html +++ b/examples/html/entityProperties.html @@ -1,7 +1,17 @@ + + Properties - + @@ -36,7 +46,7 @@ function showElements(els, show) { for (var i = 0; i < els.length; i++) { - els[i].style.display = (show) ? 'block' : 'none'; + els[i].style.display = (show) ? 'table' : 'none'; } } @@ -277,6 +287,10 @@ ); }; + function setTextareaScrolling(element) { + var isScrolling = element.scrollHeight > element.offsetHeight; + element.setAttribute("scrolling", isScrolling ? "true" : "false"); + } function loaded() { openEventBridge(function() { @@ -347,7 +361,10 @@ var elLifetime = document.getElementById("property-lifetime"); var elScriptURL = document.getElementById("property-script-url"); + /* + FIXME: See FIXME for property-script-url. var elScriptTimestamp = document.getElementById("property-script-timestamp"); + */ var elReloadScriptButton = document.getElementById("reload-script-button"); var elUserData = document.getElementById("property-user-data"); @@ -455,8 +472,8 @@ var PARAM_REGEXP = /(?:\?)(\S+)/; // Check if this has any parameters. var TIMESTAMP_REGEXP = /(&?HFTime=\d+)/; - var refreshEvent = function(event){ - var urlElement = event.target.parentElement.getElementsByClassName("url")[0]; + var refreshEvent = function (event) { + var urlElement = event.target.parentElement.getElementsByTagName("INPUT")[0]; var content = urlElement.value; var date = new Date(); var timeStamp = date.getTime(); @@ -479,7 +496,7 @@ for(var index = 0; index < urlUpdaters.length; index++){ var urlUpdater = urlUpdaters[index]; - urlUpdater.addEventListener("click", refreshEvent); + urlUpdater.addEventListener("click", refreshEvent, true); } if (window.EventBridge !== undefined) { @@ -490,7 +507,7 @@ if (data.selections.length == 0) { elType.innerHTML = "No Selection"; elID.innerHTML = ""; - disableChildren(document.getElementById("properties-list"), 'input'); + disableChildren(document.getElementById("properties-list"), 'input, textarea, checkbox'); } else if (data.selections.length > 1) { var selections = data.selections; @@ -513,7 +530,7 @@ } elType.innerHTML = typeStrs.join(", "); - disableChildren(document.getElementById("properties-list"), 'input'); + disableChildren(document.getElementById("properties-list"), 'input, textarea, checkbox'); } else { var activeElement = document.activeElement; @@ -534,10 +551,10 @@ elLocked.checked = properties.locked; if (properties.locked) { - disableChildren(document.getElementById("properties-list"), 'input'); + disableChildren(document.getElementById("properties-list"), 'input, textarea, checkbox'); elLocked.removeAttribute('disabled'); } else { - enableChildren(document.getElementById("properties-list"), 'input'); + enableChildren(document.getElementById("properties-list"), 'input, textarea, checkbox'); } @@ -617,8 +634,12 @@ elCollisionSoundURL.value = properties.collisionSoundURL; elLifetime.value = properties.lifetime; elScriptURL.value = properties.script; + /* + FIXME: See FIXME for property-script-url. elScriptTimestamp.value = properties.scriptTimestamp; + */ elUserData.value = properties.userData; + setTextareaScrolling(elUserData); elHyperlinkHref.value = properties.href; elHyperlinkDescription.value = properties.description; @@ -630,11 +651,11 @@ } for (var i = 0; i < elHyperlinkSections.length; i++) { - elHyperlinkSections[i].style.display = 'block'; + elHyperlinkSections[i].style.display = 'table'; } if (properties.type == "Box" || properties.type == "Sphere" || properties.type == "ParticleEffect") { - elColorSection.style.display = 'block'; + elColorSection.style.display = 'table'; elColorRed.value = properties.color.red; elColorGreen.value = properties.color.green; elColorBlue.value = properties.color.blue; @@ -645,11 +666,12 @@ if (properties.type == "Model") { for (var i = 0; i < elModelSections.length; i++) { - elModelSections[i].style.display = 'block'; + elModelSections[i].style.display = 'table'; } elModelURL.value = properties.modelURL; elShapeType.value = properties.shapeType; + setDropdownText(elShapeType); elCompoundShapeURL.value = properties.compoundShapeURL; elModelAnimationURL.value = properties.animation.url; elModelAnimationPlaying.checked = properties.animation.running; @@ -660,10 +682,12 @@ elModelAnimationLoop.checked = properties.animation.loop; elModelAnimationHold.checked = properties.animation.hold; elModelTextures.value = properties.textures; + setTextareaScrolling(elModelTextures); elModelOriginalTextures.value = properties.originalTextures; + setTextareaScrolling(elModelOriginalTextures); } else if (properties.type == "Web") { for (var i = 0; i < elWebSections.length; i++) { - elWebSections[i].style.display = 'block'; + elWebSections[i].style.display = 'table'; } for (var i = 0; i < elHyperlinkSections.length; i++) { elHyperlinkSections[i].style.display = 'none'; @@ -672,7 +696,7 @@ elWebSourceURL.value = properties.sourceUrl; } else if (properties.type == "Text") { for (var i = 0; i < elTextSections.length; i++) { - elTextSections[i].style.display = 'block'; + elTextSections[i].style.display = 'table'; } elTextText.value = properties.text; @@ -686,7 +710,7 @@ elTextBackgroundColorBlue.value = properties.backgroundColor.blue; } else if (properties.type == "Light") { for (var i = 0; i < elLightSections.length; i++) { - elLightSections[i].style.display = 'block'; + elLightSections[i].style.display = 'table'; } elLightSpotLight.checked = properties.isSpotlight; @@ -702,7 +726,7 @@ elLightCutoff.value = properties.cutoff.toFixed(2); } else if (properties.type == "Zone") { for (var i = 0; i < elZoneSections.length; i++) { - elZoneSections[i].style.display = 'block'; + elZoneSections[i].style.display = 'table'; } elZoneStageSunModelEnabled.checked = properties.stage.sunModelEnabled; @@ -727,6 +751,7 @@ elCompoundShapeURL.value = properties.compoundShapeURL; elZoneBackgroundMode.value = properties.backgroundMode; + setDropdownText(elZoneBackgroundMode); elZoneSkyboxColor.style.backgroundColor = "rgb(" + properties.skybox.color.red + "," + properties.skybox.color.green + "," + properties.skybox.color.blue + ")"; elZoneSkyboxColorRed.value = properties.skybox.color.red; @@ -737,13 +762,14 @@ showElements(document.getElementsByClassName('skybox-section'), elZoneBackgroundMode.value == 'skybox'); } else if (properties.type == "PolyVox") { for (var i = 0; i < elPolyVoxSections.length; i++) { - elPolyVoxSections[i].style.display = 'block'; + elPolyVoxSections[i].style.display = 'table'; } elVoxelVolumeSizeX.value = properties.voxelVolumeSize.x.toFixed(2); elVoxelVolumeSizeY.value = properties.voxelVolumeSize.y.toFixed(2); elVoxelVolumeSizeZ.value = properties.voxelVolumeSize.z.toFixed(2); elVoxelSurfaceStyle.value = properties.voxelSurfaceStyle; + setDropdownText(elVoxelSurfaceStyle); elXTextureURL.value = properties.xTextureURL; elYTextureURL.value = properties.yTextureURL; elZTextureURL.value = properties.zTextureURL; @@ -856,7 +882,10 @@ elLifetime.addEventListener('change', createEmitNumberPropertyUpdateFunction('lifetime')); elScriptURL.addEventListener('change', createEmitTextPropertyUpdateFunction('script')); + /* + FIXME: See FIXME for property-script-url. elScriptTimestamp.addEventListener('change', createEmitNumberPropertyUpdateFunction('scriptTimestamp')); + */ elUserData.addEventListener('change', createEmitTextPropertyUpdateFunction('userData')); var colorChangeFunction = createEmitColorPropertyUpdateFunction( @@ -868,7 +897,13 @@ colorScheme:'dark', layout:'hex', color:'000000', - onSubmit: function(hsb, hex, rgb, el) { + onShow: function (colpick) { + $('#property-color').attr('active', 'true'); + }, + onHide: function (colpick) { + $('#property-color').attr('active', 'false'); + }, + onSubmit: function (hsb, hex, rgb, el) { $(el).css('background-color', '#'+hex); $(el).colpickHide(); emitColorPropertyUpdate('color', rgb.r, rgb.g, rgb.b); @@ -886,7 +921,13 @@ colorScheme:'dark', layout:'hex', color:'000000', - onSubmit: function(hsb, hex, rgb, el) { + onShow: function (colpick) { + $('#property-light-color').attr('active', 'true'); + }, + onHide: function (colpick) { + $('#property-light-color').attr('active', 'false'); + }, + onSubmit: function (hsb, hex, rgb, el) { $(el).css('background-color', '#'+hex); $(el).colpickHide(); emitColorPropertyUpdate('color', rgb.r, rgb.g, rgb.b); @@ -926,10 +967,17 @@ $('#property-text-text-color').colpick({ colorScheme:'dark', layout:'hex', - color:'000000', - onSubmit: function(hsb, hex, rgb, el) { + color: '000000', + onShow: function (colpick) { + $('#property-text-text-color').attr('active', 'true'); + }, + onHide: function (colpick) { + $('#property-text-text-color').attr('active', 'false'); + }, + onSubmit: function (hsb, hex, rgb, el) { $(el).css('background-color', '#'+hex); $(el).colpickHide(); + $(el).attr('active', 'false'); emitColorPropertyUpdate('textColor', rgb.r, rgb.g, rgb.b); } }); @@ -943,7 +991,13 @@ colorScheme:'dark', layout:'hex', color:'000000', - onSubmit: function(hsb, hex, rgb, el) { + onShow: function (colpick) { + $('#property-text-background-color').attr('active', 'true'); + }, + onHide: function (colpick) { + $('#property-text-background-color').attr('active', 'false'); + }, + onSubmit: function (hsb, hex, rgb, el) { $(el).css('background-color', '#'+hex); $(el).colpickHide(); emitColorPropertyUpdate('backgroundColor', rgb.r, rgb.g, rgb.b); @@ -955,7 +1009,13 @@ colorScheme:'dark', layout:'hex', color:'000000', - onSubmit: function(hsb, hex, rgb, el) { + onShow: function (colpick) { + $('#property-zone-key-light-color').attr('active', 'true'); + }, + onHide: function (colpick) { + $('#property-zone-key-light-color').attr('active', 'false'); + }, + onSubmit: function (hsb, hex, rgb, el) { $(el).css('background-color', '#'+hex); $(el).colpickHide(); emitColorPropertyUpdate('color', rgb.r, rgb.g, rgb.b, 'keyLight'); @@ -990,7 +1050,13 @@ colorScheme:'dark', layout:'hex', color:'000000', - onSubmit: function(hsb, hex, rgb, el) { + onShow: function (colpick) { + $('#property-zone-skybox-color').attr('active', 'true'); + }, + onHide: function (colpick) { + $('#property-zone-skybox-color').attr('active', 'false'); + }, + onSubmit: function (hsb, hex, rgb, el) { $(el).css('background-color', '#'+hex); $(el).colpickHide(); emitColorPropertyUpdate('color', rgb.r, rgb.g, rgb.b, 'skybox'); @@ -1034,12 +1100,15 @@ percentage: parseInt(elRescaleDimensionsPct.value), })); }); + /* + FIXME: See FIXME for property-script-url. elReloadScriptButton.addEventListener("click", function() { EventBridge.emitWebEvent(JSON.stringify({ type: "action", action: "reloadScript" })); }); + */ elPreviewCameraButton.addEventListener("click", function() { EventBridge.emitWebEvent(JSON.stringify({ type: "action", @@ -1080,687 +1149,647 @@ }; } }); - } + // Collapsible sections + var elCollapsible = document.getElementsByClassName("section-header"); + + var toggleCollapsedEvent = function (event) { + var element = event.target; + if (element.nodeName !== "DIV") { + element = element.parentNode; + } + var isCollapsed = element.getAttribute("collapsed") !== "true"; + element.setAttribute("collapsed", isCollapsed ? "true" : "false"); + element.getElementsByTagName("span")[0].textContent = isCollapsed ? "L" : "M"; + }; + + for (var i = 0, length = elCollapsible.length; i < length; i++) { + var element = elCollapsible[i]; + element.addEventListener("click", toggleCollapsedEvent, true); + }; + + + // Textarea scollbars + var elTextareas = document.getElementsByTagName("TEXTAREA"); + + var textareaOnChangeEvent = function (event) { + setTextareaScrolling(event.target); + } + + for (var i = 0, length = elTextareas.length; i < length; i++) { + var element = elTextareas[i]; + setTextareaScrolling(element); + element.addEventListener("input", textareaOnChangeEvent, false); + element.addEventListener("change", textareaOnChangeEvent, false); + /* FIXME: Detect and update textarea scrolling attribute on resize. Unfortunately textarea doesn't have a resize + event; mouseup is a partial stand-in but doesn't handle resizing if mouse moves outside textarea rectangle. */ + element.addEventListener("mouseup", textareaOnChangeEvent, false); + }; + + // Dropdowns + // For each dropdown the following replacement is created in place of the oriringal dropdown... + // Structure created: + //
+ //
display textcarat
+ //
+ //