mirror of
https://github.com/Sneed-Group/Poodletooth-iLand
synced 2025-01-09 17:53:50 +00:00
True Friends holocausted until I make the new system tomorrow, using the panel
This commit is contained in:
parent
36bb543af6
commit
509a9697e6
18 changed files with 4 additions and 441 deletions
|
@ -503,7 +503,6 @@ from toontown.safezone import DistributedCheckers/AI
|
||||||
from toontown.safezone import DistributedFindFour/AI
|
from toontown.safezone import DistributedFindFour/AI
|
||||||
from toontown.uberdog.DistributedPartyManager/AI/UD import DistributedPartyManager/AI/UD
|
from toontown.uberdog.DistributedPartyManager/AI/UD import DistributedPartyManager/AI/UD
|
||||||
from toontown.coderedemption.TTCodeRedemptionMgr/AI import TTCodeRedemptionMgr/AI
|
from toontown.coderedemption.TTCodeRedemptionMgr/AI import TTCodeRedemptionMgr/AI
|
||||||
from toontown.friends.TrueFriendsMgr/AI import TrueFriendsMgr/AI
|
|
||||||
from toontown.cogdominium import DistributedCogdoInterior/AI
|
from toontown.cogdominium import DistributedCogdoInterior/AI
|
||||||
from toontown.cogdominium import DistributedCogdoBattleBldg/AI
|
from toontown.cogdominium import DistributedCogdoBattleBldg/AI
|
||||||
from toontown.cogdominium import DistributedCogdoElevatorExt/AI
|
from toontown.cogdominium import DistributedCogdoElevatorExt/AI
|
||||||
|
@ -664,7 +663,6 @@ dclass DistributedToon : DistributedPlayer {
|
||||||
takeDamage(uint16) broadcast ownrecv;
|
takeDamage(uint16) broadcast ownrecv;
|
||||||
setBattleId(uint32 = 0) required broadcast ram;
|
setBattleId(uint32 = 0) required broadcast ram;
|
||||||
setExperience(blob = [0*14]) required broadcast db;
|
setExperience(blob = [0*14]) required broadcast db;
|
||||||
setTrueFriends(uint32[]) required ownrecv db;
|
|
||||||
setIgnored(uint32[]) required clsend airecv ownrecv db;
|
setIgnored(uint32[]) required clsend airecv ownrecv db;
|
||||||
setReported(uint32[]) required ownrecv db;
|
setReported(uint32[]) required ownrecv db;
|
||||||
setMaxCarry(uint8 = 20) required ownrecv db;
|
setMaxCarry(uint8 = 20) required ownrecv db;
|
||||||
|
@ -3297,13 +3295,6 @@ dclass TTCodeRedemptionMgr : DistributedObject {
|
||||||
redeemCodeResult(uint32);
|
redeemCodeResult(uint32);
|
||||||
};
|
};
|
||||||
|
|
||||||
dclass TrueFriendsMgr : DistributedObject {
|
|
||||||
requestId() airecv clsend;
|
|
||||||
requestIdResult(uint32, string, string);
|
|
||||||
redeemId(string) airecv clsend;
|
|
||||||
redeemIdResult(uint32, string);
|
|
||||||
};
|
|
||||||
|
|
||||||
struct Friend
|
struct Friend
|
||||||
{
|
{
|
||||||
uint32 doId;
|
uint32 doId;
|
||||||
|
@ -3347,12 +3338,6 @@ dclass TTUFriendsManager : DistributedObjectGlobal {
|
||||||
whisperSCEmoteTo(uint32 toId, uint16 emoteId) clsend;
|
whisperSCEmoteTo(uint32 toId, uint16 emoteId) clsend;
|
||||||
setWhisperSCEmoteFrom(uint32 fromId, uint16 emoteId);
|
setWhisperSCEmoteFrom(uint32 fromId, uint16 emoteId);
|
||||||
|
|
||||||
requestSecret() clsend;
|
|
||||||
requestSecretResponse(int8 status, string secret);
|
|
||||||
|
|
||||||
submitSecret(string(0-256) secret) clsend;
|
|
||||||
submitSecretResponse(int8 status, int32 avId);
|
|
||||||
|
|
||||||
sendTalkWhisper(uint32 toId, string message) clsend;
|
sendTalkWhisper(uint32 toId, string message) clsend;
|
||||||
receiveTalkWhisper(uint32 fromId, string message);
|
receiveTalkWhisper(uint32 fromId, string message);
|
||||||
|
|
||||||
|
|
|
@ -57,10 +57,6 @@ AIMsgName2Id = {'STATESERVER_OBJECT_GENERATE_WITH_REQUIRED': 2001,
|
||||||
'CHANNEL_PUPPET_ACTION': 4004,
|
'CHANNEL_PUPPET_ACTION': 4004,
|
||||||
'DBSERVER_MAKE_FRIENDS': 1017,
|
'DBSERVER_MAKE_FRIENDS': 1017,
|
||||||
'DBSERVER_MAKE_FRIENDS_RESP': 1031,
|
'DBSERVER_MAKE_FRIENDS_RESP': 1031,
|
||||||
'DBSERVER_REQUEST_SECRET': 1025,
|
|
||||||
'DBSERVER_REQUEST_SECRET_RESP': 1026,
|
|
||||||
'DBSERVER_SUBMIT_SECRET': 1027,
|
|
||||||
'DBSERVER_SUBMIT_SECRET_RESP': 1028,
|
|
||||||
'DBSERVER_CREATE_STORED_OBJECT': 1003,
|
'DBSERVER_CREATE_STORED_OBJECT': 1003,
|
||||||
'DBSERVER_CREATE_STORED_OBJECT_RESP': 1004,
|
'DBSERVER_CREATE_STORED_OBJECT_RESP': 1004,
|
||||||
'DBSERVER_DELETE_STORED_OBJECT': 1008,
|
'DBSERVER_DELETE_STORED_OBJECT': 1008,
|
||||||
|
|
|
@ -90,17 +90,4 @@ class FriendManager(DistributedObject.DistributedObject):
|
||||||
def inviteeCancelFriendQuery(self, context):
|
def inviteeCancelFriendQuery(self, context):
|
||||||
self.notify.debug('Client: inviteeCancelFriendQuery(%d)' % context)
|
self.notify.debug('Client: inviteeCancelFriendQuery(%d)' % context)
|
||||||
messenger.send('cancelFriendInvitation', [context])
|
messenger.send('cancelFriendInvitation', [context])
|
||||||
self.up_inviteeAcknowledgeCancel(context)
|
self.up_inviteeAcknowledgeCancel(context)
|
||||||
|
|
||||||
def up_requestSecret(self):
|
|
||||||
self.notify.warning('Sending Request')
|
|
||||||
self.sendUpdate('requestSecret', [])
|
|
||||||
|
|
||||||
def requestSecretResponse(self, result, secret):
|
|
||||||
messenger.send('requestSecretResponse', [result, secret])
|
|
||||||
|
|
||||||
def up_submitSecret(self, secret):
|
|
||||||
self.sendUpdate('submitSecret', [secret])
|
|
||||||
|
|
||||||
def submitSecretResponse(self, result, avId):
|
|
||||||
messenger.send('submitSecretResponse', [result, avId])
|
|
|
@ -110,16 +110,4 @@ class FriendManagerAI(DistributedObjectAI):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def inviteeCancelFriendQuery(self, todo0):
|
def inviteeCancelFriendQuery(self, todo0):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def requestSecret(self):
|
|
||||||
pass
|
|
||||||
|
|
||||||
def requestSecretResponse(self, todo0, todo1):
|
|
||||||
pass
|
|
||||||
|
|
||||||
def submitSecret(self, todo0):
|
|
||||||
pass
|
|
||||||
|
|
||||||
def submitSecretResponse(self, todo0, todo1):
|
|
||||||
pass
|
|
|
@ -201,14 +201,10 @@ FriendInviterConfirmRemove = 'Remove'
|
||||||
FriendInviterYes = lYes
|
FriendInviterYes = lYes
|
||||||
FriendInviterNo = lNo
|
FriendInviterNo = lNo
|
||||||
FriendInviterClickToon = 'Click on the toon you would like to make friends with.'
|
FriendInviterClickToon = 'Click on the toon you would like to make friends with.'
|
||||||
FriendInviterTooMany = 'You have too many friends on your list to add another one now. You will have to remove some friends if you want to make friends with %s.'
|
|
||||||
FriendInviterToonTooMany = 'You have too many toon friends on your list to add another one now. You will have to remove some toon friends if you want to make friends with %s.'
|
FriendInviterToonTooMany = 'You have too many toon friends on your list to add another one now. You will have to remove some toon friends if you want to make friends with %s.'
|
||||||
FriendInviterNotYet = 'Would you like to make friends with %s?'
|
FriendInviterNotYet = 'Would you like to make friends with %s?'
|
||||||
FriendInviterCheckAvailability = 'Seeing if %s is available.'
|
FriendInviterCheckAvailability = 'Seeing if %s is available.'
|
||||||
FriendInviterNotAvailable = '%s is busy right now; try again later.'
|
FriendInviterNotAvailable = '%s is busy right now; try again later.'
|
||||||
FriendInviterCantSee = 'This only works if you can see %s.'
|
|
||||||
FriendInviterNotOnline = 'This only works if %s is online'
|
|
||||||
FriendInviterNotOpen = '%s does not have open chat, use secrets to make friends'
|
|
||||||
FriendInviterWentAway = '%s went away.'
|
FriendInviterWentAway = '%s went away.'
|
||||||
FriendInviterAlready = '%s is already your friend.'
|
FriendInviterAlready = '%s is already your friend.'
|
||||||
FriendInviterAlreadyInvited = '%s has already been invited.'
|
FriendInviterAlreadyInvited = '%s has already been invited.'
|
||||||
|
|
|
@ -30,7 +30,6 @@ from toontown.distributed.ToontownInternalRepository import ToontownInternalRepo
|
||||||
from toontown.coderedemption.TTCodeRedemptionMgrAI import TTCodeRedemptionMgrAI
|
from toontown.coderedemption.TTCodeRedemptionMgrAI import TTCodeRedemptionMgrAI
|
||||||
from toontown.dna.DNAParser import loadDNAFileAI
|
from toontown.dna.DNAParser import loadDNAFileAI
|
||||||
from toontown.estate.EstateManagerAI import EstateManagerAI
|
from toontown.estate.EstateManagerAI import EstateManagerAI
|
||||||
from toontown.friends.TrueFriendsMgrAI import TrueFriendsMgrAI
|
|
||||||
from toontown.hood import BRHoodAI
|
from toontown.hood import BRHoodAI
|
||||||
from toontown.hood import BossbotHQAI
|
from toontown.hood import BossbotHQAI
|
||||||
from toontown.hood import CashbotHQAI
|
from toontown.hood import CashbotHQAI
|
||||||
|
@ -127,8 +126,6 @@ class ToontownAIRepository(ToontownInternalRepository):
|
||||||
self.buildingQueryMgr = DistributedBuildingQueryMgrAI(self)
|
self.buildingQueryMgr = DistributedBuildingQueryMgrAI(self)
|
||||||
self.buildingQueryMgr.generateWithRequired(2)
|
self.buildingQueryMgr.generateWithRequired(2)
|
||||||
self.groupManager.generateWithRequired(2)
|
self.groupManager.generateWithRequired(2)
|
||||||
self.trueFriendsMgr = TrueFriendsMgrAI(self)
|
|
||||||
self.trueFriendsMgr.generateWithRequired(2)
|
|
||||||
if self.wantFishing:
|
if self.wantFishing:
|
||||||
self.fishManager = FishManagerAI(self)
|
self.fishManager = FishManagerAI(self)
|
||||||
if self.wantHousing:
|
if self.wantHousing:
|
||||||
|
|
|
@ -28,7 +28,6 @@ from toontown.toonbase.ToontownGlobals import *
|
||||||
from toontown.distributed import DelayDelete
|
from toontown.distributed import DelayDelete
|
||||||
from toontown.friends import FriendHandle
|
from toontown.friends import FriendHandle
|
||||||
from toontown.friends import FriendsListPanel
|
from toontown.friends import FriendsListPanel
|
||||||
from toontown.friends import ToontownFriendSecret
|
|
||||||
from toontown.login import AvatarChooser
|
from toontown.login import AvatarChooser
|
||||||
from toontown.makeatoon import MakeAToon
|
from toontown.makeatoon import MakeAToon
|
||||||
from toontown.pets import DistributedPet, PetDetail, PetHandle
|
from toontown.pets import DistributedPet, PetDetail, PetHandle
|
||||||
|
@ -407,7 +406,6 @@ class ToontownClientRepository(OTPClientRepository.OTPClientRepository):
|
||||||
if self.objectManager != None:
|
if self.objectManager != None:
|
||||||
self.objectManager.destroy()
|
self.objectManager.destroy()
|
||||||
self.objectManager = None
|
self.objectManager = None
|
||||||
ToontownFriendSecret.unloadFriendSecret()
|
|
||||||
FriendsListPanel.unloadFriendsList()
|
FriendsListPanel.unloadFriendsList()
|
||||||
messenger.send('cancelFriendInvitation')
|
messenger.send('cancelFriendInvitation')
|
||||||
base.removeGlitchMessage()
|
base.removeGlitchMessage()
|
||||||
|
|
|
@ -5,7 +5,6 @@ import FriendInvitee
|
||||||
import FriendNotifier
|
import FriendNotifier
|
||||||
from direct.directnotify import DirectNotifyGlobal
|
from direct.directnotify import DirectNotifyGlobal
|
||||||
from toontown.toon import ToonTeleportPanel
|
from toontown.toon import ToonTeleportPanel
|
||||||
from toontown.friends import ToontownFriendSecret
|
|
||||||
from toontown.pets import PetAvatarPanel
|
from toontown.pets import PetAvatarPanel
|
||||||
from toontown.toon import ToonAvatarPanel
|
from toontown.toon import ToonAvatarPanel
|
||||||
from toontown.suit import SuitAvatarPanel
|
from toontown.suit import SuitAvatarPanel
|
||||||
|
@ -74,7 +73,6 @@ class FriendsListManager:
|
||||||
self.ignore('friendAvatar')
|
self.ignore('friendAvatar')
|
||||||
self.ignore('avatarDetails')
|
self.ignore('avatarDetails')
|
||||||
FriendsListPanel.hideFriendsList()
|
FriendsListPanel.hideFriendsList()
|
||||||
ToontownFriendSecret.hideFriendSecret()
|
|
||||||
if base.cr.friendManager:
|
if base.cr.friendManager:
|
||||||
base.cr.friendManager.setAvailable(0)
|
base.cr.friendManager.setAvailable(0)
|
||||||
self.ignore('friendInvitation')
|
self.ignore('friendInvitation')
|
||||||
|
|
|
@ -3,7 +3,6 @@ from direct.gui.DirectGui import *
|
||||||
from pandac.PandaModules import *
|
from pandac.PandaModules import *
|
||||||
from direct.fsm import StateData
|
from direct.fsm import StateData
|
||||||
from toontown.toon import ToonAvatarPanel
|
from toontown.toon import ToonAvatarPanel
|
||||||
from toontown.friends import ToontownFriendSecret
|
|
||||||
from toontown.toonbase import ToontownGlobals
|
from toontown.toonbase import ToontownGlobals
|
||||||
from toontown.toonbase import TTLocalizer
|
from toontown.toonbase import TTLocalizer
|
||||||
from otp.otpbase import OTPGlobals
|
from otp.otpbase import OTPGlobals
|
||||||
|
@ -247,7 +246,7 @@ class FriendsListPanel(DirectFrame, StateData.StateData):
|
||||||
|
|
||||||
def __secrets(self):
|
def __secrets(self):
|
||||||
messenger.send('wakeup')
|
messenger.send('wakeup')
|
||||||
ToontownFriendSecret.showFriendSecret()
|
# TODO
|
||||||
|
|
||||||
def __newFriend(self):
|
def __newFriend(self):
|
||||||
messenger.send('wakeup')
|
messenger.send('wakeup')
|
||||||
|
|
|
@ -1,197 +0,0 @@
|
||||||
from pandac.PandaModules import *
|
|
||||||
from direct.gui.DirectGui import *
|
|
||||||
from direct.directnotify import DirectNotifyGlobal
|
|
||||||
from toontown.toonbase import TTLocalizer
|
|
||||||
from otp.otpbase import OTPGlobals
|
|
||||||
from toontown.nametag import NametagGlobals
|
|
||||||
|
|
||||||
globalFriendSecret = None
|
|
||||||
|
|
||||||
def showFriendSecret():
|
|
||||||
global globalFriendSecret
|
|
||||||
if not settings['trueFriends']:
|
|
||||||
chatMgr = base.localAvatar.chatMgr
|
|
||||||
chatMgr.fsm.request('noSecretChatAtAll')
|
|
||||||
else:
|
|
||||||
if globalFriendSecret != None:
|
|
||||||
globalFriendSecret.unload()
|
|
||||||
globalFriendSecret = ToontownFriendSecret()
|
|
||||||
globalFriendSecret.enter()
|
|
||||||
|
|
||||||
def hideFriendSecret():
|
|
||||||
if globalFriendSecret != None:
|
|
||||||
globalFriendSecret.exit()
|
|
||||||
|
|
||||||
def unloadFriendSecret():
|
|
||||||
global globalFriendSecret
|
|
||||||
if globalFriendSecret != None:
|
|
||||||
globalFriendSecret.unload()
|
|
||||||
globalFriendSecret = None
|
|
||||||
return
|
|
||||||
|
|
||||||
class ToontownFriendSecret(DirectFrame):
|
|
||||||
notify = DirectNotifyGlobal.directNotify.newCategory('ToontownFriendSecret')
|
|
||||||
|
|
||||||
def __init__(self):
|
|
||||||
DirectFrame.__init__(self, parent=aspect2dp, pos=(0, 0, 0.3), relief=None, image=DGG.getDefaultDialogGeom(), image_scale=(1.6, 1, 1.4), image_pos=(0, 0, -0.05), image_color=OTPGlobals.GlobalDialogColor, borderWidth=(0.01, 0.01))
|
|
||||||
self.initialiseoptions(ToontownFriendSecret)
|
|
||||||
self.isLoaded = 0
|
|
||||||
self.isEntered = 0
|
|
||||||
|
|
||||||
def unload(self):
|
|
||||||
if self.isLoaded == 0:
|
|
||||||
return None
|
|
||||||
self.isLoaded = 0
|
|
||||||
self.exit()
|
|
||||||
del self.introText
|
|
||||||
del self.getSecret
|
|
||||||
del self.enterSecretText
|
|
||||||
del self.enterSecret
|
|
||||||
del self.ok1
|
|
||||||
del self.ok2
|
|
||||||
del self.cancel
|
|
||||||
del self.secretText
|
|
||||||
DirectFrame.destroy(self)
|
|
||||||
return None
|
|
||||||
|
|
||||||
def load(self):
|
|
||||||
if self.isLoaded == 1:
|
|
||||||
return None
|
|
||||||
self.isLoaded = 1
|
|
||||||
self.introText = DirectLabel(parent=self, relief=None, pos=(0, 0, 0.4), scale=0.05, text=TTLocalizer.FriendSecretIntro, text_fg=(0, 0, 0, 1), text_wordwrap=30)
|
|
||||||
self.introText.hide()
|
|
||||||
guiButton = loader.loadModel('phase_3/models/gui/quit_button')
|
|
||||||
self.getSecret = DirectButton(parent=self, relief=None, pos=(0, 0, -0.11), image=(guiButton.find('**/QuitBtn_UP'), guiButton.find('**/QuitBtn_DN'), guiButton.find('**/QuitBtn_RLVR')), image_scale=TTLocalizer.FSgetSecret, text=TTLocalizer.FriendSecretGetSecret, text_scale=TTLocalizer.FSgetSecretButton, text_pos=(0, -0.02), command=self.__getSecret)
|
|
||||||
self.getSecret.hide()
|
|
||||||
self.enterSecretText = DirectLabel(parent=self, relief=None, pos=TTLocalizer.FSenterSecretTextPos, scale=0.05, text=TTLocalizer.FriendSecretEnterSecret, text_fg=(0, 0, 0, 1), text_wordwrap=30)
|
|
||||||
self.enterSecretText.hide()
|
|
||||||
self.enterSecret = DirectEntry(parent=self, relief=DGG.SUNKEN, scale=0.06, pos=(-0.6, 0, -0.38), frameColor=(0.8, 0.8, 0.5, 1), borderWidth=(0.1, 0.1), numLines=1, width=20, frameSize=(-0.4,
|
|
||||||
20.4,
|
|
||||||
-0.4,
|
|
||||||
1.1), command=self.__enterSecret)
|
|
||||||
self.enterSecret.resetFrameSize()
|
|
||||||
self.enterSecret.hide()
|
|
||||||
self.ok1 = DirectButton(parent=self, relief=None, image=(guiButton.find('**/QuitBtn_UP'), guiButton.find('**/QuitBtn_DN'), guiButton.find('**/QuitBtn_RLVR')), image_scale=TTLocalizer.FSok1, text=TTLocalizer.FriendSecretEnter, text_scale=0.06, text_pos=(0, -0.02), pos=(0, 0, -0.5), command=self.__ok1)
|
|
||||||
self.ok1.hide()
|
|
||||||
self.ok2 = DirectButton(parent=self, relief=None, image=(guiButton.find('**/QuitBtn_UP'), guiButton.find('**/QuitBtn_DN'), guiButton.find('**/QuitBtn_RLVR')), image_scale=TTLocalizer.FSok2, text=TTLocalizer.FriendSecretOK, text_scale=0.06, text_pos=(0, -0.02), pos=(0, 0, -0.57), command=self.__ok2)
|
|
||||||
self.ok2.hide()
|
|
||||||
self.cancel = DirectButton(parent=self, relief=None, text=TTLocalizer.FriendSecretCancel, image=(guiButton.find('**/QuitBtn_UP'), guiButton.find('**/QuitBtn_DN'), guiButton.find('**/QuitBtn_RLVR')), image_scale=TTLocalizer.FScancel, text_scale=0.06, text_pos=(0, -0.02), pos=(0, 0, -0.57), command=self.__cancel)
|
|
||||||
self.cancel.hide()
|
|
||||||
self.nextText = DirectLabel(parent=self, relief=None, pos=(0, 0, 0.3), scale=0.06, text='', text_scale=TTLocalizer.FSnextText, text_fg=(0, 0, 0, 1), text_wordwrap=25.5)
|
|
||||||
self.nextText.hide()
|
|
||||||
self.secretText = DirectLabel(parent=self, relief=None, pos=(0, 0, -0.42), scale=0.08, text='', text_fg=(0, 0, 0, 1), text_wordwrap=30)
|
|
||||||
self.secretText.hide()
|
|
||||||
guiButton.removeNode()
|
|
||||||
|
|
||||||
def enter(self):
|
|
||||||
if self.isEntered == 1:
|
|
||||||
return
|
|
||||||
self.isEntered = 1
|
|
||||||
if self.isLoaded == 0:
|
|
||||||
self.load()
|
|
||||||
self.show()
|
|
||||||
self.introText.show()
|
|
||||||
self.getSecret.show()
|
|
||||||
self.enterSecretText.show()
|
|
||||||
self.enterSecret.show()
|
|
||||||
self.ok1.show()
|
|
||||||
self.ok2.hide()
|
|
||||||
self.cancel.hide()
|
|
||||||
self.nextText.hide()
|
|
||||||
self.secretText.hide()
|
|
||||||
base.localAvatar.chatMgr.fsm.request('otherDialog')
|
|
||||||
self.enterSecret['focus'] = 1
|
|
||||||
NametagGlobals.setForceOnscreenChat(True)
|
|
||||||
|
|
||||||
def exit(self):
|
|
||||||
if self.isEntered == 0:
|
|
||||||
return
|
|
||||||
self.isEntered = 0
|
|
||||||
NametagGlobals.setForceOnscreenChat(False)
|
|
||||||
self.__cleanupFirstPage()
|
|
||||||
self.hide()
|
|
||||||
|
|
||||||
def __getSecret(self):
|
|
||||||
self.__cleanupFirstPage()
|
|
||||||
self.nextText['text'] = TTLocalizer.FriendSecretGettingSecret
|
|
||||||
self.nextText.setPos(0, 0, 0.3)
|
|
||||||
self.nextText.show()
|
|
||||||
self.ok1.hide()
|
|
||||||
self.cancel.show()
|
|
||||||
base.cr.trueFriendsMgr.requestId(self.gotSecret)
|
|
||||||
|
|
||||||
def gotSecret(self, id, result1, result2):
|
|
||||||
if id == 0:
|
|
||||||
self.rejectGetSecret(TTLocalizer.FriendSecretNoServer)
|
|
||||||
elif id == 1:
|
|
||||||
self.rejectGetSecret(TTLocalizer.FriendSecretNoServerResponse if not result1 else result1)
|
|
||||||
elif id == 2:
|
|
||||||
self.successGetSecret(result1, result2)
|
|
||||||
|
|
||||||
def rejectGetSecret(self, reason):
|
|
||||||
self.nextText['text'] = reason
|
|
||||||
self.nextText.show()
|
|
||||||
self.secretText.show()
|
|
||||||
self.cancel.hide()
|
|
||||||
self.ok1.hide()
|
|
||||||
self.ok2.show()
|
|
||||||
|
|
||||||
def successGetSecret(self, secret, expires):
|
|
||||||
self.nextText['text'] = TTLocalizer.FriendSecretGotSecret % expires
|
|
||||||
self.nextText.setPos(*TTLocalizer.FSgotSecretPos)
|
|
||||||
self.secretText['text'] = secret
|
|
||||||
self.nextText.show()
|
|
||||||
self.secretText.show()
|
|
||||||
self.cancel.hide()
|
|
||||||
self.ok1.hide()
|
|
||||||
self.ok2.show()
|
|
||||||
|
|
||||||
def __enterSecret(self, secret):
|
|
||||||
self.enterSecret.set('')
|
|
||||||
secret = secret.strip()
|
|
||||||
|
|
||||||
if not secret:
|
|
||||||
self.exit()
|
|
||||||
return
|
|
||||||
|
|
||||||
self.__cleanupFirstPage()
|
|
||||||
self.nextText['text'] = TTLocalizer.FriendSecretTryingSecret
|
|
||||||
base.cr.trueFriendsMgr.redeemId(secret, self.gotResponse)
|
|
||||||
self.nextText.setPos(0, 0, 0.3)
|
|
||||||
self.nextText.show()
|
|
||||||
self.cancel.hide()
|
|
||||||
self.ok1.hide()
|
|
||||||
self.ok2.show()
|
|
||||||
|
|
||||||
def gotResponse(self, id, name):
|
|
||||||
if id == 0:
|
|
||||||
self.nextText['text'] = TTLocalizer.FriendSecretNoServer
|
|
||||||
elif id == 1:
|
|
||||||
self.nextText['text'] = TTLocalizer.FriendSecretNoServerResponse if not result1 else result1
|
|
||||||
elif id == 2:
|
|
||||||
self.nextText['text'] = TTLocalizer.FriendSecretEnteredCodeSelf
|
|
||||||
elif id == 3:
|
|
||||||
self.nextText['text'] = TTLocalizer.FriendSecretAlreadyTrueFriend
|
|
||||||
elif id == 4:
|
|
||||||
self.nextText['text'] = TTLocalizer.FriendSecretSuccess % name
|
|
||||||
self.nextText.show()
|
|
||||||
self.cancel.hide()
|
|
||||||
self.ok1.hide()
|
|
||||||
self.ok2.show()
|
|
||||||
|
|
||||||
def __ok1(self):
|
|
||||||
secret = self.enterSecret.get()
|
|
||||||
self.__enterSecret(secret)
|
|
||||||
|
|
||||||
def __ok2(self):
|
|
||||||
self.exit()
|
|
||||||
|
|
||||||
def __cancel(self):
|
|
||||||
self.exit()
|
|
||||||
|
|
||||||
def __cleanupFirstPage(self):
|
|
||||||
self.introText.hide()
|
|
||||||
self.getSecret.hide()
|
|
||||||
self.enterSecretText.hide()
|
|
||||||
self.enterSecret.hide()
|
|
||||||
base.localAvatar.chatMgr.fsm.request('mainMenu')
|
|
|
@ -1,34 +0,0 @@
|
||||||
from direct.distributed.DistributedObject import DistributedObject
|
|
||||||
from direct.directnotify.DirectNotifyGlobal import directNotify
|
|
||||||
|
|
||||||
class TrueFriendsMgr(DistributedObject):
|
|
||||||
neverDisable = 1
|
|
||||||
notify = directNotify.newCategory('TrueFriendsMgr')
|
|
||||||
|
|
||||||
def __init__(self, cr):
|
|
||||||
DistributedObject.__init__(self, cr)
|
|
||||||
self.requestCallback = None
|
|
||||||
self.redeemCallback = None
|
|
||||||
|
|
||||||
def announceGenerate(self):
|
|
||||||
DistributedObject.announceGenerate(self)
|
|
||||||
base.cr.trueFriendsMgr = self
|
|
||||||
|
|
||||||
def delete(self):
|
|
||||||
if hasattr(base.cr, 'trueFriendsMgr'):
|
|
||||||
del base.cr.trueFriendsMgr
|
|
||||||
DistributedObject.delete(self)
|
|
||||||
|
|
||||||
def requestId(self, callback):
|
|
||||||
self.requestCallback = callback
|
|
||||||
self.sendUpdate('requestId')
|
|
||||||
|
|
||||||
def redeemId(self, id, callback):
|
|
||||||
self.redeemCallback = callback
|
|
||||||
self.sendUpdate('redeemId', [id])
|
|
||||||
|
|
||||||
def requestIdResult(self, id, result1, result2):
|
|
||||||
self.requestCallback(id, result1, result2)
|
|
||||||
|
|
||||||
def redeemIdResult(self, id, name):
|
|
||||||
self.redeemCallback(id, name)
|
|
|
@ -1,90 +0,0 @@
|
||||||
from direct.directnotify import DirectNotifyGlobal
|
|
||||||
from direct.distributed.DistributedObjectAI import DistributedObjectAI
|
|
||||||
from toontown.uberdog.ClientServicesManagerUD import executeHttpRequestAndLog
|
|
||||||
|
|
||||||
class TrueFriendsMgrAI(DistributedObjectAI):
|
|
||||||
notify = DirectNotifyGlobal.directNotify.newCategory("TrueFriendsMgrAI")
|
|
||||||
|
|
||||||
def announceGenerate(self):
|
|
||||||
DistributedObjectAI.announceGenerate(self)
|
|
||||||
|
|
||||||
def requestId(self):
|
|
||||||
avId = self.air.getAvatarIdFromSender()
|
|
||||||
av = self.air.doId2do.get(avId)
|
|
||||||
|
|
||||||
if not av:
|
|
||||||
return
|
|
||||||
|
|
||||||
if config.GetString('accountdb-type', 'developer') != 'remote':
|
|
||||||
self.sendUpdateToAvatarId(avId, 'requestIdResult', [0, None, None])
|
|
||||||
return
|
|
||||||
|
|
||||||
result = executeHttpRequestAndLog('truefriend', avid=avId)
|
|
||||||
|
|
||||||
if result is None:
|
|
||||||
self.sendUpdateToAvatarId(avId, 'requestIdResult', [1, None, None])
|
|
||||||
return
|
|
||||||
elif 'error' in result:
|
|
||||||
self.sendUpdateToAvatarId(avId, 'requestIdResult', [1, result['error'], None])
|
|
||||||
return
|
|
||||||
|
|
||||||
self.sendUpdateToAvatarId(avId, 'requestIdResult', [2, result['id'], result['expires']])
|
|
||||||
|
|
||||||
def redeemId(self, id):
|
|
||||||
avId = self.air.getAvatarIdFromSender()
|
|
||||||
av = self.air.doId2do.get(avId)
|
|
||||||
|
|
||||||
if not av:
|
|
||||||
return
|
|
||||||
|
|
||||||
if simbase.config.GetString('accountdb-type', 'developer') != 'remote':
|
|
||||||
self.sendUpdateToAvatarId(avId, 'redeemIdResult', [0, None])
|
|
||||||
return
|
|
||||||
|
|
||||||
result = executeHttpRequestAndLog('truefriend', id=id)
|
|
||||||
|
|
||||||
if result is None:
|
|
||||||
self.sendUpdateToAvatarId(avId, 'redeemIdResult', [1, None])
|
|
||||||
return
|
|
||||||
elif 'error' in result:
|
|
||||||
self.sendUpdateToAvatarId(avId, 'redeemIdResult', [1, result['error']])
|
|
||||||
return
|
|
||||||
|
|
||||||
targetId = int(result['avId'])
|
|
||||||
|
|
||||||
if targetId == avId:
|
|
||||||
self.sendUpdateToAvatarId(avId, 'redeemIdResult', [2, None])
|
|
||||||
return
|
|
||||||
elif av.isTrueFriend(targetId):
|
|
||||||
self.sendUpdateToAvatarId(avId, 'redeemIdResult', [3, None])
|
|
||||||
return
|
|
||||||
|
|
||||||
av.addTrueFriend(targetId)
|
|
||||||
target = self.air.doId2do.get(targetId)
|
|
||||||
|
|
||||||
if target:
|
|
||||||
target.addTrueFriend(avId)
|
|
||||||
self.sendUpdateToAvatarId(avId, 'redeemIdResult', [4, target.getName()])
|
|
||||||
else:
|
|
||||||
TrueFriendsOperation(targetId, avId)
|
|
||||||
|
|
||||||
class TrueFriendsOperation:
|
|
||||||
|
|
||||||
def __init__(self, targetId, avId):
|
|
||||||
self.targetId = targetId
|
|
||||||
self.avId = avId
|
|
||||||
simbase.air.dbInterface.queryObject(simbase.air.dbId, self.targetId, self.gotResponse)
|
|
||||||
|
|
||||||
def gotResponse(self, dclass, fields):
|
|
||||||
if dclass != simbase.air.dclassesByName['DistributedToonAI'] or not 'setName' in fields:
|
|
||||||
return
|
|
||||||
|
|
||||||
trueFriends = fields['setTrueFriends']
|
|
||||||
|
|
||||||
if self.avId in trueFriends:
|
|
||||||
self.sendUpdateToAvatarId(self.avId, 'redeemIdResult', [3, None])
|
|
||||||
return
|
|
||||||
|
|
||||||
trueFriends.append(self.avId)
|
|
||||||
simbase.air.dbInterface.updateObject(simbase.air.dbId, self.targetId, simbase.air.dclassesByName['DistributedToonAI'], {'setTrueFriends': [trueFriends]})
|
|
||||||
self.sendUpdateToAvatarId(self.avId, 'redeemIdResult', [4, fields['setName']])
|
|
|
@ -183,7 +183,6 @@ class DistributedToon(DistributedPlayer.DistributedPlayer, Toon.Toon, Distribute
|
||||||
self.promotionStatus = [0, 0, 0, 0]
|
self.promotionStatus = [0, 0, 0, 0]
|
||||||
self.buffs = []
|
self.buffs = []
|
||||||
self.redeemedCodes = []
|
self.redeemedCodes = []
|
||||||
self.trueFriends = []
|
|
||||||
self.ignored = []
|
self.ignored = []
|
||||||
self.reported = []
|
self.reported = []
|
||||||
|
|
||||||
|
@ -2585,12 +2584,6 @@ class DistributedToon(DistributedPlayer.DistributedPlayer, Toon.Toon, Distribute
|
||||||
def setRedeemedCodes(self, redeemedCodes):
|
def setRedeemedCodes(self, redeemedCodes):
|
||||||
self.redeemedCodes = redeemedCodes
|
self.redeemedCodes = redeemedCodes
|
||||||
|
|
||||||
def setTrueFriends(self, trueFriends):
|
|
||||||
self.trueFriends = trueFriends
|
|
||||||
|
|
||||||
def isTrueFriend(self, doId):
|
|
||||||
return doId in self.trueFriends
|
|
||||||
|
|
||||||
def b_setIgnored(self, ignored):
|
def b_setIgnored(self, ignored):
|
||||||
self.setIgnored(ignored)
|
self.setIgnored(ignored)
|
||||||
self.d_setIgnored(ignored)
|
self.d_setIgnored(ignored)
|
||||||
|
|
|
@ -180,7 +180,6 @@ class DistributedToonAI(DistributedPlayerAI.DistributedPlayerAI, DistributedSmoo
|
||||||
self.promotionStatus = [0, 0, 0, 0]
|
self.promotionStatus = [0, 0, 0, 0]
|
||||||
self.buffs = []
|
self.buffs = []
|
||||||
self.redeemedCodes = []
|
self.redeemedCodes = []
|
||||||
self.trueFriends = []
|
|
||||||
self.ignored = []
|
self.ignored = []
|
||||||
self.reported = []
|
self.reported = []
|
||||||
|
|
||||||
|
@ -432,27 +431,6 @@ class DistributedToonAI(DistributedPlayerAI.DistributedPlayerAI, DistributedSmoo
|
||||||
def getExperience(self):
|
def getExperience(self):
|
||||||
return self.experience.makeNetString()
|
return self.experience.makeNetString()
|
||||||
|
|
||||||
def b_setTrueFriends(self, trueFriends):
|
|
||||||
self.d_setTrueFriends(trueFriends)
|
|
||||||
self.setTrueFriends(trueFriends)
|
|
||||||
|
|
||||||
def d_setTrueFriends(self, trueFriends):
|
|
||||||
self.sendUpdate('setTrueFriends', [trueFriends])
|
|
||||||
|
|
||||||
def setTrueFriends(self, trueFriends):
|
|
||||||
self.trueFriends = trueFriends
|
|
||||||
|
|
||||||
def getTrueFriends(self):
|
|
||||||
return self.trueFriends
|
|
||||||
|
|
||||||
def isTrueFriend(self, doId):
|
|
||||||
return doId in self.trueFriends
|
|
||||||
|
|
||||||
def addTrueFriend(self, doId):
|
|
||||||
if not self.isTrueFriend(doId):
|
|
||||||
self.trueFriends.append(doId)
|
|
||||||
self.d_setTrueFriends(self.trueFriends)
|
|
||||||
|
|
||||||
def b_setIgnored(self, ignored):
|
def b_setIgnored(self, ignored):
|
||||||
self.d_setIgnored(ignored)
|
self.d_setIgnored(ignored)
|
||||||
self.setIgnored(ignored)
|
self.setIgnored(ignored)
|
||||||
|
|
|
@ -545,7 +545,4 @@ class DistributedToonUD(DistributedObjectUD):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def setRedeemedCodes(self, redeemedCodes):
|
def setRedeemedCodes(self, redeemedCodes):
|
||||||
pass
|
|
||||||
|
|
||||||
def setTrueFriends(self, trueFriends):
|
|
||||||
pass
|
pass
|
|
@ -10,7 +10,6 @@ from direct.distributed import DistributedObject
|
||||||
from direct.directnotify import DirectNotifyGlobal
|
from direct.directnotify import DirectNotifyGlobal
|
||||||
from toontown.toonbase import ToontownGlobals
|
from toontown.toonbase import ToontownGlobals
|
||||||
from toontown.toonbase import TTLocalizer
|
from toontown.toonbase import TTLocalizer
|
||||||
from toontown.friends import ToontownFriendSecret
|
|
||||||
import ToonAvatarDetailPanel
|
import ToonAvatarDetailPanel
|
||||||
import AvatarPanelBase
|
import AvatarPanelBase
|
||||||
from toontown.toontowngui import TTDialog
|
from toontown.toontowngui import TTDialog
|
||||||
|
@ -369,7 +368,7 @@ class ToonAvatarPanel(AvatarPanelBase.AvatarPanelBase):
|
||||||
|
|
||||||
def __handleSecrets(self):
|
def __handleSecrets(self):
|
||||||
base.localAvatar.chatMgr.noWhisper()
|
base.localAvatar.chatMgr.noWhisper()
|
||||||
ToontownFriendSecret.showFriendSecret()
|
# TODO
|
||||||
|
|
||||||
def __handleFriend(self):
|
def __handleFriend(self):
|
||||||
base.localAvatar.chatMgr.noWhisper()
|
base.localAvatar.chatMgr.noWhisper()
|
||||||
|
|
|
@ -8349,20 +8349,6 @@ PickTrackTitle = 'Pick your third track!'
|
||||||
PickTrackNotice = 'Choose a track!'
|
PickTrackNotice = 'Choose a track!'
|
||||||
CogLevelLabelOn = 'The cog level GUI is on.'
|
CogLevelLabelOn = 'The cog level GUI is on.'
|
||||||
CogLevelLabelOff = 'The cog level GUI is off.'
|
CogLevelLabelOff = 'The cog level GUI is off.'
|
||||||
FriendSecretIntro = "If you are playing Toontown United with someone you know in the real world, you can become True Friends. You can chat using the keyboard with your True Friends. Other Toons won't understand what you're saying.\n\nYou do this by getting a True Friend Code. Tell the True Friend Code to your friend, but not to anyone else. When your friend types in your True Friend Code on his or her screen, you'll be True Friends in Toontown!"
|
|
||||||
FriendSecretGetSecret = 'Get a True Friend Code'
|
|
||||||
FriendSecretEnterSecret = 'If you have a True Friend Code from someone you know, type it here.'
|
|
||||||
FriendSecretOK = lOK
|
|
||||||
FriendSecretEnter = 'Enter True Friend Code'
|
|
||||||
FriendSecretCancel = lCancel
|
|
||||||
FriendSecretGettingSecret = 'Getting True Friend Code...'
|
|
||||||
FriendSecretGotSecret = "Here is your new True Friend Code. Be sure to write it down!\n\nYou may give this True Friend Code to one person only. Once someone types in your True Friend Code, it will not work for anyone else. If you want to give a True Friend Code to more than one person, get another True Friend Code.\n\nThe True Friend Code will only work until %s. Your friend will have to type it in before it goes away, or it won't work.\n\nYour True Friend Code is:"
|
|
||||||
FriendSecretTryingSecret = 'Trying True Friend Code. . .'
|
|
||||||
FriendSecretNoServer = 'True Friends is not set up on this server!'
|
|
||||||
FriendSecretNoServerResponse = "Couldn't contact the True Friends server!"
|
|
||||||
FriendSecretEnteredCodeSelf = 'You just typed in your own True Friend Code! Now no one else can use that True Friend Code.'
|
|
||||||
FriendSecretAlreadyTrueFriend = 'You are True Friends with that toon already!'
|
|
||||||
FriendSecretSuccess = 'Congratulations! You are now True Friends with %s!'
|
|
||||||
|
|
||||||
HouseNames = ("Bungalow", "Tiki", "Teepee", "Castle", "Cupcake", "Cabin")
|
HouseNames = ("Bungalow", "Tiki", "Teepee", "Castle", "Cupcake", "Cabin")
|
||||||
CatalogPurchaseHouseType = "When you buy a new house type, the current one is replaced by it. To recover the old type, you'll need to buy it back. Continue?"
|
CatalogPurchaseHouseType = "When you buy a new house type, the current one is replaced by it. To recover the old type, you'll need to buy it back. Continue?"
|
||||||
|
|
|
@ -42,16 +42,11 @@ DGGGscoreLabel = 0.075
|
||||||
FPvaluePos = (0, 0, -0.35)
|
FPvaluePos = (0, 0, -0.35)
|
||||||
FPvalue = 0.05
|
FPvalue = 0.05
|
||||||
FPinfo = 0.055
|
FPinfo = 0.055
|
||||||
FSGUIdirectFrame = 0.06
|
|
||||||
FSGUIcancelButton = 0.06
|
|
||||||
FSGUIokButton = 0.06
|
|
||||||
GTenterPage2Wordwrap = 13.5
|
GTenterPage2Wordwrap = 13.5
|
||||||
GTenterPage4Wordwrap = 16.5
|
GTenterPage4Wordwrap = 16.5
|
||||||
BCGjpText = 0.04
|
BCGjpText = 0.04
|
||||||
BCGjpTextWordwrap = 10.5
|
BCGjpTextWordwrap = 10.5
|
||||||
BCGnextGame = 1.71
|
BCGnextGame = 1.71
|
||||||
FSGUIokButton = 0.06
|
|
||||||
FSGUIcancelButton = 0.06
|
|
||||||
FPnewEntry = 0.08
|
FPnewEntry = 0.08
|
||||||
FPnewRecord = 0.08
|
FPnewRecord = 0.08
|
||||||
GPgenus = 0.045
|
GPgenus = 0.045
|
||||||
|
@ -286,14 +281,6 @@ TPhaveFun = 0.1
|
||||||
TPjoinUs = 0.1
|
TPjoinUs = 0.1
|
||||||
TBSOSPSPenter = 0.1
|
TBSOSPSPenter = 0.1
|
||||||
TexitButton = 0.8
|
TexitButton = 0.8
|
||||||
FSenterSecretTextPos = (0, 0, -0.25)
|
|
||||||
FSgotSecretPos = (0, 0, 0.47)
|
|
||||||
FSgetSecretButton = 0.06
|
|
||||||
FSnextText = 1.0
|
|
||||||
FSgetSecret = (1.55, 1, 1)
|
|
||||||
FSok1 = (1.55, 1, 1)
|
|
||||||
FSok2 = (0.6, 1, 1)
|
|
||||||
FScancel = (0.6, 1, 1)
|
|
||||||
#Some languages need to change the word order
|
#Some languages need to change the word order
|
||||||
SellbotFactoryPosPart1 = (0, -0.25)
|
SellbotFactoryPosPart1 = (0, -0.25)
|
||||||
SellbotFactoryScalePart1 = 0.075
|
SellbotFactoryScalePart1 = 0.075
|
||||||
|
|
Loading…
Reference in a new issue