emportio
This commit is contained in:
		
							parent
							
								
									50f03ee43b
								
							
						
					
					
						commit
						360457907b
					
				| @ -6,7 +6,7 @@ from cards import Bang | |||||||
| import players | import players | ||||||
| from characters import all_characters | from characters import all_characters | ||||||
| from deck import Deck | from deck import Deck | ||||||
| from players import Player | from players import PendingAction, Player | ||||||
| import roles | import roles | ||||||
| 
 | 
 | ||||||
| class Game: | class Game: | ||||||
| @ -109,6 +109,9 @@ class Game: | |||||||
|             if p != attacker: |             if p != attacker: | ||||||
|                 if p.get_banged(): |                 if p.get_banged(): | ||||||
|                     self.waiting_for += 1 |                     self.waiting_for += 1 | ||||||
|  |         if self.waiting_for == 0: | ||||||
|  |             attacker.pending_action = players.PendingAction.PLAY | ||||||
|  |             attacker.notify_self() | ||||||
| 
 | 
 | ||||||
|     def indian_others(self, attacker:Player): |     def indian_others(self, attacker:Player): | ||||||
|         attacker.pending_action = players.PendingAction.WAIT |         attacker.pending_action = players.PendingAction.WAIT | ||||||
| @ -119,6 +122,9 @@ class Game: | |||||||
|             if p != attacker: |             if p != attacker: | ||||||
|                 if p.get_indians(): |                 if p.get_indians(): | ||||||
|                     self.waiting_for += 1 |                     self.waiting_for += 1 | ||||||
|  |         if self.waiting_for == 0: | ||||||
|  |             attacker.pending_action = players.PendingAction.PLAY | ||||||
|  |             attacker.notify_self() | ||||||
| 
 | 
 | ||||||
|     def attack(self, attacker:Player, target_username:str): |     def attack(self, attacker:Player, target_username:str): | ||||||
|         if self.players[self.players_map[target_username]].get_banged(): |         if self.players[self.players_map[target_username]].get_banged(): | ||||||
| @ -134,6 +140,26 @@ class Game: | |||||||
|             attacker.pending_action = players.PendingAction.WAIT |             attacker.pending_action = players.PendingAction.WAIT | ||||||
|             attacker.notify_self() |             attacker.notify_self() | ||||||
| 
 | 
 | ||||||
|  |     def emporio(self): | ||||||
|  |         self.available_cards = [self.deck.draw() for i in range(len(self.players))] | ||||||
|  |         self.players[self.turn].pending_action = players.PendingAction.CHOOSE | ||||||
|  |         self.players[self.turn].available_cards = [self.deck.draw() for i in range(len(self.players))] | ||||||
|  |         self.players[self.turn].notify_self() | ||||||
|  | 
 | ||||||
|  |     def respond_emporio(self, player, i): | ||||||
|  |         player.hand.append(self.available_cards.pop(i)) | ||||||
|  |         player.available_cards = [] | ||||||
|  |         player.pending_action = players.PendingAction.WAIT | ||||||
|  |         player.notify_self() | ||||||
|  |         nextPlayer = self.players[(self.turn + (len(self.players)-len(self.available_cards))) % len(self.players)] | ||||||
|  |         if nextPlayer == self.players[self.turn]: | ||||||
|  |             self.players[self.turn].pending_action = players.PendingAction.PLAY | ||||||
|  |             self.players[self.turn].notify_self() | ||||||
|  |         else: | ||||||
|  |             nextPlayer.pending_action = players.PendingAction.CHOOSE | ||||||
|  |             nextPlayer.available_cards = self.available_cards | ||||||
|  |             nextPlayer.notify_self() | ||||||
|  | 
 | ||||||
|     def get_player_named(self, name:str): |     def get_player_named(self, name:str): | ||||||
|         return self.players[self.players_map[name]] |         return self.players[self.players_map[name]] | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -217,7 +217,7 @@ class Player: | |||||||
|                 self.game.duel(self, againts) |                 self.game.duel(self, againts) | ||||||
|             if isinstance(card, cards.Emporio): |             if isinstance(card, cards.Emporio): | ||||||
|                 self.sio.emit('chat_message', room=self.game.name, data=f'{self.name} ha giocato {card.name}.') |                 self.sio.emit('chat_message', room=self.game.name, data=f'{self.name} ha giocato {card.name}.') | ||||||
|                 pass |                 self.game.emporio() | ||||||
|             if isinstance(card, cards.Gatling): |             if isinstance(card, cards.Gatling): | ||||||
|                 self.sio.emit('chat_message', room=self.game.name, data=f'{self.name} ha giocato {card.name}.') |                 self.sio.emit('chat_message', room=self.game.name, data=f'{self.name} ha giocato {card.name}.') | ||||||
|                 self.game.attack_others(self) |                 self.game.attack_others(self) | ||||||
| @ -247,6 +247,7 @@ class Player: | |||||||
|     def choose(self, card_index): |     def choose(self, card_index): | ||||||
|         if self.pending_action != PendingAction.CHOOSE: |         if self.pending_action != PendingAction.CHOOSE: | ||||||
|             return |             return | ||||||
|  |         if self.target_p and self.target_p != '': | ||||||
|             target = self.game.get_player_named(self.target_p) |             target = self.game.get_player_named(self.target_p) | ||||||
|             card = None |             card = None | ||||||
|             if card_index >= len(target.hand): |             if card_index >= len(target.hand): | ||||||
| @ -262,6 +263,8 @@ class Player: | |||||||
|             self.choose_action = '' |             self.choose_action = '' | ||||||
|             self.pending_action = PendingAction.PLAY |             self.pending_action = PendingAction.PLAY | ||||||
|             self.notify_self() |             self.notify_self() | ||||||
|  |         else: | ||||||
|  |             self.game.respond_emporio(self, card_index) | ||||||
| 
 | 
 | ||||||
|     def barrel_pick(self): |     def barrel_pick(self): | ||||||
|         pickable_cards = 1 + self.character.pick_mod |         pickable_cards = 1 + self.character.pick_mod | ||||||
|  | |||||||
| @ -24,6 +24,7 @@ | |||||||
| 		<p>{{hint}}</p> | 		<p>{{hint}}</p> | ||||||
| 		<Chooser v-if="card_against" text="Contro chi vuoi giocare la carta" :cards="visiblePlayers" :select="selectAgainst"/> | 		<Chooser v-if="card_against" text="Contro chi vuoi giocare la carta" :cards="visiblePlayers" :select="selectAgainst"/> | ||||||
| 		<Chooser v-if="pending_action == 3" text="Scegli come rispondere" :cards="respondCards" :select="respond"/> | 		<Chooser v-if="pending_action == 3" text="Scegli come rispondere" :cards="respondCards" :select="respond"/> | ||||||
|  | 		<Chooser v-if="shouldChooseCard" text="Scegli che carta pescare" :cards="available_cards" :select="choose"/> | ||||||
| 		<Chooser v-if="lives <= 0 && max_lives > 0" text="SEI MORTO" /> | 		<Chooser v-if="lives <= 0 && max_lives > 0" text="SEI MORTO" /> | ||||||
| 		<Chooser v-if="is_my_turn" text="GIOCA IL TUO TURNO" :key="is_my_turn" class="turn-notify" /> | 		<Chooser v-if="is_my_turn" text="GIOCA IL TUO TURNO" :key="is_my_turn" class="turn-notify" /> | ||||||
| 	</div> | 	</div> | ||||||
| @ -56,6 +57,8 @@ export default { | |||||||
| 		visiblePlayers: [], | 		visiblePlayers: [], | ||||||
| 		is_my_turn: false, | 		is_my_turn: false, | ||||||
| 		expected_response: null, | 		expected_response: null, | ||||||
|  | 		shouldChooseCard: false, | ||||||
|  | 		available_cards: [], | ||||||
| 	}), | 	}), | ||||||
| 	sockets: { | 	sockets: { | ||||||
| 		role(role) { | 		role(role) { | ||||||
| @ -73,8 +76,11 @@ export default { | |||||||
| 			this.has_played_bang = self.has_played_bang | 			this.has_played_bang = self.has_played_bang | ||||||
| 			this.is_my_turn = self.is_my_turn | 			this.is_my_turn = self.is_my_turn | ||||||
| 			this.expected_response = self.expected_response | 			this.expected_response = self.expected_response | ||||||
| 			if (this.pending_action == 5) { | 			this.available_cards = self.available_cards | ||||||
|  | 			if (this.pending_action == 5 && self.target_p) { | ||||||
| 				this.chooseCardFromPlayer(self.target_p) | 				this.chooseCardFromPlayer(self.target_p) | ||||||
|  | 			} else if (this.pending_action == 5) { | ||||||
|  | 				this.shouldChooseCard = true | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
| 		self_vis(vis) { | 		self_vis(vis) { | ||||||
| @ -140,7 +146,12 @@ export default { | |||||||
| 			} | 			} | ||||||
| 			console.log(card_data) | 			console.log(card_data) | ||||||
| 			this.$socket.emit('play_card', card_data) | 			this.$socket.emit('play_card', card_data) | ||||||
| 		} | 		}, | ||||||
|  | 		choose(card) { | ||||||
|  | 			this.$socket.emit('choose', this.available_cards.indexOf(card)) | ||||||
|  | 			this.available_cards = [] | ||||||
|  | 			this.shouldChooseCard = false | ||||||
|  | 		}, | ||||||
| 	}, | 	}, | ||||||
| 	mounted() { | 	mounted() { | ||||||
| 		this.$socket.emit('refresh') | 		this.$socket.emit('refresh') | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Alberto Xamin
						Alberto Xamin