Skip to main content

A comprehensive Python package for seamless integration of CSS frameworks (Tailwind CSS, Bootstrap) with ReactPy applications and HTML projects

Project description

ReactPy Icon

ReactFlow CSS (Py)

PyPI Version LICENSE MIT


ReactFlow CSS

ReactFlow CSS is a Python package that simplifies the integration of popular CSS frameworks like Tailwind CSS and Bootstrap into your ReactPy applications and other HTML projects. It provides a streamlined API for configuring, compiling, and serving CSS, making it easier to manage your styles directly from Python.

Features

  • Tailwind CSS Integration: Configure and compile Tailwind CSS seamlessly within your Python projects.
  • Bootstrap Integration: Include Bootstrap CSS and JavaScript with minimal setup.
  • Google SVG Icons: Access and generate SVG icons from Google Material Icons directly in your projects.
  • ReactPy Compatibility: Specifically designed for ReactPy components and workflows.
  • Unified API: Helper class for managing multiple frameworks through a single interface.
  • Template Management: Built-in templates and default styles for rapid development.
  • CLI Comment: For Setup and Build your projects

Installation

Install ReactFlow CSS using pip:

pip install ReactFlow-CSS

CLI Usage

Run the following command:

rf-css [command] [flags] [args]

The CLI simplifies the development process.

Usage Examples:

rf-css init -d

Creates default Tailwind CSS styles.

Getting Help

rf-css --help

For more information, run the above command.

Quick Start

Basic Configuration

First, create a configuration for your preferred CSS framework:

# For Tailwind CSS
from reactflow_css.tailwindcss import configure_tailwind
config_tailwind = configure_tailwind(__file__)

# For Bootstrap
from reactflow_css.bootstrap import configure_boots
config_boots = configure_boots(__file__)

Getting Default Templates

Generate default CSS templates quickly:

# Get default Tailwind CSS template
from reactflow_css.tailwindcss import default_tailwind
tailwind_css = default_tailwind(path_output="./styles/tailwind.css")

# Get default Bootstrap template
from reactflow_css.bootstrap import default_boots
bootstrap_css = default_boots(path_output="./styles/bootstrap.css")

Parameters:

  • path_output (str, optional): File path to save the generated CSS content. If None, return content as string only.

Tailwind CSS Integration

Step 1: Configure Tailwind

Set up your Tailwind configuration:

from reactflow_css.tailwindcss import configure_tailwind

config_tailwind = configure_tailwind(__file__)

# Define Tailwind configuration
tailwind_config = {
    "content": ["./src/**/*.{js,ts,jsx,tsx,py}", "./templates/**/*.html"],
    "theme": {
        "extend": {
            "colors": {
                "primary": "#3b82f6",
                "secondary": "#64748b"
            }
        }
    },
    "plugins": []
}

# Apply configuration
config_tailwind.config(tailwind_config)

Step 2: Set Up Templates

Generate the necessary Tailwind files:

# Create tailwind.config.js and input.css files
config_tailwind.render_templates(
    path_config="./tailwind.config.js",
    path_index="./input.css"
)

# Or use default templates
config_tailwind.default_templates(path_output="./styles/")

Step 3: Compile CSS

Compile your Tailwind CSS:

# Compile with file paths
compiled_css = config_tailwind.compile(
    path_config="./tailwind.config.js",
    path_index="./input.css",
    path_output="./dist/styles.css"
)

# Or compile with inline styles
compiled_css = config_tailwind.compile(
    index="@tailwind base; @tailwind components; @tailwind utilities;",
    path_output="./dist/styles.css"
)

Bootstrap Integration

Step 1: Set Up Templates

Initialize Bootstrap templates:

from reactflow_css.bootstrap import configure_boots

config_boots = configure_boots(__file__)

# Render template from existing file
template_content = config_boots.render_templates(path_index="./styles/custom.css")

Step 2: Configure Styles

Add custom styles and imports:

# Configure with custom styles and imports
custom_css = """
.custom-button {
    background-color: #007bff;
    border: none;
    padding: 12px 24px;
    border-radius: 4px;
}
"""

bootstrap_css = config_boots.config(
    style=custom_css,
    path_output="./dist/bootstrap-custom.css",
    '@import "https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css";',
    '@import "./additional-styles.css";',
    '@import "--/css/bootstrap.min.css";'
)

If you use this format @import '--/...' then it will import the css module from the main folder of this package.

Google Icons Integration

Generate SVG icons from Google Material Icons:

from reactflow_css.icons import generate_icons

# Generate single icon
icon_svg = generate_icons("home")
print(icon_svg)

# Generate multiple icons
icons = generate_icons("home", "settings", "account_circle")
for name, svg in icons.items():
    with open(f"./icons/{name}.svg", "w") as f:
        f.write(svg)

API Reference

See the source documentation for complete API reference for each module:

  • reactflow_css.tailwindcss
  • reactflow_css.bootstrap
  • reactflow_css.icons

License

This project is licensed under the MIT License. See the LICENSE file for details. The included Google icons are licensed under the Apache 2.0 License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

reactflow_css-2.0.0b5.tar.gz (3.2 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

reactflow_css-2.0.0b5-py3-none-any.whl (6.4 MB view details)

Uploaded Python 3

File details

Details for the file reactflow_css-2.0.0b5.tar.gz.

File metadata

  • Download URL: reactflow_css-2.0.0b5.tar.gz
  • Upload date:
  • Size: 3.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.11

File hashes

Hashes for reactflow_css-2.0.0b5.tar.gz
Algorithm Hash digest
SHA256 6186584b88125c3192baa434fdb75a539a0e6c2891430acd72dff84042d41a84
MD5 3b34453dd2db70563209923df22d1f7d
BLAKE2b-256 26e5c81b32e4bbdbccf759f137ce9e18e9dbcf9d495f174a2d31fa46709f11c5

See more details on using hashes here.

File details

Details for the file reactflow_css-2.0.0b5-py3-none-any.whl.

File metadata

File hashes

Hashes for reactflow_css-2.0.0b5-py3-none-any.whl
Algorithm Hash digest
SHA256 dd37c62d29c6d36ac062ff30702578a1470b6560e9ea0de161e2061983ebcdbd
MD5 17606e9f1e8be553ef0b7760089cdd2c
BLAKE2b-256 981b9c9342297fa774c462e8fb427e90fadf6a7665bd4c2478b45d4c04780da7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page