Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/CheDAOLabs/cc-dojo-map


https://github.com/CheDAOLabs/cc-dojo-map

Last synced: about 2 months ago
JSON representation

Awesome Lists containing this project

README

        

> This example is not a complete or fully functional implementation of the game. Instead, it is a basic demonstration that illustrates how to integrate C&C (Crypts And Caverns) into the game world.

# demonstrate

![demonstrate](https://github.com/CheDAOLabs/cc-dojo-map/blob/main/docs/assets/cc-dojo-map.gif?raw=true)

![demonstrate](https://github.com/CheDAOLabs/cc-dojo-map/blob/v0.4.2/docs/assets/dojo-map.gif?raw=true)

# crypts and caverns example

A simple game example

Requires Dojo to implement player movement

interface

```
#[starknet::interface]
trait ICryptsAndCaverns {

fn owner_of(self: @TState, token_id: u256);

fn get_svg(self: @TState, token_id: u256);

fn generate_dungeon(self: @TState, token_id: u256);

fn get_seed(self: @TState, token_id: u256);

fn mint(ref self: TState);

}
```

### Components

- Player
- Map

### Systems

- Movement

### Split into several stages

- Parsing CC map data using Cairo, which can depend on the CC library
- Implementing new map generation based on the CC library, without using the mint form
- Allowing the player to move on the map and interact with local katana
- Implementing points of interest and teleportation points

## How to build

Omitting the installation of Rust, Cairo, and Scarb.

### build backend

1. Clone the source code:

```shell
git clone https://github.com/CheDAOLabs/cc-dojo-map.git
```

2. Execute the script, specifying the Dojo version:

```shell
dojoup
```

3. Start Katana:

```shell
katana --disable-fee --invoke-max-steps 4294967295
```

4. Compile the contract:

```shell
sozo build
```

5. Deploy the contract:

```shell
sozo migrate
```

6. Indexer

```shell
torii --world WORLD_ADDRESS
```

7. Add auth
```shell
cd scripts & sh default_auth.sh & sh cc_auth.sh
```

8. Invoke the contract:

```shell
sozo execute CC_CONTRACT_ADDRESS test
```

### build client

#### Start the React app.

```console
cd client3
yarn
yarn dev
```

```shell
http://localhost:5173/
```

### Project Structure

| Name | Description |
| --- | --- |
|client| for testnet c&c|
|client3| for katana c&c|

### Version Check

| Name | Version | Compatibility Dojo version | Coments
| --- | --- | --- | --- |
|cc-dojo-map|v0.1.0|v0.2.3| testnet C&C integrated into Dojo
|cc-dojo-map|v0.2.0|v0.3.0-rc9| update dojo to v0.3.0-rc9
|cc-dojo-map|v0.2.1|v0.3.0| update dojo to v0.3.0
|cc-dojo-map|v0.3.0|v0.3.0| C&C deployed in Katana
|cc-dojo-map|v0.3.15|v0.3.15| update dojo to v0.3.15
|cc-dojo-map|v0.4.0|v0.4.0| update dojo to v0.4.0
|cc-dojo-map|v0.4.2|v0.4.2| update dojo to v0.4.2