Mercurial > hg > NetworkVis
comparison d3s_examples/python-neo4jrestclient/static/platin/js/Map/PlacenamePopup.js @ 8:18ef6948d689
new d3s examples
author | Dirk Wintergruen <dwinter@mpiwg-berlin.mpg.de> |
---|---|
date | Thu, 01 Oct 2015 17:17:27 +0200 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
7:45dad9e38c82 | 8:18ef6948d689 |
---|---|
1 /* | |
2 * PlacenamePopup.js | |
3 * | |
4 * Copyright (c) 2012, Stefan Jänicke. All rights reserved. | |
5 * | |
6 * This library is free software; you can redistribute it and/or | |
7 * modify it under the terms of the GNU Lesser General Public | |
8 * License as published by the Free Software Foundation; either | |
9 * version 3 of the License, or (at your option) any later version. | |
10 * | |
11 * This library is distributed in the hope that it will be useful, | |
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
14 * Lesser General Public License for more details. | |
15 * | |
16 * You should have received a copy of the GNU Lesser General Public | |
17 * License along with this library; if not, write to the Free Software | |
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | |
19 * MA 02110-1301 USA | |
20 */ | |
21 | |
22 /** | |
23 * @class PlacenamePopup | |
24 * specific map popup for showing and interacting on placename labels | |
25 * @author Stefan Jänicke (stjaenicke@informatik.uni-leipzig.de) | |
26 * @release 1.0 | |
27 * @release date: 2012-07-27 | |
28 * @version date: 2012-07-27 | |
29 */ | |
30 function PlacenamePopup(parent) { | |
31 | |
32 this.parentDiv = parent.gui.mapWindow; | |
33 | |
34 this.createPopup = function(x, y, labels) { | |
35 this.labels = labels; | |
36 var pnPopup = this; | |
37 var popup = new MapPopup(parent); | |
38 var onClose = function() { | |
39 parent.deselection(); | |
40 pnPopup.reset(); | |
41 } | |
42 popup.initialize(x, y, onClose); | |
43 $.extend(this, popup); | |
44 | |
45 this.content = document.createElement("div"); | |
46 this.inner = document.createElement("div"); | |
47 | |
48 this.resultsLabel = document.createElement("div"); | |
49 this.resultsLabel.setAttribute('class', 'popupDDBResults'); | |
50 this.content.appendChild(this.resultsLabel); | |
51 this.backward = document.createElement("div"); | |
52 this.backward.setAttribute('class', 'prevItem'); | |
53 this.content.appendChild(this.backward); | |
54 this.backward.onclick = function() { | |
55 pnPopup.descriptionIndex--; | |
56 pnPopup.showDescription(); | |
57 } | |
58 | |
59 this.number = document.createElement("div"); | |
60 this.content.appendChild(this.number); | |
61 this.number.style.display = 'none'; | |
62 this.number.style.fontSize = '13px'; | |
63 | |
64 this.forward = document.createElement("div"); | |
65 this.forward.setAttribute('class', 'nextItem'); | |
66 this.content.appendChild(this.forward); | |
67 this.forward.onclick = function() { | |
68 pnPopup.descriptionIndex++; | |
69 pnPopup.showDescription(); | |
70 } | |
71 if (parent.options.showDescriptions) { | |
72 this.descriptions = document.createElement("div"); | |
73 this.descriptions.setAttribute('class', 'descriptions'); | |
74 this.descriptions.onclick = function() { | |
75 pnPopup.switchToDescriptionMode(); | |
76 } | |
77 } | |
78 | |
79 this.back = document.createElement("div"); | |
80 this.back.setAttribute('class', 'back'); | |
81 this.popupDiv.appendChild(this.back); | |
82 this.back.onclick = function() { | |
83 pnPopup.back.style.display = "none"; | |
84 pnPopup.backward.style.display = "none"; | |
85 pnPopup.forward.style.display = "none"; | |
86 pnPopup.number.style.display = 'none'; | |
87 pnPopup.showLabels(); | |
88 } | |
89 | |
90 this.content.appendChild(this.inner); | |
91 this.listLabels(); | |
92 this.showLabels(); | |
93 | |
94 }; | |
95 | |
96 this.switchToDescriptionMode = function() { | |
97 this.descriptionIndex = 0; | |
98 this.descriptionContents = this.activeLabel.descriptions; | |
99 this.number.style.display = 'inline-block'; | |
100 this.inner.style.minWidth = "300px"; | |
101 this.showDescription(); | |
102 this.count = this.activeLabel.weight; | |
103 this.setCount(); | |
104 this.back.style.display = "inline-block"; | |
105 } | |
106 | |
107 this.showDescription = function() { | |
108 $(this.inner).empty(); | |
109 this.inner.appendChild(this.descriptionContents[this.descriptionIndex]); | |
110 this.setContent(this.content); | |
111 if (this.descriptionContents.length == 1) { | |
112 this.backward.style.display = "none"; | |
113 this.forward.style.display = "none"; | |
114 } else { | |
115 if (this.descriptionIndex == 0) { | |
116 this.backward.style.display = "none"; | |
117 } else { | |
118 this.backward.style.display = "inline-block"; | |
119 } | |
120 if (this.descriptionIndex == this.descriptionContents.length - 1) { | |
121 this.forward.style.display = "none"; | |
122 } else { | |
123 this.forward.style.display = "inline-block"; | |
124 } | |
125 } | |
126 if (this.descriptionContents.length > 1) { | |
127 this.number.innerHTML = "#" + (this.descriptionIndex + 1); | |
128 } else { | |
129 this.number.style.display = 'none'; | |
130 } | |
131 this.decorate(); | |
132 } | |
133 | |
134 this.setCount = function() { | |
135 var c = this.count; | |
136 if (c > 1) { | |
137 this.resultsLabel.innerHTML = c + " " + GeoTemConfig.getString('results'); | |
138 } else { | |
139 this.resultsLabel.innerHTML = c + " " + GeoTemConfig.getString('result'); | |
140 } | |
141 } | |
142 | |
143 this.listLabels = function() { | |
144 var pnPopup = this; | |
145 this.labelDivs = []; | |
146 this.labelCount = 0; | |
147 this.labelsWidth = 0; | |
148 for (var i = 0; i < this.labels.length; i++) { | |
149 var div = document.createElement("div"); | |
150 var content = document.createElement("div"); | |
151 this.labels[i].allStyle += "position: relative; white-space: nowrap;"; | |
152 content.appendChild(this.labels[i].div); | |
153 content.setAttribute('class', 'ddbPopupLabel'); | |
154 div.appendChild(content); | |
155 this.labels[i].div.setAttribute('style', this.labels[i].allStyle + "" + this.labels[i].selectedStyle); | |
156 this.input.appendChild(div); | |
157 if (this.input.offsetWidth > this.labelsWidth) { | |
158 this.labelsWidth = this.input.offsetWidth; | |
159 } | |
160 this.labels[i].div.setAttribute('style', this.labels[i].allStyle + "" + this.labels[i].unselectedStyle); | |
161 this.labelDivs.push(div); | |
162 var descriptions = []; | |
163 for (var j = 0; j < this.labels[i].elements.length; j++) { | |
164 var div = document.createElement("div"); | |
165 div.innerHTML = this.labels[i].elements[j].description; | |
166 descriptions.push(div); | |
167 } | |
168 this.labels[i].descriptions = descriptions; | |
169 if (this.labels[i].place != "all" || i == 0) { | |
170 this.labelCount += this.labels[i].weight; | |
171 } | |
172 } | |
173 if ( typeof this.descriptions != 'undefined') { | |
174 this.labelsWidth += 20; | |
175 } | |
176 } | |
177 | |
178 this.showLabels = function() { | |
179 $(this.inner).empty(); | |
180 this.count = this.labelCount; | |
181 this.setCount(); | |
182 for (var i = 0; i < this.labelDivs.length; i++) { | |
183 this.inner.appendChild(this.labelDivs[i]); | |
184 } | |
185 this.inner.style.width = this.labelsWidth + "px"; | |
186 this.inner.style.minWidth = this.labelsWidth + "px"; | |
187 this.setContent(this.content); | |
188 this.decorate(); | |
189 } | |
190 | |
191 this.showLabelContent = function(label) { | |
192 for (var i = 0; i < this.labels.length; i++) { | |
193 if (this.labels[i] == label) { | |
194 this.activeLabel = this.labels[i]; | |
195 if ( typeof this.descriptions != 'undefined') { | |
196 this.labelDivs[i].appendChild(this.descriptions); | |
197 } | |
198 this.decorate(); | |
199 break; | |
200 } | |
201 } | |
202 } | |
203 | |
204 this.setLanguage = function(language) { | |
205 this.language = language; | |
206 if (this.visible) { | |
207 this.updateTexts(); | |
208 } | |
209 } | |
210 }; |