Merge branch 'master' into fleet
This commit is contained in:
1
.gitignore
vendored
1
.gitignore
vendored
@@ -12,3 +12,4 @@
|
|||||||
#Patch files
|
#Patch files
|
||||||
*.patch
|
*.patch
|
||||||
#Personal
|
#Personal
|
||||||
|
/saveddata
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
__all__ = ["pyfaGlobalPreferences","pyfaHTMLExportPreferences"]
|
__all__ = ["pyfaGlobalPreferences","pyfaHTMLExportPreferences","pyfaUpdatePreferences"]
|
||||||
|
|||||||
119
gui/builtinPreferenceViews/pyfaUpdatePreferences.py
Normal file
119
gui/builtinPreferenceViews/pyfaUpdatePreferences.py
Normal file
@@ -0,0 +1,119 @@
|
|||||||
|
import wx
|
||||||
|
import service
|
||||||
|
import os
|
||||||
|
|
||||||
|
from gui.preferenceView import PreferenceView
|
||||||
|
from gui import bitmapLoader
|
||||||
|
|
||||||
|
import service
|
||||||
|
import gui.globalEvents as GE
|
||||||
|
|
||||||
|
|
||||||
|
class PFUpdatePref (PreferenceView):
|
||||||
|
title = "Pyfa Update Options"
|
||||||
|
desc = """
|
||||||
|
Pyfa can automatically check and notify you of new releases.
|
||||||
|
These options will allow you to choose what kind of updates, if any, you wish
|
||||||
|
to receive notifications for.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def populatePanel( self, panel ):
|
||||||
|
self.UpdateSettings = service.settings.UpdateSettings.getInstance()
|
||||||
|
self.dirtySettings = False
|
||||||
|
|
||||||
|
mainSizer = wx.BoxSizer( wx.VERTICAL )
|
||||||
|
|
||||||
|
self.stTitle = wx.StaticText( panel, wx.ID_ANY, self.title, wx.DefaultPosition, wx.DefaultSize, 0 )
|
||||||
|
self.stTitle.Wrap( -1 )
|
||||||
|
self.stTitle.SetFont( wx.Font( 12, 70, 90, 90, False, wx.EmptyString ) )
|
||||||
|
mainSizer.Add( self.stTitle, 0, wx.ALL, 5 )
|
||||||
|
|
||||||
|
self.stDesc = wx.StaticText( panel, wx.ID_ANY, self.desc, wx.DefaultPosition, wx.DefaultSize, 0 )
|
||||||
|
mainSizer.Add( self.stDesc, 0, wx.ALL, 5 )
|
||||||
|
|
||||||
|
self.suppressAll = wx.CheckBox( panel, wx.ID_ANY, u"Don't check for updates", wx.DefaultPosition, wx.DefaultSize, 0 )
|
||||||
|
self.suppressPrerelease = wx.CheckBox( panel, wx.ID_ANY, u"Allow pre-release notifications", wx.DefaultPosition, wx.DefaultSize, 0 )
|
||||||
|
|
||||||
|
mainSizer.Add( self.suppressAll, 0, wx.ALL|wx.EXPAND, 5 )
|
||||||
|
mainSizer.Add( self.suppressPrerelease, 0, wx.ALL|wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
self.suppressAll.Bind(wx.EVT_CHECKBOX, self.OnSuppressAllStateChange)
|
||||||
|
self.suppressPrerelease.Bind(wx.EVT_CHECKBOX, self.OnPrereleaseStateChange)
|
||||||
|
|
||||||
|
self.suppressAll.SetValue(self.UpdateSettings.get('all'))
|
||||||
|
self.suppressPrerelease.SetValue(not self.UpdateSettings.get('prerelease'))
|
||||||
|
|
||||||
|
if (self.UpdateSettings.get('version')):
|
||||||
|
self.versionSizer = wx.BoxSizer( wx.VERTICAL )
|
||||||
|
|
||||||
|
|
||||||
|
self.versionTitle = wx.StaticText( panel, wx.ID_ANY, "Suppressing "+self.UpdateSettings.get('version')+" Notifications", wx.DefaultPosition, wx.DefaultSize, 0 )
|
||||||
|
self.versionTitle.Wrap( -1 )
|
||||||
|
self.versionTitle.SetFont( wx.Font( 12, 70, 90, 90, False, wx.EmptyString ) )
|
||||||
|
|
||||||
|
self.versionInfo = '''
|
||||||
|
There is a release available which you have chosen to suppress.
|
||||||
|
You can choose to reset notification suppression for this release,
|
||||||
|
or download the new release from GitHub.
|
||||||
|
'''
|
||||||
|
|
||||||
|
self.versionSizer.AddSpacer( ( 5, 5), 0, wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
self.versionSizer.Add( wx.StaticLine( panel, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL ), 0, wx.EXPAND, 5 )
|
||||||
|
self.versionSizer.AddSpacer( ( 5, 5), 0, wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
self.versionSizer.Add( self.versionTitle, 0, wx.EXPAND, 5 )
|
||||||
|
self.versionDesc = wx.StaticText( panel, wx.ID_ANY, self.versionInfo, wx.DefaultPosition, wx.DefaultSize, 0 )
|
||||||
|
self.versionSizer.Add( self.versionDesc, 0, wx.ALL, 5 )
|
||||||
|
|
||||||
|
actionSizer = wx.BoxSizer( wx.HORIZONTAL )
|
||||||
|
resetSizer = wx.BoxSizer( wx.VERTICAL )
|
||||||
|
|
||||||
|
self.downloadButton = wx.Button( panel, wx.ID_ANY, "Download", wx.DefaultPosition, wx.DefaultSize, 0 )
|
||||||
|
self.downloadButton.Bind(wx.EVT_BUTTON, self.OnDownload)
|
||||||
|
resetSizer.Add( self.downloadButton, 0, wx.ALL, 5 )
|
||||||
|
actionSizer.Add( resetSizer, 1, wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
self.resetButton = wx.Button( panel, wx.ID_ANY, "Reset Suppression", wx.DefaultPosition, wx.DefaultSize, 0 )
|
||||||
|
self.resetButton.Bind(wx.EVT_BUTTON, self.ResetSuppression)
|
||||||
|
actionSizer.Add( self.resetButton, 0, wx.ALL, 5 )
|
||||||
|
self.versionSizer.Add( actionSizer, 0, wx.EXPAND, 5 )
|
||||||
|
mainSizer.Add( self.versionSizer, 0, wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
self.ToggleSuppressAll(self.suppressAll.IsChecked())
|
||||||
|
|
||||||
|
panel.SetSizer( mainSizer )
|
||||||
|
panel.Layout()
|
||||||
|
|
||||||
|
def ToggleSuppressAll(self, bool):
|
||||||
|
''' Toggles other inputs on/off depending on value of SuppressAll '''
|
||||||
|
if bool:
|
||||||
|
self.suppressPrerelease.Disable()
|
||||||
|
else:
|
||||||
|
self.suppressPrerelease.Enable()
|
||||||
|
|
||||||
|
def OnSuppressAllStateChange(self, event):
|
||||||
|
self.UpdateSettings.set('all', self.suppressAll.IsChecked())
|
||||||
|
self.ToggleSuppressAll(self.suppressAll.IsChecked())
|
||||||
|
|
||||||
|
def OnPrereleaseStateChange(self, event):
|
||||||
|
self.UpdateSettings.set('prerelease', not self.suppressPrerelease.IsChecked())
|
||||||
|
|
||||||
|
def ResetSuppression(self, event):
|
||||||
|
self.UpdateSettings.set('version', None)
|
||||||
|
|
||||||
|
# Todo: Find a way to hide the entire panel in one go
|
||||||
|
self.versionSizer.Hide(True)
|
||||||
|
self.versionTitle.Hide()
|
||||||
|
self.versionDesc.Hide()
|
||||||
|
self.downloadButton.Hide()
|
||||||
|
self.resetButton.Hide()
|
||||||
|
self.resetButton.Hide()
|
||||||
|
|
||||||
|
def OnDownload(self, event):
|
||||||
|
wx.LaunchDefaultBrowser('https://github.com/DarkFenX/Pyfa/releases/tag/'+self.UpdateSettings.get('version'))
|
||||||
|
|
||||||
|
def getImage(self):
|
||||||
|
return bitmapLoader.getBitmap("pyfa64", "icons")
|
||||||
|
|
||||||
|
PFUpdatePref.register()
|
||||||
@@ -230,7 +230,7 @@ class FittingView(d.Display):
|
|||||||
self.removeModule(self.mods[row])
|
self.removeModule(self.mods[row])
|
||||||
self.Select(row,0)
|
self.Select(row,0)
|
||||||
row = self.GetNextSelected(row)
|
row = self.GetNextSelected(row)
|
||||||
|
|
||||||
event.Skip()
|
event.Skip()
|
||||||
|
|
||||||
def fitRemoved(self, event):
|
def fitRemoved(self, event):
|
||||||
@@ -288,9 +288,8 @@ class FittingView(d.Display):
|
|||||||
wx.PostEvent(self.mainFrame, GE.FitChanged(fitID=fitID))
|
wx.PostEvent(self.mainFrame, GE.FitChanged(fitID=fitID))
|
||||||
else:
|
else:
|
||||||
populate = cFit.appendModule(fitID, itemID)
|
populate = cFit.appendModule(fitID, itemID)
|
||||||
if populate:
|
|
||||||
self.slotsChanged()
|
|
||||||
if populate is not None:
|
if populate is not None:
|
||||||
|
self.slotsChanged()
|
||||||
wx.PostEvent(self.mainFrame, GE.FitChanged(fitID=fitID))
|
wx.PostEvent(self.mainFrame, GE.FitChanged(fitID=fitID))
|
||||||
|
|
||||||
event.Skip()
|
event.Skip()
|
||||||
@@ -304,14 +303,14 @@ class FittingView(d.Display):
|
|||||||
else:
|
else:
|
||||||
if "wxMSW" in wx.PlatformInfo:
|
if "wxMSW" in wx.PlatformInfo:
|
||||||
self.click(event)
|
self.click(event)
|
||||||
|
|
||||||
def removeModule(self, module):
|
def removeModule(self, module):
|
||||||
cFit = service.Fit.getInstance()
|
cFit = service.Fit.getInstance()
|
||||||
fit = cFit.getFit(self.activeFitID)
|
fit = cFit.getFit(self.activeFitID)
|
||||||
populate = cFit.removeModule(self.activeFitID, fit.modules.index(module))
|
populate = cFit.removeModule(self.activeFitID, fit.modules.index(module))
|
||||||
|
|
||||||
if populate is not None:
|
if populate is not None:
|
||||||
if populate: self.slotsChanged()
|
self.slotsChanged()
|
||||||
wx.PostEvent(self.mainFrame, GE.FitChanged(fitID=self.activeFitID))
|
wx.PostEvent(self.mainFrame, GE.FitChanged(fitID=self.activeFitID))
|
||||||
|
|
||||||
def swapItems(self, x, y, itemID):
|
def swapItems(self, x, y, itemID):
|
||||||
@@ -373,16 +372,16 @@ class FittingView(d.Display):
|
|||||||
if self.activeFitID is not None and self.activeFitID == event.fitID:
|
if self.activeFitID is not None and self.activeFitID == event.fitID:
|
||||||
self.generateMods()
|
self.generateMods()
|
||||||
self.refresh(self.mods)
|
self.refresh(self.mods)
|
||||||
|
|
||||||
exportHtml.getInstance().refreshFittingHTMl()
|
exportHtml.getInstance().refreshFittingHTMl()
|
||||||
|
|
||||||
self.Show(self.activeFitID is not None and self.activeFitID == event.fitID)
|
self.Show(self.activeFitID is not None and self.activeFitID == event.fitID)
|
||||||
except wx._core.PyDeadObjectError:
|
except wx._core.PyDeadObjectError:
|
||||||
pass
|
pass
|
||||||
finally:
|
finally:
|
||||||
event.Skip()
|
event.Skip()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def scheduleMenu(self, event):
|
def scheduleMenu(self, event):
|
||||||
event.Skip()
|
event.Skip()
|
||||||
@@ -451,7 +450,7 @@ class FittingView(d.Display):
|
|||||||
5: ''}
|
5: ''}
|
||||||
def slotColour(self, slot):
|
def slotColour(self, slot):
|
||||||
return self.slotColourMap[slot] or self.GetBackgroundColour()
|
return self.slotColourMap[slot] or self.GetBackgroundColour()
|
||||||
|
|
||||||
def refresh(self, stuff):
|
def refresh(self, stuff):
|
||||||
d.Display.refresh(self, stuff)
|
d.Display.refresh(self, stuff)
|
||||||
sFit = service.Fit.getInstance()
|
sFit = service.Fit.getInstance()
|
||||||
@@ -460,7 +459,7 @@ class FittingView(d.Display):
|
|||||||
for slotType in Slot.getTypes():
|
for slotType in Slot.getTypes():
|
||||||
slot = Slot.getValue(slotType)
|
slot = Slot.getValue(slotType)
|
||||||
slotMap[slot] = fit.getSlotsFree(slot) < 0
|
slotMap[slot] = fit.getSlotsFree(slot) < 0
|
||||||
|
|
||||||
for i, mod in enumerate(self.mods):
|
for i, mod in enumerate(self.mods):
|
||||||
if slotMap[mod.slot]:
|
if slotMap[mod.slot]:
|
||||||
self.SetItemBackgroundColour(i, wx.Colour(204, 51, 51))
|
self.SetItemBackgroundColour(i, wx.Colour(204, 51, 51))
|
||||||
|
|||||||
@@ -49,6 +49,7 @@ from gui.graphFrame import GraphFrame
|
|||||||
from gui.copySelectDialog import CopySelectDialog
|
from gui.copySelectDialog import CopySelectDialog
|
||||||
from gui.utils.clipboard import toClipboard, fromClipboard
|
from gui.utils.clipboard import toClipboard, fromClipboard
|
||||||
from gui.fleetBrowser import FleetBrowser
|
from gui.fleetBrowser import FleetBrowser
|
||||||
|
from gui.updateDialog import UpdateDialog
|
||||||
from gui.builtinViews import *
|
from gui.builtinViews import *
|
||||||
|
|
||||||
#dummy panel(no paint no erasebk)
|
#dummy panel(no paint no erasebk)
|
||||||
@@ -161,6 +162,15 @@ class MainFrame(wx.Frame):
|
|||||||
#Show ourselves
|
#Show ourselves
|
||||||
self.Show()
|
self.Show()
|
||||||
|
|
||||||
|
#Check for updates
|
||||||
|
self.sUpdate = service.Update.getInstance()
|
||||||
|
self.sUpdate.CheckUpdate(self.ShowUpdateBox)
|
||||||
|
|
||||||
|
def ShowUpdateBox(self, release):
|
||||||
|
dlg = UpdateDialog(self, release)
|
||||||
|
dlg.ShowModal()
|
||||||
|
dlg.Destroy()
|
||||||
|
|
||||||
def LoadMainFrameAttribs(self):
|
def LoadMainFrameAttribs(self):
|
||||||
|
|
||||||
mainFrameDefaultAttribs = {"wnd_width":1000, "wnd_height": 700, "wnd_maximized": False}
|
mainFrameDefaultAttribs = {"wnd_width":1000, "wnd_height": 700, "wnd_maximized": False}
|
||||||
|
|||||||
120
gui/updateDialog.py
Normal file
120
gui/updateDialog.py
Normal file
@@ -0,0 +1,120 @@
|
|||||||
|
#===============================================================================
|
||||||
|
# Copyright (C) 2010 Diego Duclos
|
||||||
|
#
|
||||||
|
# This file is part of pyfa.
|
||||||
|
#
|
||||||
|
# pyfa 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.
|
||||||
|
#
|
||||||
|
# pyfa 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 pyfa. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#===============================================================================
|
||||||
|
|
||||||
|
import wx
|
||||||
|
import bitmapLoader
|
||||||
|
import config
|
||||||
|
import service
|
||||||
|
import dateutil.parser
|
||||||
|
|
||||||
|
class UpdateDialog(wx.Dialog):
|
||||||
|
|
||||||
|
def __init__(self, parent, release):
|
||||||
|
wx.Dialog.__init__ ( self, parent, id = wx.ID_ANY, title = "Pyfa Update", pos = wx.DefaultPosition, size = wx.Size( 400,300 ), style = wx.DEFAULT_DIALOG_STYLE )
|
||||||
|
|
||||||
|
self.UpdateSettings = service.settings.UpdateSettings.getInstance()
|
||||||
|
self.releaseInfo = release
|
||||||
|
self.SetSizeHintsSz( wx.DefaultSize, wx.DefaultSize )
|
||||||
|
|
||||||
|
mainSizer = wx.BoxSizer( wx.VERTICAL )
|
||||||
|
|
||||||
|
headSizer = wx.BoxSizer( wx.HORIZONTAL )
|
||||||
|
|
||||||
|
self.headingText = wx.StaticText( self, wx.ID_ANY, "Pyfa Update Available!", wx.DefaultPosition, wx.DefaultSize, wx.ALIGN_CENTRE )
|
||||||
|
self.headingText.Wrap( -1 )
|
||||||
|
self.headingText.SetFont( wx.Font( 14, 74, 90, 92, False) )
|
||||||
|
|
||||||
|
headSizer.Add( self.headingText, 1, wx.ALL, 5 )
|
||||||
|
mainSizer.Add( headSizer, 0, wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
mainSizer.Add( wx.StaticLine( self, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL ), 0, wx.EXPAND |wx.ALL, 5 )
|
||||||
|
|
||||||
|
versionSizer = wx.BoxSizer( wx.HORIZONTAL )
|
||||||
|
|
||||||
|
if(self.releaseInfo['prerelease']):
|
||||||
|
self.releaseText = wx.StaticText( self, wx.ID_ANY, "Pre-release", wx.DefaultPosition, wx.DefaultSize, wx.ALIGN_RIGHT )
|
||||||
|
self.releaseText.SetFont( wx.Font( 12, 74, 90, 92, False) )
|
||||||
|
self.releaseText.SetForegroundColour( wx.Colour( 230, 0, 0 ) )
|
||||||
|
else:
|
||||||
|
self.releaseText = wx.StaticText( self, wx.ID_ANY, "Stable", wx.DefaultPosition, wx.DefaultSize, wx.ALIGN_RIGHT )
|
||||||
|
self.releaseText.SetFont( wx.Font( 12, 74, 90, 90, False) )
|
||||||
|
|
||||||
|
self.releaseText.Wrap( -1 )
|
||||||
|
|
||||||
|
versionSizer.Add( self.releaseText, 1, wx.ALL, 5 )
|
||||||
|
|
||||||
|
self.versionText = wx.StaticText( self, wx.ID_ANY, self.releaseInfo['tag_name'], wx.DefaultPosition, wx.DefaultSize, wx.ALIGN_LEFT )
|
||||||
|
self.versionText.Wrap( -1 )
|
||||||
|
self.versionText.SetFont( wx.Font( 12, 74, 90, 90, False) )
|
||||||
|
|
||||||
|
versionSizer.Add( self.versionText, 1, wx.ALL, 5 )
|
||||||
|
versionSizer.AddSpacer( ( 15, 5), 0, wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
mainSizer.Add( versionSizer, 0, wx.EXPAND, 5 )
|
||||||
|
mainSizer.AddSpacer( ( 0, 5), 0, wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
releaseDate = dateutil.parser.parse(self.releaseInfo['created_at'])
|
||||||
|
notesSizer = wx.BoxSizer( wx.HORIZONTAL )
|
||||||
|
self.notesTextCtrl = wx.TextCtrl( self, wx.ID_ANY, str(releaseDate.date())+":\n\n"+self.releaseInfo['body'], wx.DefaultPosition, wx.DefaultSize, wx.TE_AUTO_URL|wx.TE_MULTILINE|wx.TE_READONLY|wx.DOUBLE_BORDER|wx.TRANSPARENT_WINDOW )
|
||||||
|
|
||||||
|
notesSizer.Add( self.notesTextCtrl, 1, wx.EXPAND|wx.LEFT|wx.RIGHT, 5 )
|
||||||
|
mainSizer.Add( notesSizer, 1, wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
self.supressCheckbox = wx.CheckBox( self, wx.ID_ANY, "Don't remind me again for this release", wx.DefaultPosition, wx.DefaultSize, 0 )
|
||||||
|
self.supressCheckbox.Bind(wx.EVT_CHECKBOX, self.SuppressChange)
|
||||||
|
|
||||||
|
mainSizer.Add( self.supressCheckbox, 0, wx.ALL, 5 )
|
||||||
|
mainSizer.Add( wx.StaticLine( self, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL ), 0, wx.EXPAND |wx.ALL, 5 )
|
||||||
|
|
||||||
|
actionSizer = wx.BoxSizer( wx.HORIZONTAL )
|
||||||
|
|
||||||
|
goSizer = wx.BoxSizer( wx.VERTICAL )
|
||||||
|
self.downloadButton = wx.Button( self, wx.ID_ANY, "Download", wx.DefaultPosition, wx.DefaultSize, 0 )
|
||||||
|
self.downloadButton.Bind(wx.EVT_BUTTON, self.OnDownload)
|
||||||
|
goSizer.Add( self.downloadButton, 0, wx.ALL, 5 )
|
||||||
|
actionSizer.Add( goSizer, 1, wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
self.closeButton = wx.Button(self, wx.ID_CLOSE)
|
||||||
|
self.closeButton.Bind(wx.EVT_BUTTON, self.OnClose)
|
||||||
|
actionSizer.Add( self.closeButton, 0, wx.ALL, 5 )
|
||||||
|
mainSizer.Add( actionSizer, 0, wx.EXPAND, 5 )
|
||||||
|
|
||||||
|
self.SetSizer( mainSizer )
|
||||||
|
self.Layout()
|
||||||
|
|
||||||
|
# Handle use-case of suppressing a release, then a new version becoming available.
|
||||||
|
# If that new version is not suppressed, the old version will remain in the preferences and
|
||||||
|
# may cause confusion. If this dialog box is popping up for any reason, that mean we can
|
||||||
|
# safely reset this setting
|
||||||
|
self.UpdateSettings.set('version', None)
|
||||||
|
|
||||||
|
self.Centre( wx.BOTH )
|
||||||
|
|
||||||
|
def OnClose(self, e):
|
||||||
|
self.Destroy()
|
||||||
|
|
||||||
|
def SuppressChange(self, e):
|
||||||
|
if (self.supressCheckbox.IsChecked()):
|
||||||
|
self.UpdateSettings.set('version', self.releaseInfo['tag_name'])
|
||||||
|
else:
|
||||||
|
self.UpdateSettings.set('version', None)
|
||||||
|
|
||||||
|
def OnDownload(self, e):
|
||||||
|
wx.LaunchDefaultBrowser('https://github.com/DarkFenX/Pyfa/releases/tag/'+self.releaseInfo['tag_name'])
|
||||||
|
self.OnClose(e)
|
||||||
@@ -5,3 +5,4 @@ from service.character import Character
|
|||||||
from service.damagePattern import DamagePattern
|
from service.damagePattern import DamagePattern
|
||||||
from service.settings import SettingsProvider
|
from service.settings import SettingsProvider
|
||||||
from service.fleet import Fleet
|
from service.fleet import Fleet
|
||||||
|
from service.update import Update
|
||||||
|
|||||||
@@ -630,10 +630,13 @@ class Market():
|
|||||||
|
|
||||||
def searchShips(self, name):
|
def searchShips(self, name):
|
||||||
"""Find ships according to given text pattern"""
|
"""Find ships according to given text pattern"""
|
||||||
results = eos.db.searchItems(name)
|
filter = eos.types.Category.name.in_(["Ship"])
|
||||||
|
results = eos.db.searchItems(name, where=filter,
|
||||||
|
join=(eos.types.Item.group, eos.types.Group.category),
|
||||||
|
eager=("icon", "group.category", "metaGroup", "metaGroup.parent"))
|
||||||
ships = set()
|
ships = set()
|
||||||
for item in results:
|
for item in results:
|
||||||
if self.getCategoryByItem(item).name == "Ship" and self.getPublicityByItem(item):
|
if self.getPublicityByItem(item):
|
||||||
ships.add(item)
|
ships.add(item)
|
||||||
return ships
|
return ships
|
||||||
|
|
||||||
|
|||||||
@@ -38,6 +38,7 @@ class SettingsProvider():
|
|||||||
os.mkdir(self.BASE_PATH);
|
os.mkdir(self.BASE_PATH);
|
||||||
|
|
||||||
def getSettings(self, area, defaults=None):
|
def getSettings(self, area, defaults=None):
|
||||||
|
|
||||||
s = self.settings.get(area)
|
s = self.settings.get(area)
|
||||||
if s is None:
|
if s is None:
|
||||||
p = os.path.join(self.BASE_PATH, area)
|
p = os.path.join(self.BASE_PATH, area)
|
||||||
@@ -215,4 +216,31 @@ class HTMLExportSettings():
|
|||||||
return self.serviceHTMLExportSettings["path"]
|
return self.serviceHTMLExportSettings["path"]
|
||||||
|
|
||||||
def setPath(self, path):
|
def setPath(self, path):
|
||||||
self.serviceHTMLExportSettings["path"] = path
|
self.serviceHTMLExportSettings["path"] = path
|
||||||
|
|
||||||
|
"""
|
||||||
|
Settings used by update notification
|
||||||
|
"""
|
||||||
|
class UpdateSettings():
|
||||||
|
_instance = None
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def getInstance(cls):
|
||||||
|
if cls._instance == None:
|
||||||
|
cls._instance = UpdateSettings()
|
||||||
|
|
||||||
|
return cls._instance
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
# Settings
|
||||||
|
# all - If True, suppress all update notifications
|
||||||
|
# prerelease - If True, suppress only prerelease notifications
|
||||||
|
# version - Set to release tag that user does not want notifications for
|
||||||
|
serviceUpdateDefaultSettings = { "all": False, "prerelease": True, 'version': None }
|
||||||
|
self.serviceUpdateSettings = SettingsProvider.getInstance().getSettings("pyfaServiceUpdateSettings", serviceUpdateDefaultSettings)
|
||||||
|
|
||||||
|
def get(self, type):
|
||||||
|
return self.serviceUpdateSettings[type]
|
||||||
|
|
||||||
|
def set(self, type, value):
|
||||||
|
self.serviceUpdateSettings[type] = value
|
||||||
86
service/update.py
Normal file
86
service/update.py
Normal file
@@ -0,0 +1,86 @@
|
|||||||
|
#===============================================================================
|
||||||
|
# Copyright (C) 2010 Diego Duclos
|
||||||
|
#
|
||||||
|
# This file is part of pyfa.
|
||||||
|
#
|
||||||
|
# pyfa 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.
|
||||||
|
#
|
||||||
|
# pyfa 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 pyfa. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#===============================================================================
|
||||||
|
|
||||||
|
import threading
|
||||||
|
import wx
|
||||||
|
import urllib2
|
||||||
|
import json
|
||||||
|
import config
|
||||||
|
import service
|
||||||
|
|
||||||
|
class CheckUpdateThread(threading.Thread):
|
||||||
|
def __init__(self, callback):
|
||||||
|
threading.Thread.__init__(self)
|
||||||
|
self.callback = callback
|
||||||
|
self.settings = service.settings.UpdateSettings.getInstance()
|
||||||
|
|
||||||
|
def run(self):
|
||||||
|
# Suppress all
|
||||||
|
if (self.settings.get('all')):
|
||||||
|
return
|
||||||
|
|
||||||
|
try:
|
||||||
|
# @todo: use proxy settings?
|
||||||
|
response = urllib2.urlopen('https://api.github.com/repos/DarkFenX/Pyfa/releases')
|
||||||
|
jsonResponse = json.loads(response.read());
|
||||||
|
i = 0
|
||||||
|
while (True):
|
||||||
|
release = jsonResponse[i]
|
||||||
|
|
||||||
|
# Suppress pre releases
|
||||||
|
if (release['prerelease'] and self.settings.get('prerelease')):
|
||||||
|
i += 1
|
||||||
|
continue
|
||||||
|
|
||||||
|
# Handle use-case of updating to suppressed version
|
||||||
|
if self.settings.get('version') == 'v'+config.version:
|
||||||
|
self.settings.set('version', None)
|
||||||
|
|
||||||
|
# Suppress version
|
||||||
|
if (release['tag_name'] == self.settings.get('version')):
|
||||||
|
return
|
||||||
|
|
||||||
|
version = release['tag_name'].replace('v', '', 1)
|
||||||
|
|
||||||
|
if self.versiontuple(version) > self.versiontuple(config.version):
|
||||||
|
wx.CallAfter(self.callback, jsonResponse[i])
|
||||||
|
break;
|
||||||
|
|
||||||
|
except: # for when there is no internet connection
|
||||||
|
pass
|
||||||
|
|
||||||
|
def versiontuple(self, v):
|
||||||
|
return tuple(map(int, (v.split("."))))
|
||||||
|
|
||||||
|
class Update():
|
||||||
|
instance = None
|
||||||
|
def __init__(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def CheckUpdate(self, callback):
|
||||||
|
thread = CheckUpdateThread(callback)
|
||||||
|
thread.start()
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def getInstance(cls):
|
||||||
|
if cls.instance == None:
|
||||||
|
cls.instance = Update()
|
||||||
|
return cls.instance
|
||||||
|
|
||||||
|
|
||||||
Reference in New Issue
Block a user