/usr/share/pyshared/advancedcaching/qt/searchgeocachesdialog.py is in agtl 0.8.0.3-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 | #!/usr/bin/python
# -*- coding: utf-8 -*-
# Copyright (C) 2010 Daniel Fett
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# Author: Daniel Fett agtl@danielfett.de
# Jabber: fett.daniel@jaber.ccc.de
# Bugtracker and GIT Repository: http://github.com/webhamster/advancedcaching
#
import logging
from PyQt4.QtCore import *
from PyQt4.QtGui import *
import geocaching
from searchresultsdialog import QtSearchResultsDialog
from ui_searchgeocachesdialog import Ui_SearchGeocachesDialog
d = lambda x: x.decode('utf-8')
logger = logging.getLogger('qtsearchgeocachesdialog')
class QtSearchGeocachesDialog(Ui_SearchGeocachesDialog, QDialog):
RADI = [1, 2, 3, 5, 10, 15, 20, 50, 100]
TYPELIST = [
('traditional', geocaching.GeocacheCoordinate.TYPE_REGULAR),
('multi stage', geocaching.GeocacheCoordinate.TYPE_MULTI),
('virtual', geocaching.GeocacheCoordinate.TYPE_VIRTUAL),
('earth', geocaching.GeocacheCoordinate.TYPE_EARTH),
('event', geocaching.GeocacheCoordinate.TYPE_EVENT),
('mystery', geocaching.GeocacheCoordinate.TYPE_MYSTERY),
('webcam', geocaching.GeocacheCoordinate.TYPE_WEBCAM),
('all/other', geocaching.GeocacheCoordinate.TYPE_UNKNOWN)
]
def __init__(self, core, map_position, user_position, parent=None):
QDialog.__init__(self, parent)
self.core = core
self.setupUi(self)
self.populateUi()
self.setModal(True)
self.dialogButtonBox.clicked.connect(self.__button_clicked)
self.map_position = map_position
self.user_position = user_position
def populateUi(self):
for name, type in self.TYPELIST:
m = QListWidgetItem(name, self.listWidgetType)
m.setCheckState(Qt.Unchecked if type == geocaching.GeocacheCoordinate.TYPE_UNKNOWN else Qt.Checked)
self.comboBoxLocation.currentIndexChanged.connect(self.__combo_box_changed)
def __combo_box_changed(self, index):
self.spinBoxRadius.setEnabled(index != 0)
if index == 1:
text = self.map_position.get_latlon() if self.map_position != None else 'not available'
elif index == 2:
text = self.user_position.get_latlon() if self.user_position != None else 'not available'
else:
text = ''
self.labelLocation.setText(d(text))
def show(self):
QDialog.show(self)
def __button_clicked(self, button):
id = self.dialogButtonBox.standardButton(button)
if id == QDialogButtonBox.Ok:
self.__start_search()
def __start_search(self):
# Name
name = str(self.lineEditName.text()).strip().lower()
if name == '':
name = None
logger.debug("Name: %s" % name)
# Location & Radius
i = self.comboBoxLocation.currentIndex()
if i == 1 and self.map_position != None:
center = self.map_position
elif i == 2 and self.user_position != None:
center = self.user_position
else:
center = None
if center != None:
radius = self.spinBoxRadius.value()
sqrt_2 = 1.41421356
c1 = center.transform(-45, radius * 1000 * sqrt_2)
c2 = center.transform(-45 + 180, radius * 1000 * sqrt_2)
location = (c2, c1)
logger.debug("Location: %s %s" % location)
else:
location = None
logger.debug("Location: None")
# Details (1)
types = [self.TYPELIST[x][1] for x in range(self.listWidgetType.count()) if self.listWidgetType.item(x).checkState() == Qt.Checked]
if geocaching.GeocacheCoordinate.TYPE_UNKNOWN in types:
types = None
logger.debug("Types: %s" % types)
if self.checkBoxHideFound.checkState() == Qt.Checked:
found = False
else:
found = None
logger.debug("Found: %s" % found)
if self.checkBoxShowOnlyMarked.checkState() == Qt.Checked:
marked = True
else:
marked = False
logger.debug("Marked: %s" % marked)
# Details (2)
sizes = [x + 1 for x in range(self.listWidgetSize.count()) if self.listWidgetSize.item(x).checkState() == Qt.Checked]
if sizes == [1, 2, 3, 4, 5]:
sizes = None
logger.debug("Sizes: %s" % sizes)
r = lambda x: int(x / 0.5) * 0.5
diff_min = r(self.doubleSpinBoxDifficultyMin.value())
diff_max = r(self.doubleSpinBoxDifficultyMax.value() + 0.5)
if diff_min == 1 and diff_max == 5.5:
difficulties = None
else:
# range doesn't support floats!
difficulties = [x / 10.0 for x in range(int(diff_min * 10), int(diff_max * 10), 5)]
logger.debug("Difficulties: %s" % difficulties)
terr_min = r(self.doubleSpinBoxTerrainMin.value())
terr_max = r(self.doubleSpinBoxTerrainMax.value() + 0.5)
if terr_min == 1 and terr_max == 5.5:
terrains = None
else:
# range doesn't support floats!
terrains = [x / 10.0 for x in range(int(terr_min * 10), int(terr_max * 10), 5)]
logger.debug("Terrains: %s" % terrains)
results = self.core.get_points_filter(found=found, name_search=name, size=sizes, terrain=terrains, diff=difficulties, ctype=types, marked=marked, location=location)
logger.debug("Found %d results" % len(results[0]))
self.__show_results(results)
def __show_results(self, results):
d = QtSearchResultsDialog(self.core)
d.show(results[0])
|