{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9856bb2-b1d8-4614-aadd-36bd7fb15efd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import py3Dmol\n",
    "from rdkit import Chem\n",
    "\n",
    "\n",
    "def visualize_complex(pdb_block, sdf_block, show_protein_surface=True, show_ligand=True, show_ligand_surface=False):\n",
    "    view = py3Dmol.view()\n",
    "\n",
    "    # Add protein to the canvas\n",
    "    view.addModel(pdb_block, 'pdb')\n",
    "    if show_protein_surface:\n",
    "        view.addSurface(py3Dmol.VDW, {'opacity': 0.7, 'color': 'white'}, {'model': -1})\n",
    "    else:\n",
    "        view.setStyle({'model': -1}, {'cartoon': {'color': 'spectrum'}, 'line': {}})\n",
    "    view.setStyle({'model': -1}, {\"cartoon\": {\"style\": \"edged\", 'opacity': 0}})\n",
    "\n",
    "    # Add ligand to the canvas\n",
    "    if show_ligand:\n",
    "        view.addModel(sdf_block, 'sdf')\n",
    "        view.setStyle({'model': -1}, {'stick': {'color': 'spectrum'}})\n",
    "        # view.setStyle({'model': -1}, {'cartoon': {'color': 'spectrum'}, 'line': {}})\n",
    "        if show_ligand_surface:\n",
    "            view.addSurface(py3Dmol.VDW, {'opacity': 0.8}, {'model': -1})\n",
    "\n",
    "    view.zoomTo()\n",
    "    return view.show()\n",
    "\n",
    "protein_path = './test_set'\n",
    "# Choose the protein you would like to view.\n",
    "with open(protein_path+f\"/TNKS2_HUMAN_948_1162_0/5aeh_A_rec.pdb\") as f:\n",
    "    pdb_block = f.read()\n",
    "with open('./ligand'+f\"/TNKS2_HUMAN_948_1162_0/ligand_0.sdf\") as f: \n",
    "    sdf_block = f.read()\n",
    "visualize_complex(pdb_block,sdf_block)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
