@iktos-oss/molecule-representation
v1.11.1
Published
exports interactif molecule represnetations as react components
Downloads
971
Readme
molecule-representation
React components for interactive 2D molecule representation rendering.
Demo
Visit https://molecule-representation-ramziweslati.vercel.app for a demo of the package, you can browse the diffrent options like molecule representations with zoom, click handler, substructure alignement...
Deployments are automated via Vercel.
Usage
Initial setup
1- First follow the @iktos-oss/rdkit-provider setup.
2- Wrap your components in an RDKit provider from @iktos-oss/rdkit-provider
import { RDKitProvider } from '@iktos-oss/rdkit-provider';
<RDKitProvider>
<Component />
</RDKitProvider>`
3- For better preformance we recommend enabling the caching of rdkitjs JsMol instances, this can be done using RDKitProvider
import { RDKitProvider } from '@iktos-oss/rdkit-provider';
<RDKitProvider cache={{ enableJsMolCaching: true, maxJsMolsCached: 30 }}>
<Component />
</RDKitProvider>`
Rendering molecules
import { MoleculeRepresentation, MoleculeRepresentationProps } from '@iktos-oss/molecule-representation';
const props: MoleculeRepresentationProps = {
smiles: 'Cc1cccc(-c2ccccc2)c1',
addAtomIndices: true,
bondsToHighlight: [
[1, 0],
[3, 4],
],
atomsToHighlight: [
[1, 0],
[3, 4],
],
atomsStyles: {
default: { fill: 'green' },
1: { fill: 'red' },
},
bondsStyles: {
default: { stroke: 'black', 'stroke-width': '1px' },
'0-1': { stroke: 'green', 'stroke-width': '2px' },
'4-*': { 'stroke-width': '3px' },
'*-6': { 'stroke-width': '4px' },
'6-*': { 'stroke-width': '2px' },
},
height: 200,
width: 300,
onAtomClick: (atomId: string) => console.log("clicked atoms idx:", atomId),
onBondClick: (bondIdentifier: ClickedBondIdentifiers) => {
console.log("clicked bond idx:", bondIdentifier.bondId)
console.log("clicked bond starting atom idx:", bondIdentifier.startAtomId)
console.log("clicked bond ending atom idx:", bondIdentifier.endAtomId)
}
zoomable: true
};
<MoleculeRepresentation {...props} onAtomClick={} />
Local dev
git clone https://github.com/iktos/molecule-representation.git
cd molecule-representation
npm install
npm run storybook