Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added Solitaire Game #2360

Merged
merged 1 commit into from
Jul 13, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 37 additions & 0 deletions Solitaire/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# **Solitaire**
<br>

## **Description 📃**

This is a digital version of the classic Solitaire card game developed using JavaScript, HTML, and CSS. The game follows the traditional rules of Solitaire, where the objective is to move all cards to their foundation piles by arranging them in ascending order and by suit. It's a single-player game that provides a fun and challenging experience for users.

## **Functionalities 🎮**
**Drag and Drop:** You can move cards by dragging them from one pile to another. Click and hold the card you want to move, drag it to the desired destination, and release the mouse button to drop the card.

**Move Counter:** The game keeps track of the number of moves you make while playing. You can use this as a measure of your progress or challenge yourself to complete the game with the fewest moves possible.

**Timer:** The game includes a timer that starts as soon as you begin playing. It tracks the time taken to complete the game, allowing you to challenge yourself to beat your previous records.
<br>

## **How to play? 🕹️**
- **Setup:** The game begins with 52 playing cards shuffled and dealt into seven tableau piles. The first pile has one card, the second has two cards, and so on until the seventh pile, which has seven cards. The remaining cards form the stock pile.

- **Objective:** The goal is to move all the cards to four foundation piles, one for each suit, in ascending order (Ace to King).

- **Gameplay:** You can move cards in the following ways:

**i) Tableau Piles:** Cards in the tableau can be moved onto another tableau pile if the top card of the destination pile is of the opposite color and one rank higher. For example, you can move a black 10 onto a red Jack.

**ii) Foundation Piles:** Aces can be moved to the foundation piles, and then cards of the same suit can be placed in ascending order on the Aces. For example, you can move the Ace of Hearts to the Hearts foundation, followed by the 2 of Hearts, 3 of Hearts, and so on.

**iii) Stock Pile:** Click on the stock pile to draw cards. These cards can be moved to the tableau or foundation piles following the rules mentioned above. When the stock pile is empty, you can click on the empty space to flip over the waste pile and create a new stock pile.

- **Winning:** You win the game when all cards are successfully moved to the foundation piles in ascending order and by suit.

<br>

## **Screenshots 📸**

![image](game.png)


342 changes: 342 additions & 0 deletions Solitaire/cards.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,342 @@
let deck = [
{
face: '2',
suitClass: 'two',
suitCentreClass: 1,
suit: 'heart'
},
{
face: '2',
suitClass: 'two',
suitCentreClass: 1,
suit: 'spade'
},
{
face: '2',
suitClass: 'two',
suitCentreClass: 1,
suit: 'diamond'
},
{
face: '2',
suitClass: 'two',
suitCentreClass: 1,
suit: 'clubs'
},
{
face: '3',
suitClass: 'three',
suitCentreClass: 2,
suit: 'heart'
},
{
face: '3',
suitClass: 'three',
suitCentreClass: 2,
suit: 'spade'
},
{
face: '3',
suitClass: 'three',
suitCentreClass: 2,
suit: 'diamond'
},
{
face: '3',
suitClass: 'three',
suitCentreClass: 2,
suit: 'clubs'
},
{
face: '4',
suitClass: 'four',
suitCentreClass: 3,
suit: 'heart'
},
{
face: '4',
suitClass: 'four',
suitCentreClass: 3,
suit: 'spade'
},
{
face: '4',
suitClass: 'four',
suitCentreClass: 3,
suit: 'diamond'
},
{
face: '4',
suitClass: 'four',
suitCentreClass: 3,
suit: 'clubs'
},
{
face: '5',
suitClass: 'five',
suitCentreClass: 4,
suit: 'heart'
},
{
face: '5',
suitClass: 'five',
suitCentreClass: 4,
suit: 'spade'
},
{
face: '5',
suitClass: 'five',
suitCentreClass: 4,
suit: 'diamond'
},
{
face: '5',
suitClass: 'five',
suitCentreClass: 4,
suit: 'clubs'
},
{
face: '6',
suitClass: 'six',
suitCentreClass: 5,
suit: 'heart'
},
{
face: '6',
suitClass: 'six',
suitCentreClass: 5,
suit: 'spade'
},
{
face: '6',
suitClass: 'six',
suitCentreClass: 5,
suit: 'diamond'
},
{
face: '6',
suitClass: 'six',
suitCentreClass: 5,
suit: 'clubs'
},
{
face: '7',
suitClass: 'seven',
suitCentreClass: 6,
suit: 'heart'
},
{
face: '7',
suitClass: 'seven',
suitCentreClass: 6,
suit: 'spade'
},
{
face: '7',
suitClass: 'seven',
suitCentreClass: 6,
suit: 'diamond'
},
{
face: '7',
suitClass: 'seven',
suitCentreClass: 6,
suit: 'clubs'
},
{
face: '8',
suitClass: 'eight',
suitCentreClass: 7,
suit: 'heart'
},
{
face: '8',
suitClass: 'eight',
suitCentreClass: 7,
suit: 'spade'
},
{
face: '8',
suitClass: 'eight',
suitCentreClass: 7,
suit: 'diamond'
},
{
face: '8',
suitClass: 'eight',
suitCentreClass: 7,
suit: 'clubs'
},
{
face: '9',
suitClass: 'nine',
suitCentreClass: 8,
suit: 'heart'
},
{
face: '9',
suitClass: 'nine',
suitCentreClass: 8,
suit: 'spade'
},
{
face: '9',
suitClass: 'nine',
suitCentreClass: 8,
suit: 'diamond'
},
{
face: '9',
suitClass: 'nine',
suitCentreClass: 8,
suit: 'clubs'
},
{
face: '10',
suitClass: 'ten',
suitCentreClass: 9,
suit: 'heart'
},
{
face: '10',
suitClass: 'ten',
suitCentreClass: 9,
suit: 'spade'
},
{
face: '10',
suitClass: 'ten',
suitCentreClass: 9,
suit: 'diamond'
},
{
face: '10',
suitClass: 'ten',
suitCentreClass: 9,
suit: 'clubs'
},
{
face: 'J',
suitClass: 'face',
suitCentreClass: 'red',
suit: 'heart'
},
{
face: 'J',
suitClass: 'face',
suitCentreClass: 'black',
suit: 'spade'
},
{
face: 'J',
suitClass: 'face',
suitCentreClass: 'red',
suit: 'diamond'
},
{
face: 'J',
suitClass: 'face',
suitCentreClass: 'black',
suit: 'clubs'
},
{
face: 'Q',
suitClass: 'face',
suitCentreClass: 'red',
suit: 'heart'
},
{
face: 'Q',
suitClass: 'face',
suitCentreClass: 'black',
suit: 'spade'
},
{
face: 'Q',
suitClass: 'face',
suitCentreClass: 'red',
suit: 'diamond'
},
{
face: 'Q',
suitClass: 'face',
suitCentreClass: 'black',
suit: 'clubs'
},
{
face: 'K',
suitClass: 'face',
suitCentreClass: 'red',
suit: 'heart'
},
{
face: 'K',
suitClass: 'face',
suitCentreClass: 'black',
suit: 'spade'
},
{
face: 'K',
suitClass: 'face',
suitCentreClass: 'red',
suit: 'diamond'
},
{
face: 'K',
suitClass: 'face',
suitCentreClass: 'black',
suit: 'clubs'
},
{
face: 'A',
suitClass: 'face',
suitCentreClass: 'red',
suit: 'heart'
},
{
face: 'A',
suitClass: 'face',
suitCentreClass: 'black',
suit: 'spade'
},
{
face: 'A',
suitClass: 'face',
suitCentreClass: 'red',
suit: 'diamond'
},
{
face: 'A',
suitClass: 'face',
suitCentreClass: 'black',
suit: 'clubs'
}
];
let cardFaces = ['A', '2', '3', '4', '5', '6', '7', '8', '9', '10', 'J', 'Q', 'K'];
let suitClasses = ['two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine', 'ten'];
let suitCentreClasses = ['one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine', 'ten'];
let suits = ['heart', 'spade', 'diamond', 'clubs'];


function shuffleArray(arr) {
return arr.sort(() => Math.random() - 0.5);
}

let shuffled = '';

function shuffleCards(count, array){
if(count <= 10){
shuffled = shuffleArray(array);
count++;
return shuffleCards(count, array);
}
return shuffled;
}

function cardPosition(card){
for(let i = 0; i < cardFaces.length; i++){
if(card == cardFaces[i]){
return i;
}
}
}
Binary file added Solitaire/game.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Loading