Skip to main content

No project description provided

Project description

abstract_react

Python tooling for analyzing, cleaning, and enriching React / TypeScript projects.

abstract_react started as an automated TypeScript import/helper toolkit and gradually expanded into a broader project utility layer for React and TypeScript codebases. It now includes import cleanup, dependency graph analysis, metadata generation, domain/title utilities, and build/path helpers — all driven from Python.

Why

Frontend projects often end up needing automation that lives outside the frontend itself.

Whether the goal is cleaning imports, tracing dependency structure, generating metadata, or supporting a larger publishing/build pipeline, the usual Node-only toolchain is not always the most convenient orchestration layer.

abstract_react exists to let Python drive that work.

What it does

Import cleanup and reconstruction

  • parses single-line and multi-line TypeScript import statements
  • extracts import symbols and source paths
  • rebuilds import sections cleanly
  • preserves file structure and supports safe replacement flows via structured schemas

Project analysis and graphing

  • analyzes exports, imports, and re-exports
  • distinguishes export kinds where possible
  • builds entry-reachable dependency graphs
  • builds full-project graphs across a source tree
  • emits graph structures suitable for downstream visualization or tooling

Metadata and SEO-oriented utilities

  • generates normalized metadata dictionaries
  • builds Open Graph output from page info
  • supports title/domain variant derivation
  • integrates image validation and resize logic into metadata generation flows

Build and path helpers

  • resolves absolute and relative paths
  • derives output paths for tooling workflows
  • supports project-oriented filesystem operations around code generation and analysis

Project scope

This is not a React component library.

This is a Python-side utility package for working around React and TypeScript projects:

  • inspecting them
  • cleaning them
  • mapping them
  • generating metadata for them
  • fitting them into larger automation pipelines

That distinction matters.

Good fit for

  • Python-heavy developers maintaining React or TS projects
  • automated cleanup/refactor tooling
  • import normalization workflows
  • dependency inspection and graphing
  • metadata/SEO generation pipelines
  • build-time or pre-deployment project automation

Architecture at a glance

React / TypeScript project
        │
        ├── import parsing + reconstruction
        │
        ├── export / re-export inspection
        │
        ├── dependency graph building
        │
        ├── metadata + Open Graph generation
        │
        └── path/build utility support

Features

  • Python-first orchestration for React/TS projects
  • robust import extraction from raw file text
  • structured dataclasses for transformation workflows
  • graph-based dependency analysis
  • metadata generation for frontend/page outputs
  • utility support for larger project automation systems

Installation

pip install abstract-react

Or from source:

git clone <your-repo-url>
cd abstract_react
pip install -e .

Examples

Analyze a reachable dependency graph

from pathlib import Path
from abstract_react.analyze_utils.src.graph_utils import build_graph_reachable

graph = build_graph_reachable(
    entry=Path("src/main.tsx"),
    src_root=Path("src")
)

print(graph["nodes"])
print(graph["edges"])

Extract imports from a file

from abstract_react.clean_imports.src.functions.importUtils import extract_all_imports_robust

imports = extract_all_imports_robust("src/example.ts")
for imp in imports:
    print(imp.from_path, imp.imports)

Rebuild an import section

from abstract_react.clean_imports.src.functions.importUtils import extract_all_imports_robust
from abstract_react.clean_imports.src.functions.fileUtils import replace_imports_in_file

imports = extract_all_imports_robust("src/example.ts")

replacement = replace_imports_in_file(
    file_path="src/example.ts",
    new_imports=[
        'import { something } from "./utils";'
    ],
    imports=imports
)

print(replacement.new_content)

Generate metadata

from abstract_react.meta_utils.generators.metadata_builder import generate_metadata

info = {
    "title": "Example Page",
    "description": "Example description",
    "share_url": "https://example.com/page",
    "thumbnail": "thumb.jpg",
    "thumbnail_link": "https://example.com/thumb.jpg",
}

meta = generate_metadata(info)
print(meta["og"])
print(meta["twitter"])

Example module areas

abstract_react/
├── analyze_utils/
│   ├── graph analysis
│   ├── worker utilities
│   └── import/export inspection
├── clean_imports/
│   ├── import parsing
│   ├── file reconstruction
│   ├── schemas
│   └── replacement utilities
├── meta_utils/
│   ├── metadata builders
│   ├── Open Graph helpers
│   ├── Twitter helpers
│   ├── title/domain utilities
│   └── API-facing helpers
├── build_utils/
│   └── path/build helpers

Design notes

This package grew outward from a narrower original purpose.

It began as automated TypeScript helper/import tooling, but the same workflows naturally led into adjacent needs:

  • project structure awareness
  • dependency inspection
  • path resolution
  • metadata generation
  • frontend-facing automation support

So while the package is broader now than the original intent, the growth is still coherent: it is all centered on Python-controlled tooling for React/TypeScript projects.

Roadmap ideas

  • CLI entrypoints for common workflows

  • clearer public API surface

  • graph export targets beyond DOT

  • project config presets

  • stronger separation between:

    • import tooling
    • analyzer tooling
    • metadata tooling

Status

Actively evolving utility package.

Originally import-focused. Now a broader automation toolkit for React/TypeScript ecosystems managed from Python.


Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

abstract_react-0.0.0.136.tar.gz (98.7 kB view details)

Uploaded Source

Built Distribution

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

abstract_react-0.0.0.136-py3-none-any.whl (142.7 kB view details)

Uploaded Python 3

File details

Details for the file abstract_react-0.0.0.136.tar.gz.

File metadata

  • Download URL: abstract_react-0.0.0.136.tar.gz
  • Upload date:
  • Size: 98.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for abstract_react-0.0.0.136.tar.gz
Algorithm Hash digest
SHA256 84afe42c91d8d3c653dfdff58a1c8965221cb29d3884c314f6f238f7eeb378bf
MD5 02f3fdb20da7d0eb771ef9177e7f3a08
BLAKE2b-256 ebcaab7a13b1cd0f0678ed7c5a359483d272940a73fb0d309e9f7fda869b46b1

See more details on using hashes here.

File details

Details for the file abstract_react-0.0.0.136-py3-none-any.whl.

File metadata

File hashes

Hashes for abstract_react-0.0.0.136-py3-none-any.whl
Algorithm Hash digest
SHA256 ef4ffe384883a46a18f0ae6aef394381e939f8724ed8174aeddeb9a1f3ad3e18
MD5 9d760501230343316c932c6b50cac052
BLAKE2b-256 28d3e5c1bfe7f655387eccae42abd5cc224a5b514c944d084126151525c202af

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