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.143.tar.gz (647.4 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.143-py3-none-any.whl (1.2 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: abstract_react-0.0.0.143.tar.gz
  • Upload date:
  • Size: 647.4 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.143.tar.gz
Algorithm Hash digest
SHA256 72b67d5ad19bb02f1bcd0972eba3ce5e73069a429a86df65bab5f6e14e0a16c2
MD5 2c2772f6307f25c8c77eea16e4ed89ab
BLAKE2b-256 8c85858f958f58ce742d666ad6dd94e3d70f841f80c01210e60e595655f99b64

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for abstract_react-0.0.0.143-py3-none-any.whl
Algorithm Hash digest
SHA256 541167e1658f3df49d8ca1d3c4f5d0b097a4316f8d096568b33b86e2c8c4fc95
MD5 f765e86230226616ff05ebe9ee1e32bb
BLAKE2b-256 3499dcd752efd5e6c35322bec70eeb05110c18a0660c6774df38baa46e8cda24

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