Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/CheDAOLabs/cc-dojo-map
https://github.com/CheDAOLabs/cc-dojo-map
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/CheDAOLabs/cc-dojo-map
- Owner: CheDAOLabs
- License: mit
- Created: 2023-10-07T08:26:49.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-03-19T10:19:16.000Z (10 months ago)
- Last Synced: 2024-08-04T01:11:28.644Z (5 months ago)
- Language: TypeScript
- Size: 168 MB
- Stars: 9
- Watchers: 0
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
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