Skip to content

Latest commit

 

History

History
383 lines (289 loc) · 37.3 KB

README_OLD.md

File metadata and controls

383 lines (289 loc) · 37.3 KB

project-logo

CAIN

A foundry alternative playing system for CAIN, created by Tom Bloom. Code created by Adam Kostandy

license last-commit repo-top-language repo-language-count


Table of Contents

CREDITS

- Myco from the Pilot.NET/CAIN Discord for providing icon assets
- Tom Bloom Creator of Cain
- My sunday DND group

Overview

Cain is an open-source project designed to streamline CAIN RPG system management within FoundryVTT. Cain enhances user experiences through customizable actors, items, and effects. The projects core functionalities, encapsulated in the cain module, facilitate dynamic talisman management, item roll logic, and interactive character sheet customization. Cains value proposition lies in its ability to empower game masters with a comprehensive system that ensures efficient data organization and seamless gameplay customization.


Features

Feature Description
⚙️ Architecture The project has a modular architecture with clear separation of concerns, utilizing Sass for styling and JavaScript for functionality. It follows a structured system design in FoundryVTT for efficient data processing and management.
🔩 Code Quality The codebase maintains high quality standards with reusable styles, compressed JavaScript libraries, and efficient data handling. It follows a consistent design system for frontend elements, enhancing maintainability and coherence across the project.
📄 Documentation Extensive documentation is provided, defining metadata, supported types, licensing terms, and localization strings. Detailed explanations are present for classes, helpers, templates, and components, aiding system management, customization, and user interface design.
🔌 Integrations Key integrations include SASS for CSS compilation, Handlebars templates for fast rendering, and FoundryVTT for system metadata. External dependencies support dynamic image updates, active effects management, and talisman interaction within the system.
🧩 Modularity The codebase exhibits high modularity, enabling easy extension and integration of additional features. Classes, templates, and styles are organized in a structured manner, promoting code reusability and scalability for future enhancements.
🧪 Testing Testing frameworks and tools used are not explicitly mentioned in the provided details.
⚡️ Performance The system promotes efficiency and resource optimization through centralized code management, dynamic data handling, and fast rendering using cached Handlebars templates. Layout elements are designed for responsive web display, enhancing user experiences in the application.
🛡️ Security Security measures for data protection and access control are not explicitly discussed in the provided details.
📦 Dependencies Key external libraries and dependencies include SASS for CSS compilation, Handlebars for template rendering, and FoundryVTT for managing system metadata and UI components. These libraries enhance styling, performance, and functionality within the project.
🚀 Scalability The project demonstrates scalability with its structured architecture, modularity, and efficient resource management. The codebase is well-organized for handling increased traffic and load, facilitating easy integration of new features and extensions.

Repository Structure

└── cain/
    ├── CHANGELOG.md
    ├── LICENSE.txt
    ├── README.md
    ├── assets
    │   ├── CAT
    │   ├── Talismans
    │   ├── anvil-impact.png
    │   ├── brain.png
    │   └── talisman-icon.png
    ├── css
    │   └── cain.css
    ├── lang
    │   └── en.json
    ├── lib
    │   └── some-lib
    ├── module
    │   ├── cain.mjs
    │   ├── data
    │   ├── documents
    │   ├── helpers
    │   └── sheets
    ├── package.json
    ├── packs
    │   └── .gitattributes
    ├── src
    │   └── scss
    ├── system.json
    ├── template.json
    └── templates
        ├── actor
        ├── item
        └── talisman-window.hbs

Modules

.
File Summary
package.json Enables CSS compilation for the Cain system using SASS. Automates the compilation process and enables watching for style changes. Key features include building expanded CSS and supporting source maps.
template.json Defines supported types for Actors and Items in the system, guiding the template structure.
LICENSE.txt Defines licensing terms for the repository content, granting usage permissions under the MIT License. Excludes compendium content from this license. Specifies attribution for the image anvil-impact.png.
system.json Defines metadata for the Cain system in FoundryVTT, specifying authors, version, media, compatibility, styles, languages, and more. Facilitates system management, compatibility, and customization for users of the system.
lib.some-lib
File Summary
some-lib.css Enhances Cains UI with reusable styles for various components. Supports maintainability and consistency across the projects frontend, complementing the design system.
some-lib.min.js Enables custom functionality within the system using a compressed JavaScript library, enhancing modularity and extensibility. The file serves as a core component of the repositorys architecture for integrating additional features seamlessly.
css
File Summary
cain.css Cain/module/cain.mjsThe cain.mjsfile within themodule` directory of the Cain repository serves as a crucial module orchestrating various functionalities of the system. It acts as a central hub for handling data processing, document management, and providing essential helper functions to streamline operations within the system. This code file integrates key components essential for the overall functioning of the system, promoting efficiency and coherence in managing the systems resources effectively.
module
File Summary
cain.mjs Defines classes, constants, and macros for the Cain system. Registers document, sheet, and handlebars helpers. Enables item creation and macro assignment. Facilitates talisman interaction through a dedicated window and button on the interface.
module.documents
File Summary
item.mjs Enhances Item class with dynamic data handling and roll logic for dice commands. Extends functionality to simplify system data and handle clickable rolls elegantly in chat interface.
talisman-window.mjs Implements TalismanWindow class for managing global Talismans in the Cain system. Enables GMs to add, edit, and delete talismans with image and mark settings. Supports dynamic image and mark updates based on user interactions.
actor.mjs Defines a custom data structure for the Actor document, enhancing data handling for the Simple system in the Cain repository. Extends base Actor functionalities to prepare, augment, and convert data efficiently for character sheets and queries.
module.helpers
File Summary
effects.mjs Manages Active Effects for Actor/Item Sheets with control buttons to create, edit, delete, or toggle effects. Prepares data structure for categorizing effects into temporary, passive, or inactive categories.
templates.mjs Loads and caches Handlebars templates to enable fast rendering in the Cain system. Pre-loads template paths for talismans, actors, and items, enhancing performance for displaying game elements.
config.mjs Defines registered skills, sin marks and abilities used in the system, enhancing gameplay mechanics with rich character customization options and thematic depth.
module.sheets
File Summary
actor-sheet.mjs This code file, located in the module/sheets directory, enhances the functionality related to managing active effects for actors within the larger cain repository. It imports key functions for managing active effects and retrieving configuration settings. By leveraging these imports, the code streamlines the process of organizing and preparing active effect categories, contributing to a more efficient and user-friendly system for handling actor-related data within the project.
item-sheet.mjs Enhances ItemSheet presentation with dynamic templating, enriched descriptions, system flags, and active effects management. Integrates contextual data and UI enhancements for interactive item manipulation within the larger Cain repository.
src.scss
File Summary
cain.scss Enhances styling for the cain module by importing custom fonts, utilities, and global styles. Organizes components related to forms, resources, items, and effects within the .cain class, streamlining the visual presentation in the Cain repository.
src.scss.components
File Summary
_resource.scss Defines bold styling for resource labels in the repositorys SCSS components, enhancing readability and visual hierarchy.
_forms.scss Styles sheet for forms and headers in the Cain module. Defines layout properties for form items, profile images, header fields, character names, tabs, and text editors. Maintains a consistent visual design within the user interface.
_effects.scss Defines centralized styling for item effects in Cain modules UI components. Aligns content, adds borders, and sets font size. Enhances visual consistency and readability for effect-related elements.
_items.scss Styles components for items in the UI, defining headers, lists, names, controls, and individual items. Enhances readability and user interaction.
src.scss.global
File Summary
_grid.scss Defines grid layouts for responsive web design, offering columns ranging from 2 to 12. Includes grid offsets for alignment control. Supports dynamic content structuring for enhanced user experiences within the application.
_flex.scss Enhances layout flexibility with centralized alignment and spacing options using Flexbox properties. Establishes consistent design patterns for center, left, and right alignments, optimizing UI rendering for diverse screen sizes.
_window.scss Window-appuses primary font,rollable` elements change color and shadow on hover/focus. Contributes consistent UI styling for interactive elements aiding user engagement in the projects UI development.
src.scss.utils
File Summary
_variables.scss Define padding and border styles variables for consistent UI spacing and elements in the Cain repositorys styling layer.
_mixins.scss Defines mixins for hiding elements in the repositorys CSS architecture. Supports accessibility and UI design by providing reusable utilities for making elements visually hidden or completely hidden from view.
_colors.scss Defines core color variables for consistent styling in the repositorys SCSS files. Establishes essential color values such as white, black, dark, faint, beige, and tan for maintaining a cohesive design system across the project.
_typography.scss Defines primary and secondary fonts for consistent typography in the parent repositorys stylesheets. Ensures a unified visual language across the project to enhance readability and brand consistency.
lang
File Summary
en.json Define localization strings for skills, abilities, labels, items, and effects in English within the en.json file for the Cain system, facilitating user interface display in the respective game elements.
templates
File Summary
talisman-window.hbs Defines a stylized UI layout for managing Global Talismans. Displays talisman details dynamically, with GM-exclusive controls. Applies custom styling for a Jujutsu Kaisen-themed interface, enhancing user experience within the cain module of the repository.
templates.actor
File Summary
actor-npc-sheet.hbs Implements an NPC character sheet with editable fields for health, power, CR/XP, biography, and owned items. Facilitates interactive character management in the RPG system through a visually appealing and user-friendly interface.
actor-character-sheet.hbs Renders a character sheet with profile information and tabs for managing stats, descriptions, items, abilities, sin, and talismans. Utilizes Handlebars for dynamic content display in the Cain repositorys actor template structure.
templates.actor.parts
File Summary
actor-items.hbs Renders kit points and scrip amount inputs.-Displays gear items with controls for creation, editing, and deletion.-Utilizes CSS styling for a visually appealing and consistent layout.
actor-talismans.hbs Renders a dynamic interface for managing talismans in the actor profile, displaying talisman details with controls to edit and delete. Allows users to add new talismans.
actor-abilities.hbs Renders dynamic content for displaying and managing Psyche and item sections within the actor abilities UI component. Dynamically generates buttons, checkboxes, and lists based on system data for engaging user interactions and customization options.
actor-features.hbs Designs and styles a dynamic character sheet interface with checkboxes, sliders, and dice roller functionality.-Displays character progression indicators and prompts for XP advancement decisions, enhancing the immersive role-playing experience.
actor-sin.hbs Enables tracking and management of sin overflow and sin marks for characters. Allows setting max value, checking overflow, rolling sin marks, and clearing/deleting marks. Supports dynamic display based on character data.
templates.item
File Summary
item-feature-sheet.hbs Enhances item feature sheets by displaying item details, enabling interactive editing, and integrating with a system for enriched text handling. Facilitates easy navigation through tabs for description, attributes, and effects, streamlining user interaction within the repositorys architecture.
item-item-sheet.hbs Customizes item details for an RPG character sheet, integrating image, resource quantities, type, and descriptions. Facilitates seamless editing and organization with tabbed navigation for descriptions and attributes, enhancing gameplay experience.
item-spell-sheet.hbs Empowers spell management by providing tabs for description and attributes. Includes an editor for enriched text data and fields for spell level input. Enhances user experience for customizing and organizing spell information in the system.
item-agenda-sheet.hbs Displays a fallback template for items lacking specific ones. Features a customizable form with item name input. Includes tab navigation for Description section with rich text editing capabilities for system descriptions.
item-blasphemy-sheet.hbs Enables customization of item details and effects in Cains system through a user-friendly interface with tabs for description, attributes, and effects. Facilitates seamless navigation and editing of items with dynamic content.
item-sheet.hbs Defines the fallback template for items without specific ones. Displays item details, such as name and image. Offers tab navigation for Description and Attributes sections, supporting enriched text data editing. Maintains modularity for easy addition of new fields.
templates.item.parts
File Summary
item-effects.hbs Renders a dynamic list of item effects with controls for creation, editing, and deletion. Incorporates localized labels and icons for each effect, enhancing user interaction within the item management module of the greater repository system.

Getting Started

System Requirements:

  • None: version x.y.z

Installation

From source

  1. Clone the cain repository:
$ git clone https://github.com/diabeatz96/cain
  1. Change to the project directory:
$ cd cain
  1. Install the dependencies:
$ > INSERT-INSTALL-COMMANDS

Usage

From source

Run cain using the command below:

$ > INSERT-RUN-COMMANDS

Tests

Run the test suite using the command below:

$ > INSERT-TEST-COMMANDS

Project Roadmap

  • ► INSERT-TASK-1
  • ► INSERT-TASK-2
  • ► ...

Contributing

Contributions are welcome! Here are several ways you can contribute:

Contributing Guidelines
  1. Fork the Repository: Start by forking the project repository to your github account.
  2. Clone Locally: Clone the forked repository to your local machine using a git client.
    git clone https://github.com/diabeatz96/cain
  3. Create a New Branch: Always work on a new branch, giving it a descriptive name.
    git checkout -b new-feature-x
  4. Make Your Changes: Develop and test your changes locally.
  5. Commit Your Changes: Commit with a clear message describing your updates.
    git commit -m 'Implemented new feature x.'
  6. Push to github: Push the changes to your forked repository.
    git push origin new-feature-x
  7. Submit a Pull Request: Create a PR against the original project repository. Clearly describe the changes and their motivations.
  8. Review: Once your PR is reviewed and approved, it will be merged into the main branch. Congratulations on your contribution!
Contributor Graph


License

This project is protected under the SELECT-A-LICENSE License. For more details, refer to the LICENSE file.


Acknowledgments

  • List any resources, contributors, inspiration, etc. here.

Return