.. image:: https://img.shields.io/badge/dynamic/json.svg?label=forum&url=https%3A%2F%2Fforum.image.sc%2Ftags%2Fomero-figure.json&query=%24.topic_list.tags.0.topic_count&colorB=brightgreen&suffix=%20topics&logo=
:target: https://forum.image.sc/tag/omero-figure
:alt: Image.sc forum
.. image:: https://github.com/ome/omero-figure/workflows/OMERO/badge.svg
:target: https://github.com/ome/omero-figure/actions
.. image:: https://badge.fury.io/py/omero-figure.svg
:target: https://badge.fury.io/py/omero-figure
OMERO.figure
============
An OMERO.web app for creating figures from images in OMERO.
For full details see `SUPPORT.md <https://github.com/ome/omero-figure/blob/master/SUPPORT.md>`_.
Requirements
------------
* OMERO.web 5.6.0 or newer.
Installing from PyPI
--------------------
This section assumes that an OMERO.web is already installed.
Install the app using `pip <https://pip.pypa.io/en/stable/>`_:
NB: You need to ensure that you are running ``pip`` from the python environment
where ``omero-web`` is installed. Depending on your install, you may need to
call ``pip`` with, for example: ``/path/to_web_venv/venv/bin/pip install ...``
::
$ pip install -U omero-figure
Add figure custom app to your installed web apps:
::
$ omero config append omero.web.apps '"omero_figure"'
Display a link to 'Figure' at the top of the webclient:
::
$ omero config append omero.web.ui.top_links '["Figure", "figure_index",
{"title": "Open Figure in new tab", "target": "_blank"}]'
Add 'Figure' to the 'Open with' options, available from context menu on
the webclient tree:
::
$ omero config append omero.web.open_with '["omero_figure", "new_figure",
{"supported_objects":["images"], "target": "_blank", "label": "OMERO.figure"}]'
Now restart OMERO.web as normal.
Enabling figure export
----------------------
This section assumes that an OMERO.server is already installed.
Figures can be exported as PDF or TIFF files using a script that runs on the OMERO.server. This script needs to be uploaded to the OMERO.server and its dependencies
installed in the OMERO.server virtual environment.
The script can be uploaded using two alternative workflows, both of which require you to have the correct admin privileges.
To find where OMERO.figure has been installed using pip, run:
::
$ pip show omero-figure
The command will display the absolute path to the directory where the application is installed e.g. ``~/<virtualenv_name>/lib/python3.6/site-packages``. Go to that directory.
*Option 1*: Connect to the OMERO server and upload the script via the CLI. It is important to be in the correct directory when uploading so that the script is uploaded with the full path: ``omero/figure_scripts/Figure_To_Pdf.py``:
::
$ cd omero_figure/scripts
$ omero script upload omero/figure_scripts/Figure_To_Pdf.py --official
*Option 2*: Alternatively, before starting the OMERO.server, copy the script from the figure install
``/omero_figure/scripts/omero/figure_scripts/Figure_To_Pdf.py`` to the OMERO.server ``path/to/OMERO.server/lib/scripts/omero/figure_scripts``. Then restart the OMERO.server.
*Option 3*: Upload the script through the OMERO web interface: For this, log into your OMERO web interface as admin, select the scripts icon and click on the "Upload Script" button.
Select the ``Figure_To_Pdf.py`` script from the directory where you copied it to locally and upload it into the directory ``omero/figure_scripts``.
Now install the script's dependencies:
* Install `reportlab <https://bitbucket.org/rptlab/reportlab>`_ PDF python package.
This needs to be installed in the virtual environment where the ``OMERO.server`` is installed. Depending on your install, you may need to
call ``pip`` with, for example: ``/path/to_server_venv/venv/bin/pip install ...``
::
$ pip install reportlab
* Optional: Figure legends can be formatted using Markdown syntax. To see this correctly in the exported PDF info page, we need `Python Markdown <https://python-markdown.github.io/>`_:
::
$ pip install markdown
Upgrading OMERO.figure
----------------------
After upgrading OMERO.figure with:
::
$ pip install -U omero-figure
You need to update the Figure export script using one of the 2 options described
above. If using *Option 1*, you need to *replace* the existing script:
::
# Get the ID of the existing Figure_To_Pdf script:
$ omero script list
# Replace the script
$ cd omero_figure/scripts
$ omero script replace <SCRIPT_ID> omero/figure_scripts/Figure_To_Pdf.py
Development
-----------
We use `vite.js <https://vitejs.dev/>`_ to build and serve the app during development.
Install Node from https://nodejs.org, then:
::
$ cd omero-figure
$ npm install
To serve the app at http://localhost:8080/ using the vite dev server
(this will automatically refresh the page when changes are saved):
::
$ npm run start
If you are editing the Shape-Editor code, you can view the test page at
http://localhost:8080/shapeEditorTest.html
CORS
****
During development, we load and save figure files to an omero-web server.
You will need to have CORS enabled on your local omero-web server at
http://localhost:4080/ and be logged in already.
This URL can be edited in `src/index.html`.
You MUST access the figure app at http://localhost:8080/ (NOT http://127.0.0.1:8080/)
for CORS to work.
NB: in general, POST actions such as saving of figure files or exporting figures doesn't
yet work with the dev server. To test these actions, build the app as described below:
Build
-----
To build the app:
::
$ npm run build
This compiles index.html and other static assets into correct locations to be
served by the Django `omero-web` server.
To serve this on a local omero-web, set config as above and install with:
::
$ pip install -e .
In order to build whenever changes are saved within the `src/` directory:
::
$ npm run watch
Release process
---------------
This repository uses `bump2version <https://pypi.org/project/bump2version/>`_ to manage version numbers.
To tag a release run::
$ bumpversion release
This will remove the ``.dev0`` suffix from the current version, commit, and tag the release.
To switch back to a development version run::
$ bumpversion --no-tag [major|minor|patch]
specifying ``major``, ``minor`` or ``patch`` depending on whether the development branch will be a `major, minor or patch release <https://semver.org/>`_. This will also add the ``.dev0`` suffix.
Remember to ``git push`` all commits and tags.
License
-------
OMERO.figure is released under the AGPL.
Copyright
---------
2016-2024, The Open Microscopy Environment
Raw data
{
"_id": null,
"home_page": "https://github.com/ome/omero-figure",
"name": "omero-figure",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3",
"maintainer_email": null,
"keywords": "OMERO.web, figure",
"author": "The Open Microscopy Team",
"author_email": "ome-devel@lists.openmicroscopy.org.uk",
"download_url": "https://files.pythonhosted.org/packages/01/3c/f521dfc3282a2fdd972e4fc626825754725f00c71498508be1e66c3f9cfa/omero_figure-7.1.0.tar.gz",
"platform": null,
"description": ".. image:: https://img.shields.io/badge/dynamic/json.svg?label=forum&url=https%3A%2F%2Fforum.image.sc%2Ftags%2Fomero-figure.json&query=%24.topic_list.tags.0.topic_count&colorB=brightgreen&suffix=%20topics&logo=\n :target: https://forum.image.sc/tag/omero-figure\n :alt: Image.sc forum\n\n.. image:: https://github.com/ome/omero-figure/workflows/OMERO/badge.svg\n :target: https://github.com/ome/omero-figure/actions\n\n.. image:: https://badge.fury.io/py/omero-figure.svg\n :target: https://badge.fury.io/py/omero-figure\n\n\nOMERO.figure\n============\n\nAn OMERO.web app for creating figures from images in OMERO.\n\nFor full details see `SUPPORT.md <https://github.com/ome/omero-figure/blob/master/SUPPORT.md>`_.\n\nRequirements\n------------\n\n* OMERO.web 5.6.0 or newer.\n\n\nInstalling from PyPI\n--------------------\n\nThis section assumes that an OMERO.web is already installed.\n\nInstall the app using `pip <https://pip.pypa.io/en/stable/>`_:\n\nNB: You need to ensure that you are running ``pip`` from the python environment\nwhere ``omero-web`` is installed. Depending on your install, you may need to\ncall ``pip`` with, for example: ``/path/to_web_venv/venv/bin/pip install ...``\n\n::\n\n $ pip install -U omero-figure\n\nAdd figure custom app to your installed web apps:\n\n::\n\n $ omero config append omero.web.apps '\"omero_figure\"'\n\nDisplay a link to 'Figure' at the top of the webclient:\n\n::\n\n $ omero config append omero.web.ui.top_links '[\"Figure\", \"figure_index\",\n {\"title\": \"Open Figure in new tab\", \"target\": \"_blank\"}]' \n\n\nAdd 'Figure' to the 'Open with' options, available from context menu on\nthe webclient tree:\n\n::\n\n $ omero config append omero.web.open_with '[\"omero_figure\", \"new_figure\",\n {\"supported_objects\":[\"images\"], \"target\": \"_blank\", \"label\": \"OMERO.figure\"}]'\n\nNow restart OMERO.web as normal.\n\n\nEnabling figure export\n----------------------\n\nThis section assumes that an OMERO.server is already installed.\n\nFigures can be exported as PDF or TIFF files using a script that runs on the OMERO.server. This script needs to be uploaded to the OMERO.server and its dependencies\ninstalled in the OMERO.server virtual environment.\n\nThe script can be uploaded using two alternative workflows, both of which require you to have the correct admin privileges.\nTo find where OMERO.figure has been installed using pip, run:\n\n::\n\n $ pip show omero-figure\n\nThe command will display the absolute path to the directory where the application is installed e.g. ``~/<virtualenv_name>/lib/python3.6/site-packages``. Go to that directory.\n\n*Option 1*: Connect to the OMERO server and upload the script via the CLI. It is important to be in the correct directory when uploading so that the script is uploaded with the full path: ``omero/figure_scripts/Figure_To_Pdf.py``:\n\n::\n\n $ cd omero_figure/scripts\n $ omero script upload omero/figure_scripts/Figure_To_Pdf.py --official\n\n*Option 2*: Alternatively, before starting the OMERO.server, copy the script from the figure install\n``/omero_figure/scripts/omero/figure_scripts/Figure_To_Pdf.py`` to the OMERO.server ``path/to/OMERO.server/lib/scripts/omero/figure_scripts``. Then restart the OMERO.server.\n\n*Option 3*: Upload the script through the OMERO web interface: For this, log into your OMERO web interface as admin, select the scripts icon and click on the \"Upload Script\" button.\nSelect the ``Figure_To_Pdf.py`` script from the directory where you copied it to locally and upload it into the directory ``omero/figure_scripts``.\n\nNow install the script's dependencies:\n\n\n* Install `reportlab <https://bitbucket.org/rptlab/reportlab>`_ PDF python package.\n This needs to be installed in the virtual environment where the ``OMERO.server`` is installed. Depending on your install, you may need to\n call ``pip`` with, for example: ``/path/to_server_venv/venv/bin/pip install ...``\n\n::\n\n $ pip install reportlab\n\n* Optional: Figure legends can be formatted using Markdown syntax. To see this correctly in the exported PDF info page, we need `Python Markdown <https://python-markdown.github.io/>`_:\n\n::\n\n $ pip install markdown\n\nUpgrading OMERO.figure\n----------------------\n\nAfter upgrading OMERO.figure with:\n\n::\n\n $ pip install -U omero-figure\n\nYou need to update the Figure export script using one of the 2 options described\nabove. If using *Option 1*, you need to *replace* the existing script:\n\n::\n\n # Get the ID of the existing Figure_To_Pdf script:\n $ omero script list\n\n # Replace the script\n $ cd omero_figure/scripts\n $ omero script replace <SCRIPT_ID> omero/figure_scripts/Figure_To_Pdf.py\n\n\nDevelopment\n-----------\n\nWe use `vite.js <https://vitejs.dev/>`_ to build and serve the app during development.\n\nInstall Node from https://nodejs.org, then:\n\n::\n\n $ cd omero-figure\n $ npm install\n\nTo serve the app at http://localhost:8080/ using the vite dev server\n(this will automatically refresh the page when changes are saved):\n\n::\n\n $ npm run start\n\nIf you are editing the Shape-Editor code, you can view the test page at\nhttp://localhost:8080/shapeEditorTest.html\n\n\nCORS\n****\n\nDuring development, we load and save figure files to an omero-web server.\nYou will need to have CORS enabled on your local omero-web server at\nhttp://localhost:4080/ and be logged in already.\nThis URL can be edited in `src/index.html`.\n\nYou MUST access the figure app at http://localhost:8080/ (NOT http://127.0.0.1:8080/)\nfor CORS to work.\n\nNB: in general, POST actions such as saving of figure files or exporting figures doesn't\nyet work with the dev server. To test these actions, build the app as described below:\n\n\nBuild\n-----\n\nTo build the app:\n\n::\n\n $ npm run build\n\nThis compiles index.html and other static assets into correct locations to be\nserved by the Django `omero-web` server.\n\nTo serve this on a local omero-web, set config as above and install with:\n\n::\n\n $ pip install -e .\n\nIn order to build whenever changes are saved within the `src/` directory:\n\n::\n\n $ npm run watch\n\n\nRelease process\n---------------\n\nThis repository uses `bump2version <https://pypi.org/project/bump2version/>`_ to manage version numbers.\nTo tag a release run::\n\n $ bumpversion release\n\nThis will remove the ``.dev0`` suffix from the current version, commit, and tag the release.\n\nTo switch back to a development version run::\n\n $ bumpversion --no-tag [major|minor|patch]\n\nspecifying ``major``, ``minor`` or ``patch`` depending on whether the development branch will be a `major, minor or patch release <https://semver.org/>`_. This will also add the ``.dev0`` suffix.\n\nRemember to ``git push`` all commits and tags.\n\nLicense\n-------\n\nOMERO.figure is released under the AGPL.\n\nCopyright\n---------\n\n2016-2024, The Open Microscopy Environment\n",
"bugtrack_url": null,
"license": "AGPL-3.0",
"summary": "OMERO figure creation app",
"version": "7.1.0",
"project_urls": {
"Download": "https://github.com/ome/omero-figure/archive/v7.1.0.tar.gz",
"Homepage": "https://github.com/ome/omero-figure"
},
"split_keywords": [
"omero.web",
" figure"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "ea5b7ef1639d033da1d2d74823a48a2e84abbcb1dc7d3393de8dc78c72ef65ba",
"md5": "ba54a0ed832b696eb96d66cd47da7a82",
"sha256": "d7bfe15f43edf303f4ee69552aa689a7751220c77629f4fce4e315131dc1b9e7"
},
"downloads": -1,
"filename": "omero_figure-7.1.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "ba54a0ed832b696eb96d66cd47da7a82",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3",
"size": 1114011,
"upload_time": "2024-09-03T09:09:33",
"upload_time_iso_8601": "2024-09-03T09:09:33.857275Z",
"url": "https://files.pythonhosted.org/packages/ea/5b/7ef1639d033da1d2d74823a48a2e84abbcb1dc7d3393de8dc78c72ef65ba/omero_figure-7.1.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "013cf521dfc3282a2fdd972e4fc626825754725f00c71498508be1e66c3f9cfa",
"md5": "f767215711705d19c67a6f5bff77bc8a",
"sha256": "36c314b2c41b8dd0db2d8f72def624cfc7fe730eaabb75c647966ba680fed086"
},
"downloads": -1,
"filename": "omero_figure-7.1.0.tar.gz",
"has_sig": false,
"md5_digest": "f767215711705d19c67a6f5bff77bc8a",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3",
"size": 1108128,
"upload_time": "2024-09-03T09:09:35",
"upload_time_iso_8601": "2024-09-03T09:09:35.278907Z",
"url": "https://files.pythonhosted.org/packages/01/3c/f521dfc3282a2fdd972e4fc626825754725f00c71498508be1e66c3f9cfa/omero_figure-7.1.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-09-03 09:09:35",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "ome",
"github_project": "omero-figure",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [
{
"name": "omego",
"specs": []
}
],
"lcname": "omero-figure"
}