Copy and Paste  -   An Application to Copy/Paste Text  

 
S.No 5857 Name ARCode Date/Time 17-Nov-2023 02:55:42 PM

Copy text from below
import React, { useState } from 'react';
import { View, Text, TouchableOpacity, StyleSheet } from 'react-native';

const CricketGame = () => {
  const players = ['Player 1', 'Player 2', 'Player 3'];
  const targetScore = 30;

  const [scores, setScores] = useState({});
  const [turns, setTurns] = useState({});
  const [gameOver, setGameOver] = useState(false);
  const [currentTurn, setCurrentTurn] = useState(0);

  const playTurn = (playerIndex) => {
    if (gameOver || playerIndex !== currentTurn) return;

    const score = Math.floor(Math.random() * 6) + 1;
    const currentPlayer = players[playerIndex];

   


    const updatedScores = {
      ...scores,
      [currentPlayer]: (scores[currentPlayer] || 0) + score,
    };



    const updatedTurns = {
      ...turns,
      [currentPlayer]: (turns[currentPlayer] || 0) + 1,
    };

    setScores(updatedScores);
    setTurns(updatedTurns);

    if (updatedScores[currentPlayer] >= targetScore) {
      // Game over, show match summary
      showMatchSummary(updatedScores, updatedTurns);
    } else {
      // Move to the next player's turn
      setCurrentTurn((currentTurn + 1) % players.length);
    }
  };

  const showMatchSummary = (updatedScores, updatedTurns) => {
    setScores(updatedScores);
    setTurns(updatedTurns);
    setGameOver(true);
  };

  const getOrdinalSuffix = (number) => {
    const suffixes = ['st', 'nd', 'rd'];
    const v = number % 100;
    return number + (suffixes[(v - 20) % 10] || suffixes[v] || 'th');
  };

  return (
    <View style={styles.container}>
      {players.map((player, index) => (
        <TouchableOpacity
          key={player}
          style={[styles.button, { backgroundColor: index === currentTurn ? 'lightblue' : 'gray' }]}
          onPress={() => playTurn(index)}
          disabled={gameOver || scores[player] >= targetScore || currentTurn !== index}
        >
          <Text>{`${player}'s Turn\nScore: ${scores[player] || 0}\n${turns[player] || 0} Turns`}</Text>
        </TouchableOpacity>
      ))}
      <Text style={styles.targetScore}>{`Target Score: ${targetScore}`}</Text>

      {/* Display match summary if the game is over */}
      {gameOver && (
        <Text>{`Match Summary\n${Object.keys(scores)
          .sort((a, b) => scores[b] - scores[a])
          .map((player, index) => `${getOrdinalSuffix(index + 1)}: ${player}, Score: ${scores[player]}, No of Turns: ${turns[player]}`)
          .join('\n')}`}</Text>
      )}
    </View>
  );
};

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
  },
  button: {
    padding: 10,
    margin: 10,
  },
  targetScore: {
    marginTop: 20,
  },
});

export default CricketGame;




comments powered by Disqus
NEW ENTRIES
S.No Name Entry Time/Date
5931 1111 23-Apr-2024 03:54:24 PM
5930 Savvy Cats 23-Apr-2024 06:52:03 AM
5929 listoclassob 22-Apr-2024 01:21:06 PM
5928 listofmap 22-Apr-2024 01:11:05 PM
5927 arrow inarro 22-Apr-2024 12:41:59 PM
5926 missing 21-Apr-2024 02:53:32 PM
5925 list of maps 16-Apr-2024 03:03:57 PM
5924 Micro 3 16-Apr-2024 11:57:26 AM
5923 Micro2 16-Apr-2024 11:53:20 AM
5922 Micro 16-Apr-2024 11:53:04 AM
5921 VRSefy 14-Apr-2024 06:56:37 PM
5920 Rogers Landw 08-Apr-2024 02:57:52 PM
5919 Frank Family 29-Mar-2024 03:50:35 PM
5918 Google Drive 27-Mar-2024 11:09:57 AM
5917 Google Drive 27-Mar-2024 10:41:56 AM
5916 google drive 25-Mar-2024 10:38:06 AM
5915 Stucco Champ 20-Mar-2024 10:55:56 PM
5914 B Physical 19-Mar-2024 10:52:02 AM
5913 guaranteelnc 12-Mar-2024 07:49:53 PM
5912 Spectrum Ele 12-Mar-2024 07:47:54 PM
5911 Spectrum 12-Mar-2024 01:30:08 PM
5910 Dr. Osman 11-Mar-2024 11:41:59 AM
5909 CHILD HOT 09-Mar-2024 08:02:39 AM
5908 H.-0-.T Vid 05-Mar-2024 08:20:33 AM
5907 Beyounce 04-Mar-2024 03:18:28 PM
5906 axiomintegra 03-Mar-2024 12:55:47 PM
5905 Comfort Ride 29-Feb-2024 04:03:14 PM
5904 David\'s RV P 26-Feb-2024 11:15:44 AM
5903 Child HOT 22-Feb-2024 06:43:26 AM
5902 Dumpsterfl 20-Feb-2024 01:33:22 PM

1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 [Next] [Last]
 
web counter
web counter


To report any error messages or bugs, or other issues, please send email at: info@pakproject.com