georgebuilds/livewire-molecule

A Laravel Livewire component for 3D molecular visualization using 3DMol.js

Installs: 8

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 2

pkg:composer/georgebuilds/livewire-molecule

v1.0.1 2025-12-31 00:26 UTC

README

A Laravel Livewire component for 3D molecular visualization powered by 3DMol.js.

Features

  • ๐Ÿงช Multiple input formats: SMILES, InChI, PDB ID, PubChem CID, or raw SDF data
  • ๐ŸŽจ Multiple visualization styles: stick, sphere, cartoon, line, ball-and-stick
  • ๐Ÿ”„ Three display modes: interactive, rotating, static
  • โšก Reactive updates with Livewire
  • ๐ŸŽฏ Automatic 3D coordinate generation from SMILES/InChI

Requirements

  • PHP 8.1+
  • Laravel 10, 11, or 12
  • Livewire 3.x
  • Alpine.js (included with Livewire)

Installation

composer require georgebuilds/livewire-molecule

Optionally publish the config file:

php artisan vendor:publish --tag=molecule-config

Usage

Basic Usage

{{-- From SMILES notation --}}
<livewire:molecule smiles="CCO" />

{{-- From PDB ID --}}
<livewire:molecule pdb="1CRN" />

{{-- From PubChem CID --}}
<livewire:molecule pubchem-cid="2244" />

{{-- From InChI --}}
<livewire:molecule inchi="InChI=1S/C2H6O/c1-2-3/h3H,2H2,1H3" />

{{-- From raw SDF data --}}
<livewire:molecule :sdf="$sdfContent" />

Display Modes

{{-- Interactive (default) - user can rotate/zoom --}}
<livewire:molecule smiles="CCO" mode="interactive" />

{{-- Rotating - auto-rotates on Y axis --}}
<livewire:molecule smiles="CCO" mode="rotating" />

{{-- Static - no interaction --}}
<livewire:molecule smiles="CCO" mode="static" />

Visualization Styles

<livewire:molecule smiles="CCO" style="stick" />
<livewire:molecule smiles="CCO" style="sphere" />
<livewire:molecule smiles="CCO" style="ball-and-stick" />
<livewire:molecule smiles="CCO" style="cartoon" /> {{-- Best for proteins --}}
<livewire:molecule smiles="CCO" style="line" />

Customizing Appearance

<livewire:molecule
    smiles="c1ccccc1"
    mode="interactive"
    style="ball-and-stick"
    background-color="#1a1a2e"
    width="500px"
    height="400px"
/>

Reactive Updates

The component reacts to property changes:

<div x-data="{ currentSmiles: 'CCO' }">
    <select x-model="currentSmiles">
        <option value="CCO">Ethanol</option>
        <option value="CC(=O)O">Acetic Acid</option>
        <option value="c1ccccc1">Benzene</option>
    </select>

    <livewire:molecule :smiles="$currentSmiles" />
</div>

Configuration

// config/molecule.php

return [
    // Default background color
    'default_background' => '#ffffff',

    // HTTP timeout for external APIs (seconds)
    'timeout' => 10,

    // Cache settings for resolved molecules
    'cache' => [
        'enabled' => true,
        'ttl' => 60 * 60 * 24, // 24 hours
        'prefix' => 'molecule_',
    ],
];

Input Format Priority

When multiple identifiers are provided, the component uses this priority:

  1. sdf (raw data, no API call needed)
  2. pdb (fetches from RCSB PDB)
  3. pubchem-cid (fetches from PubChem)
  4. smiles (converts via NCI CACTUS)
  5. inchi (converts via NCI CACTUS)

External APIs Used

This package relies on these free public APIs for structure retrieval and conversion:

API Purpose Rate Limits
RCSB PDB Fetch protein structures Generous
PubChem Fetch compound structures 5 req/sec
NCI CACTUS SMILES/InChI โ†’ 3D conversion Best effort

For production use with high traffic, consider implementing your own conversion service or caching aggressively.

Troubleshooting

"Failed to convert SMILES to 3D structure"

  • Verify the SMILES string is valid
  • The NCI CACTUS service may be temporarily unavailable
  • Some complex molecules may fail to convert

Molecule appears blank

  • Check browser console for JavaScript errors
  • Ensure 3DMol.js is loading (check Network tab)
  • Verify the molecule data is being resolved (check $moleculeData property)

Testing

composer test

Acknowledgments

  • 3DMol.js - BSD-3-Clause licensed molecular viewer
  • NCI CACTUS - Chemical structure conversion service
  • PubChem - Chemical compound database

License

MIT License. See LICENSE for details.

This package includes 3DMol.js which is licensed under BSD-3-Clause.