a WAY better DistributedNPCLaffRestock: client, AI and GUI

This commit is contained in:
Zach 2015-05-12 00:06:23 -05:00
parent 1cedf121b1
commit ab43bd1afe
13 changed files with 301 additions and 84 deletions

View file

@ -1957,16 +1957,17 @@ dclass DistributedNPCKartClerk : DistributedNPCToonBase {
transactionDone() airecv clsend; transactionDone() airecv clsend;
}; };
dclass DistributedNPCLaffRestock : DistributedNPCToonBase {
setMovie(uint8, uint32, uint32, uint32[], int16) broadcast ram;
restock(uint32, uint8) airecv clsend;
transactionDone() airecv clsend;
};
dclass DistributedNPCGlove : DistributedNPCToonBase { dclass DistributedNPCGlove : DistributedNPCToonBase {
doTransformation(uint32 avId, uint32) broadcast; doTransformation(uint32 avId, uint32) broadcast;
requestTransformation(uint32) airecv clsend; requestTransformation(uint32) airecv clsend;
}; };
dclass DistributedNPCLaffRestock : DistributedNPCToonBase {
restock() airecv clsend;
restockResult(int8, int16);
};
dclass DistributedKnockKnockDoor : DistributedAnimatedProp { dclass DistributedKnockKnockDoor : DistributedAnimatedProp {
}; };

View file

@ -13,7 +13,7 @@ from direct.gui.DirectGui import *
""" """
def inject(): def inject(_):
code = textbox.GetValue() code = textbox.GetValue()
exec(code, globals()) exec(code, globals())
@ -30,4 +30,4 @@ textbox.AppendText(defaultText)
threading.Thread(target=app.MainLoop).start() threading.Thread(target=app.MainLoop).start()
__builtin__.base = ShowBase() __builtin__.base = ShowBase()
base.run() base.run()

View file

@ -2,7 +2,7 @@
from pandac.PandaModules import * from pandac.PandaModules import *
hashVal = 3008682321L hashVal = 630664315
from toontown.coghq import DistributedCashbotBossSafe, DistributedCashbotBossCrane, DistributedBattleFactory, DistributedCashbotBossTreasure, DistributedCogHQDoor, DistributedSellbotHQDoor, DistributedFactoryElevatorExt, DistributedMintElevatorExt, DistributedLawOfficeElevatorExt, DistributedLawOfficeElevatorInt, LobbyManager, DistributedMegaCorp, DistributedFactory, DistributedLawOffice, DistributedLawOfficeFloor, DistributedLift, DistributedDoorEntity, DistributedSwitch, DistributedButton, DistributedTrigger, DistributedCrushableEntity, DistributedCrusherEntity, DistributedStomper, DistributedStomperPair, DistributedLaserField, DistributedGolfGreenGame, DistributedSecurityCamera, DistributedMover, DistributedElevatorMarker, DistributedBarrelBase, DistributedGagBarrel, DistributedBeanBarrel, DistributedHealBarrel, DistributedGrid, ActiveCell, DirectionalCell, CrusherCell, DistributedCrate, DistributedSinkingPlatform, BattleBlocker, DistributedMint, DistributedMintRoom, DistributedMintBattle, DistributedStage, DistributedStageRoom, DistributedStageBattle, DistributedLawbotBossGavel, DistributedLawbotCannon, DistributedLawbotChair, DistributedCogKart, DistributedCountryClub, DistributedCountryClubRoom, DistributedMoleField, DistributedCountryClubBattle, DistributedMaze, DistributedFoodBelt, DistributedBanquetTable, DistributedGolfSpot from toontown.coghq import DistributedCashbotBossSafe, DistributedCashbotBossCrane, DistributedBattleFactory, DistributedCashbotBossTreasure, DistributedCogHQDoor, DistributedSellbotHQDoor, DistributedFactoryElevatorExt, DistributedMintElevatorExt, DistributedLawOfficeElevatorExt, DistributedLawOfficeElevatorInt, LobbyManager, DistributedMegaCorp, DistributedFactory, DistributedLawOffice, DistributedLawOfficeFloor, DistributedLift, DistributedDoorEntity, DistributedSwitch, DistributedButton, DistributedTrigger, DistributedCrushableEntity, DistributedCrusherEntity, DistributedStomper, DistributedStomperPair, DistributedLaserField, DistributedGolfGreenGame, DistributedSecurityCamera, DistributedMover, DistributedElevatorMarker, DistributedBarrelBase, DistributedGagBarrel, DistributedBeanBarrel, DistributedHealBarrel, DistributedGrid, ActiveCell, DirectionalCell, CrusherCell, DistributedCrate, DistributedSinkingPlatform, BattleBlocker, DistributedMint, DistributedMintRoom, DistributedMintBattle, DistributedStage, DistributedStageRoom, DistributedStageBattle, DistributedLawbotBossGavel, DistributedLawbotCannon, DistributedLawbotChair, DistributedCogKart, DistributedCountryClub, DistributedCountryClubRoom, DistributedMoleField, DistributedCountryClubBattle, DistributedMaze, DistributedFoodBelt, DistributedBanquetTable, DistributedGolfSpot

View file

@ -18,6 +18,7 @@ class CogHQExterior(BattlePlace.BattlePlace):
'teleportIn', 'teleportIn',
'doorIn']), 'doorIn']),
State.State('walk', self.enterWalk, self.exitWalk, ['stickerBook', State.State('walk', self.enterWalk, self.exitWalk, ['stickerBook',
'purchase',
'teleportOut', 'teleportOut',
'tunnelOut', 'tunnelOut',
'doorOut', 'doorOut',
@ -38,6 +39,7 @@ class CogHQExterior(BattlePlace.BattlePlace):
'doorOut', 'doorOut',
'squished', 'squished',
'died']), 'died']),
State.State('purchase', self.enterPurchase, self.exitPurchase, ['walk']),
State.State('WaitForBattle', self.enterWaitForBattle, self.exitWaitForBattle, ['battle', 'walk']), State.State('WaitForBattle', self.enterWaitForBattle, self.exitWaitForBattle, ['battle', 'walk']),
State.State('battle', self.enterBattle, self.exitBattle, ['walk', 'teleportOut', 'died']), State.State('battle', self.enterBattle, self.exitBattle, ['walk', 'teleportOut', 'died']),
State.State('squished', self.enterSquished, self.exitSquished, ['walk', 'died', 'teleportOut']), State.State('squished', self.enterSquished, self.exitSquished, ['walk', 'died', 'teleportOut']),
@ -86,6 +88,19 @@ class CogHQExterior(BattlePlace.BattlePlace):
self.ignoreAll() self.ignoreAll()
BattlePlace.BattlePlace.exit(self) BattlePlace.BattlePlace.exit(self)
def enterPurchase(self):
base.localAvatar.b_setAnimState('neutral', 1)
self.accept('teleportQuery', self.handleTeleportQuery)
base.localAvatar.setTeleportAvailable(1)
base.localAvatar.laffMeter.start()
base.localAvatar.obscureMoveFurnitureButton(1)
def exitPurchase(self):
base.localAvatar.setTeleportAvailable(0)
self.ignore('teleportQuery')
base.localAvatar.laffMeter.stop()
base.localAvatar.obscureMoveFurnitureButton(-1)
def enterTunnelOut(self, requestStatus): def enterTunnelOut(self, requestStatus):
fromZoneId = self.zoneId - self.zoneId % 100 fromZoneId = self.zoneId - self.zoneId % 100
tunnelName = base.cr.hoodMgr.makeLinkTunnelName(self.loader.hood.id, fromZoneId) tunnelName = base.cr.hoodMgr.makeLinkTunnelName(self.loader.hood.id, fromZoneId)

View file

@ -19,13 +19,33 @@ class CogHQLoader(StateData.StateData):
self.parentFSMState = parentFSMState self.parentFSMState = parentFSMState
self.placeDoneEvent = 'cogHQLoaderPlaceDone' self.placeDoneEvent = 'cogHQLoaderPlaceDone'
self.townBattleDoneEvent = 'town-battle-done' self.townBattleDoneEvent = 'town-battle-done'
self.fsm = ClassicFSM.ClassicFSM('CogHQLoader', [State.State('start', None, None, ['quietZone', 'cogHQExterior', 'cogHQBossBattle']), self.fsm = ClassicFSM.ClassicFSM(
State.State('cogHQExterior', self.enterCogHQExterior, self.exitCogHQExterior, ['quietZone', 'cogHQLobby']), 'CogHQLoader', [State.State('start',
State.State('cogHQLobby', self.enterCogHQLobby, self.exitCogHQLobby, ['quietZone', 'cogHQExterior', 'cogHQBossBattle']), None,
State.State('cogHQBossBattle', self.enterCogHQBossBattle, self.exitCogHQBossBattle, ['quietZone']), None,
State.State('quietZone', self.enterQuietZone, self.exitQuietZone, ['cogHQExterior', 'cogHQLobby', 'cogHQBossBattle']), ['quietZone', 'cogHQExterior', 'cogHQBossBattle']),
State.State('final', None, None, ['start'])], 'start', 'final') State.State('cogHQExterior',
return self.enterCogHQExterior,
self.exitCogHQExterior,
['quietZone', 'cogHQLobby']),
State.State('cogHQLobby',
self.enterCogHQLobby,
self.exitCogHQLobby,
['quietZone', 'cogHQExterior', 'cogHQBossBattle']),
State.State('cogHQBossBattle',
self.enterCogHQBossBattle,
self.exitCogHQBossBattle,
['quietZone']),
State.State('quietZone',
self.enterQuietZone,
self.exitQuietZone,
['cogHQExterior', 'cogHQLobby', 'cogHQBossBattle']),
State.State('final',
None,
None,
['start'])],
'start',
'final')
def load(self, zoneId): def load(self, zoneId):
self.parentFSMState.addChild(self.fsm) self.parentFSMState.addChild(self.fsm)

View file

@ -14,10 +14,27 @@ class CogHood(Hood):
def __init__(self, parentFSM, doneEvent, dnaStore, hoodId): def __init__(self, parentFSM, doneEvent, dnaStore, hoodId):
Hood.__init__(self, parentFSM, doneEvent, dnaStore, hoodId) Hood.__init__(self, parentFSM, doneEvent, dnaStore, hoodId)
self.fsm = ClassicFSM.ClassicFSM('Hood', [State.State('start', self.enterStart, self.exitStart, ['cogHQLoader']), self.fsm = ClassicFSM.ClassicFSM(
State.State('cogHQLoader', self.enterCogHQLoader, self.exitCogHQLoader, ['quietZone']), 'Hood',
State.State('quietZone', self.enterQuietZone, self.exitQuietZone, ['cogHQLoader']), [State.State('start',
State.State('final', self.enterFinal, self.exitFinal, [])], 'start', 'final') self.enterStart,
self.exitStart,
['cogHQLoader']),
State.State('cogHQLoader',
self.enterCogHQLoader,
self.exitCogHQLoader,
['quietZone']),
State.State('quietZone',
self.enterQuietZone,
self.exitQuietZone,
['cogHQLoader']),
State.State('final',
self.enterFinal,
self.exitFinal,
[])
],
'start',
'final')
self.fsm.enterInitialState() self.fsm.enterInitialState()
# Until Hood is cleaned up, we will need to define some variables: # Until Hood is cleaned up, we will need to define some variables:

View file

@ -1,24 +1,28 @@
from pandac.PandaModules import *
from direct.distributed import ClockDelta
from toontown.chat.ChatGlobals import CFSpeech, CFTimeout from toontown.chat.ChatGlobals import CFSpeech, CFTimeout
from toontown.toonbase import TTLocalizer, ToontownGlobals from toontown.toonbase import TTLocalizer, ToontownGlobals
from toontown.toontowngui import TTDialog from toontown.toontowngui import TTDialog
from toontown.toon import NPCToons from toontown.toon import NPCToons
from DistributedNPCToonBase import DistributedNPCToonBase from DistributedNPCToonBase import DistributedNPCToonBase
import LaffRestockGlobals import LaffRestockGlobals
from LaffShopGui import *
class DistributedNPCLaffRestock(DistributedNPCToonBase): class DistributedNPCLaffRestock(DistributedNPCToonBase):
def __init__(self, cr): def __init__(self, cr):
DistributedNPCToonBase.__init__(self, cr) DistributedNPCToonBase.__init__(self, cr)
self.isLocalToon = 0
self.av = None
self.laffGui = None
def disable(self): def disable(self):
self.ignoreAll() self.ignoreAll()
self.destroyDialog() if self.laffGui:
self.laffGui.destroy()
self.laffGui = None
self.av = None
DistributedNPCToonBase.disable(self) DistributedNPCToonBase.disable(self)
def destroyDialog(self):
if hasattr(self, 'dialog'):
self.dialog.cleanup()
del self.dialog
def initToonState(self): def initToonState(self):
self.setAnimState('neutral', 0.9, None, None) self.setAnimState('neutral', 0.9, None, None)
@ -28,44 +32,80 @@ class DistributedNPCLaffRestock(DistributedNPCToonBase):
self.setH(pos[1]) self.setH(pos[1])
def getCollSphereRadius(self): def getCollSphereRadius(self):
return 1.0 return 1.25
def handleCollisionSphereEnter(self, collEntry): def handleCollisionSphereEnter(self, collEntry):
laff = base.localAvatar.getMaxHp() - base.localAvatar.getHp() base.cr.playGame.getPlace().fsm.request('purchase')
self.sendUpdate('avatarEnter', [])
if laff <= 0: def __handleUnexpectedExit(self):
self.setChatAbsolute(TTLocalizer.RestockFullLaffMessage, CFSpeech|CFTimeout) self.notify.warning('unexpected exit')
self.av = None
def resetLaffClerk(self):
self.ignoreAll()
if self.laffGui:
self.laffGui.destroy()
self.laffGui = None
self.show()
self.startLookAround()
self.detectAvatars()
if self.isLocalToon:
self.showNametag2d()
self.freeAvatar()
return Task.done
def setMovie(self, mode, npcId, avId, extraArgs, timestamp):
timeStamp = ClockDelta.globalClockDelta.localElapsedTime(timestamp)
self.remain = NPCToons.CLERK_COUNTDOWN_TIME - timeStamp
self.npcId = npcId
self.isLocalToon = avId == base.localAvatar.doId
if mode == NPCToons.SELL_MOVIE_CLEAR:
return return
if mode == NPCToons.SELL_MOVIE_TIMEOUT:
if self.isLocalToon:
if self.laffGui:
self.laffGui.destroy()
self.laffGui = None
self.setChatAbsolute(TTLocalizer.STOREOWNER_TOOKTOOLONG, CFSpeech | CFTimeout)
self.resetLaffClerk()
elif mode == NPCToons.SELL_MOVIE_START:
self.av = base.cr.doId2do.get(avId)
if self.av is None:
self.notify.warning('Avatar %d not found in doId' % avId)
return
else:
self.accept(self.av.uniqueName('disable'), self.__handleUnexpectedExit)
self.setupAvatars(self.av)
if self.isLocalToon:
self.hideNametag2d()
laff = self.av.getMaxHp() - self.av.getHp()
cost = laff * ToontownGlobals.CostPerLaffRestock
self.popupLaffGUI(laff, cost)
elif mode == NPCToons.SELL_MOVIE_COMPLETE:
self.setChatAbsolute(TTLocalizer.RestockLaffMessage, CFSpeech | CFTimeout)
self.resetLaffClerk()
elif mode == LaffRestockGlobals.FullLaff:
self.setChatAbsolute(TTLocalizer.RestockFullLaffMessage, CFSpeech | CFTimeout)
self.resetLaffClerk()
elif mode == LaffRestockGlobals.NoMoney:
self.setChatAbsolute(TTLocalizer.RestockNoMoneyMessage, CFSpeech | CFTimeout)
self.resetLaffClerk()
cost = laff * ToontownGlobals.CostPerLaffRestock def __handleRestock(self, cost):
self.sendUpdate('restock', [self.av.doId, cost])
if cost > base.localAvatar.getTotalMoney(): def __handleGuiDone(self, bTimedOut=False):
self.setChatAbsolute(TTLocalizer.RestockNoMoneyMessage % cost, CFSpeech|CFTimeout) self.ignoreAll()
return if self.laffGui:
self.laffGui.destroy()
self.laffGui = None
if not bTimedOut:
self.sendUpdate('transactionDone')
base.cr.playGame.getPlace().setState('stopped') def popupLaffGUI(self, laff, cost):
base.setCellsActive(base.bottomCells, 0) self.setChatAbsolute('', CFSpeech)
self.accept('restockLaff', self.__handleRestock)
self.dialog = TTDialog.TTDialog(style=TTDialog.YesNo, text=TTLocalizer.RestockAskMessage % (laff, cost), command=self.confirmRestock) self.acceptOnce('guiDone', self.__handleGuiDone)
self.dialog.show() self.laffGui = LaffShopGui(text=TTLocalizer.RestockAskMessage % (laff, cost),
extraArgs=[cost])
def confirmRestock(self, value):
base.cr.playGame.getPlace().setState('walk')
base.setCellsActive(base.bottomCells, 1)
if value > 0:
self.sendUpdate('restock')
else:
self.setChatAbsolute(TTLocalizer.RestockLaffCancelMessage, CFSpeech|CFTimeout)
self.destroyDialog()
def restockResult(self, state, cost):
if state == LaffRestockGlobals.NO_LAFF:
message = TTLocalizer.RestockFullLaffMessage
elif state == LaffRestockGlobals.NO_MONEY:
message = TTLocalizer.RestockNoMoneyMessage % cost
else:
message = TTLocalizer.RestockLaffMessage
self.setChatAbsolute(message, CFSpeech|CFTimeout)

View file

@ -1,27 +1,94 @@
from direct.distributed import ClockDelta
from toontown.toonbase import ToontownGlobals from toontown.toonbase import ToontownGlobals
import LaffRestockGlobals, DistributedNPCToonBaseAI from DistributedNPCToonBaseAI import DistributedNPCToonBaseAI
from pandac.PandaModules import *
from toontown.toonbase import TTLocalizer
from direct.task import Task
import LaffRestockGlobals
from toontown.toon import NPCToons
class DistributedNPCLaffRestockAI(DistributedNPCToonBaseAI.DistributedNPCToonBaseAI): class DistributedNPCLaffRestockAI(DistributedNPCToonBaseAI):
def restock(self): def __init__(self, air, npcId):
DistributedNPCToonBaseAI.__init__(self, air, npcId)
self.givesQuests = 0
self.busy = 0
def delete(self):
taskMgr.remove(self.uniqueName('clearMovie'))
self.ignoreAll()
DistributedNPCToonBaseAI.delete(self)
def d_setMovie(self, avId, flag, extraArgs=[]):
self.sendUpdate('setMovie', [flag,
self.npcId,
avId,
extraArgs,
ClockDelta.globalClockDelta.getRealNetworkTime()])
def avatarEnter(self):
avId = self.air.getAvatarIdFromSender() avId = self.air.getAvatarIdFromSender()
av = self.air.doId2do.get(avId) if avId not in self.air.doId2do:
self.notify.warning('Avatar: %s not found' % avId)
if not av:
return return
if self.isBusy():
self.freeAvatar(avId)
return
av = self.air.doId2do[avId]
self.busy = avId
self.acceptOnce(self.air.getAvatarExitEvent(avId), self.__handleUnexpectedExit, extraArgs=[avId])
laff = av.getMaxHp() - av.getHp() laff = av.getMaxHp() - av.getHp()
if laff <= 0:
self.sendUpdateToAvatarId(avId, 'restockResult', [LaffRestockGlobals.NO_LAFF, 0])
return
cost = laff * ToontownGlobals.CostPerLaffRestock cost = laff * ToontownGlobals.CostPerLaffRestock
if laff <= 0:
self.d_setMovie(avId, LaffRestockGlobals.FullLaff)
self.sendClearMovie(None)
elif cost > av.getTotalMoney():
self.d_setMovie(avId, LaffRestockGlobals.NoMoney)
self.sendClearMovie(None)
else:
self.d_setMovie(avId, NPCToons.SELL_MOVIE_START)
taskMgr.doMethodLater(LaffRestockGlobals.LAFFCLERK_TIMER, self.sendTimeoutMovie, self.uniqueName('clearMovie'))
DistributedNPCToonBaseAI.avatarEnter(self)
if cost > av.getTotalMoney(): def transactionDone(self):
self.sendUpdateToAvatarId(avId, 'restockResult', [LaffRestockGlobals.NO_MONEY, cost]) avId = self.air.getAvatarIdFromSender()
if self.busy != avId:
self.air.writeServerEvent('suspicious', avId, 'DistributedNPCLaffRestockAI.transactionDone busy with %s' % self.busy)
self.notify.warning('somebody called transactionDone that I was not busy with! avId: %s' % avId)
return return
av = simbase.air.doId2do.get(avId)
if av:
self.d_setMovie(avId, NPCToons.SELL_MOVIE_COMPLETE, [])
self.sendClearMovie(None)
return
av.takeMoney(cost) def __handleUnexpectedExit(self, avId):
av.b_setHp(av.getMaxHp()) self.notify.warning('avatar:' + str(avId) + ' has exited unexpectedly')
self.sendUpdateToAvatarId(avId, 'restockResult', [LaffRestockGlobals.SUCCESS, 0]) self.notify.warning('not busy with avId: %s, busy: %s ' % (avId, self.busy))
taskMgr.remove(self.uniqueName('clearMovie'))
self.sendClearMovie(None)
return
def sendTimeoutMovie(self, task):
self.d_setMovie(self.busy, NPCToons.SELL_MOVIE_TIMEOUT)
self.sendClearMovie(None)
return Task.done
def sendClearMovie(self, task):
self.ignore(self.air.getAvatarExitEvent(self.busy))
taskMgr.remove(self.uniqueName('clearMovie'))
self.busy = 0
self.d_setMovie(0, NPCToons.SELL_MOVIE_CLEAR)
return Task.done
def restock(self, avId, cost):
sendAvId = self.air.getAvatarIdFromSender()
if self.busy != avId:
self.air.writeServerEvent('suspicious', avId, 'DistributedNPCLaffRestockAI.restock busy with %s' % self.busy)
self.notify.warning('somebody called restock that I was not busy with! avId: %s' % avId)
return
av = simbase.air.doId2do.get(avId)
if av:
movieType = NPCToons.SELL_MOVIE_COMPLETE
av.takeMoney(cost)
av.b_setHp(av.getMaxHp())

View file

@ -15,6 +15,7 @@ ChoiceTimeout = 20
class DistributedNPCToon(DistributedNPCToonBase): class DistributedNPCToon(DistributedNPCToonBase):
def __init__(self, cr): def __init__(self, cr):
DistributedNPCToonBase.__init__(self, cr) DistributedNPCToonBase.__init__(self, cr)
@ -221,4 +222,4 @@ class DistributedNPCToon(DistributedNPCToonBase):
if self.trackChoiceGui: if self.trackChoiceGui:
self.trackChoiceGui.destroy() self.trackChoiceGui.destroy()
self.trackChoiceGui = None self.trackChoiceGui = None
self.sendUpdate('chooseTrack', [trackId]) self.sendUpdate('chooseTrack', [trackId])

View file

@ -17,6 +17,7 @@ from toontown.toonbase import ToontownGlobals
class DistributedNPCToonBase(DistributedToon.DistributedToon): class DistributedNPCToonBase(DistributedToon.DistributedToon):
def __init__(self, cr): def __init__(self, cr):
try: try:
self.DistributedNPCToon_initialized self.DistributedNPCToon_initialized

View file

@ -1,3 +1,4 @@
NO_LAFF = 0 LAFFCLERK_TIMER = 30
NO_MONEY = 1 FullLaff = 12
SUCCESS = 2 NoMoney = 14
Success = 1

View file

@ -0,0 +1,55 @@
from pandac.PandaModules import *
from direct.directnotify import DirectNotifyGlobal
from direct.gui.DirectGui import *
from direct.showbase import DirectObject
from toontown.toonbase import ToontownGlobals
from toontown.toonbase import TTLocalizer
from toontown.toonbase import ToontownTimer
from toontown.toontowngui import TTDialog
import LaffRestockGlobals
class LaffShopGui(object, DirectObject.DirectObject):
notify = DirectNotifyGlobal.directNotify.newCategory('LaffShopGui')
def __init__(self, **kw):
self.dialog = None
self.timer = None
self.timer = ToontownTimer.ToontownTimer()
self.timer.reparentTo(aspect2d)
self.timer.posInTopRightCorner()
self.timer.accept('RESET_LAFFSHOP_TIMER', self.__resetTimer)
self.timer.countdown(LaffRestockGlobals.LAFFCLERK_TIMER, self.__timerExpired)
self.__doDialog(**kw)
def destroy(self):
self.ignoreAll()
if self.timer:
self.timer.destroy()
self.timer = None
if self.dialog:
self.dialog.destroy()
self.dialog = None
def __resetTimer(self):
if self.timer:
self.timer.stop()
self.timer.countdown(LaffRestockGlobals.LAFFCLERK_TIMER, self.__timerExpired)
def __timerExpired(self):
messenger.send('guiDone', [True])
def __destroyDialog(self, resp, cost):
if self.timer:
self.ignoreAll()
if self.dialog:
self.dialog.destroy()
self.dialog = None
if resp == LaffRestockGlobals.Success:
messenger.send('restockLaff', [cost])
messenger.send('guiDone', [False])
def __doDialog(self, **kw):
self.dialog = TTDialog.TTDialog(style=TTDialog.YesNo,
command=self.__destroyDialog,
**kw)
self.dialog.show()

View file

@ -8443,8 +8443,7 @@ DonaldChatter = ["I'm glad you're here today!",
'I love to play tag. Do you?'] 'I love to play tag. Do you?']
NPCFriendUnavailable = 'Unavailable' NPCFriendUnavailable = 'Unavailable'
FireTalkMessage = "You're fired!" FireTalkMessage = "You're fired!"
RestockFullLaffMessage = "Sorry, but you're already happy!" RestockFullLaffMessage = "You're already happy!"
RestockNoMoneyMessage = "Sorry, but you need %s jellybeans to restock your laff!" RestockNoMoneyMessage = "You need more jellybeans to restock your laff!"
RestockLaffMessage = "Have fun!"
RestockAskMessage = "Would you like to restock %s laff for %s jellybeans?" RestockAskMessage = "Would you like to restock %s laff for %s jellybeans?"
RestockLaffMessage = "Enjoy your happiness!"
RestockLaffCancelMessage = "Alright. Come back here if you change your mind."