Skip to content
Draft
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
71 commits
Select commit Hold shift + click to select a range
a2787a0
- Move contents of `commands.py` to scripts in new `bin` directory an…
gvwilson Jul 10, 2025
3dced44
preload _plotly_utils
LiamConnors Jul 22, 2025
bc32c86
add docstrings directly to px functions
LiamConnors Dec 2, 2024
174b0e9
change docstring style
LiamConnors Jul 22, 2025
badb199
Merge pull request #5292 from plotly/plotly.express-docstrings
gvwilson Jul 22, 2025
86f69f1
Merge branch 'mkdocs-conversion' into preload-plotly-utils
gvwilson Jul 22, 2025
c0237f6
Merge pull request #5290 from plotly/preload-plotly-utils
gvwilson Jul 22, 2025
76b36dd
feat: numpy documentation style
gvwilson Jul 22, 2025
96af9f6
feat: regenerating Python code with .js fixes
gvwilson Jul 22, 2025
9525f6a
feat: converting doc/python/*.md using bin/run_markdown.py
gvwilson Jul 23, 2025
80792d8
better verbosity
gvwilson Jul 26, 2025
9386750
feat: conditionalize Makefile target for testing
gvwilson Jul 29, 2025
36b21ab
add missing imports and variable definitions
LiamConnors Jul 29, 2025
6d1e5c8
Merge remote-tracking branch 'origin/fix-docs' into mkdocs-conversion
gvwilson Jul 30, 2025
20c60ef
Merge remote-tracking branch 'origin/add-missing-imports' into mkdocs…
gvwilson Jul 30, 2025
a07ea45
feat: script to check all examples in doc/python.
gvwilson Jul 30, 2025
5cad013
use _parse_md function
LiamConnors Jul 30, 2025
2e38a9a
don't process code block in region sections
LiamConnors Jul 30, 2025
e45f54c
Merge pull request #5307 from plotly/update-script
gvwilson Jul 31, 2025
73a8291
modify tests to import from graph_objects
gvwilson Jul 30, 2025
36ee5e9
add trivial test to make sure plotly.graph_objects import works
gvwilson Aug 1, 2025
57d923c
updating notes
gvwilson Aug 1, 2025
ca37382
swapping graph_objs and graph_objects
gvwilson Aug 5, 2025
31b73ce
Added backslashes to descriptions with '[][]'
daexs Aug 12, 2025
fae9563
Fixed markdown formatting for valType 'info_array'
daexs Aug 14, 2025
c2e20c7
Added backslashes to descriptions with '[][]'
daexs Aug 12, 2025
0f9b311
Fixed markdown formatting for valType 'info_array'
daexs Aug 14, 2025
3f5ee9f
regenerating with latest changes
gvwilson Aug 14, 2025
f345aef
Fixed double bracket error for regular expressions
daexs Aug 14, 2025
f840f11
Minor code cleanup
daexs Aug 14, 2025
4a7873c
Fixed double bracket error in 'basedatatypes.py'
daexs Aug 14, 2025
b0cd2f9
Merge branch 'mkdocs-conversion' of https://github.com/plotly/plotly.…
daexs Aug 14, 2025
cd623aa
Regenerated code after basevalidators.py changes
daexs Aug 14, 2025
98fab98
Fix SyntaxWarning and adjusted valType 'enumerated' docstring format.
daexs Aug 14, 2025
9ddde0f
Fixed formatting issues with nested enumerated docstrings in info_arr…
daexs Aug 15, 2025
683643c
Fixed list format in 'Dash' and 'String' properties.
daexs Aug 18, 2025
efde201
Fixed formatting for 'Compound' and 'color' properties.
daexs Aug 18, 2025
01da1c6
Fixed formatting for 'Integer' types.
daexs Aug 18, 2025
8d12a05
Fixed formatting for 'Colorscale', 'CompoundArray', and 'BaseData' ty…
daexs Aug 19, 2025
6690116
Fixed confusing indentation & some formatting
daexs Aug 19, 2025
4154910
Fixed formatting issues and consistency
daexs Aug 19, 2025
df9cc3a
feat: allow `--schema path` option to code generation
gvwilson Aug 20, 2025
77d19bb
Merge pull request #17 from gvwilson/mkdocs-conversion
daexs Aug 20, 2025
bdd049b
Fixed code block and type annotation formatting.
daexs Aug 21, 2025
cbd983d
Minor code cleanup
daexs Aug 21, 2025
95ea818
Fixed example parsing error
daexs Aug 22, 2025
31c8a2f
Fixed formatting issues and modified json file for double bracket error.
daexs Aug 25, 2025
f35c9fa
Fixed **kwargs bold formatting issue
daexs Aug 26, 2025
eef950e
Fixed types for parameters 'annotation', 'annotation_position', and '…
daexs Aug 26, 2025
e339098
Merge branch 'main' into mkdocs-conversion
gvwilson Aug 27, 2025
3e5ee8b
Merge branch 'main' into mkdocs-conversion
gvwilson Aug 27, 2025
a943429
saving generated example files
gvwilson Aug 27, 2025
569b6d7
feat: build YAML table of contents for examples
gvwilson Aug 27, 2025
6d2f32f
fix: switch to relative paths in examples
gvwilson Aug 27, 2025
dc0418a
feat: fixing some dangling references in doc/python example files
gvwilson Aug 28, 2025
66208c6
Added pages to nav bar and extra css styling
daexs Aug 28, 2025
d116e27
Fixed warnings and errors
daexs Aug 29, 2025
8607d4a
feat: allow bin/run_markdown.py to take a single block number for tes…
gvwilson Aug 29, 2025
9a40907
Fixed small import and missing module errors
daexs Sep 2, 2025
b215b37
Fixed small missing import and variable errors. Also added 'getting-s…
daexs Sep 3, 2025
1847061
Added permalinks to replace empty md files
daexs Sep 3, 2025
9da9b2d
Fixed Image not JSON serializable error
daexs Sep 3, 2025
883c0d9
Edited comment for clarity
daexs Sep 3, 2025
63882d0
Fixed deprecation warning for 'type' found when county-choropleth.md …
daexs Sep 3, 2025
7e8a638
Fixed 403 Error from Wikimedia when reading image
daexs Sep 4, 2025
77e76af
Made variable state shared across codeblocks and cleaned up previous …
daexs Sep 4, 2025
1d1620c
Fixed html image rendering and reading image from wikimedia
daexs Sep 4, 2025
2310f66
Replaced image rendering from IPython's image display and overrided P…
daexs Sep 5, 2025
a673e59
Fixed pip install invalid syntax error
daexs Sep 5, 2025
0fa35da
Fixed some references and absolute links that were broken
daexs Sep 8, 2025
842ad01
feat: filter content for mkdocstrings
gvwilson Sep 17, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 3 additions & 3 deletions js/install.json
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
{
"schemaVersion": 1,
"name": "jupyterlab-plotly",
"packageName": "jupyterlab-plotly",
"version": "6.0.1",
"packageManager": "python",
"jupyterlab": {
"mimeExtension": "lib/mimeExtension.js"
}
}

}
198 changes: 99 additions & 99 deletions js/lib/mimeExtension.js

Large diffs are not rendered by default.

1,106 changes: 132 additions & 974 deletions js/package-lock.json

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion js/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
},
"dependencies": {
"lodash-es": "^4.17.21",
"plotly.js": "3.0.1",
"plotly.js": "3.0.3",
"@lumino/widgets": "~2.4.0"
},
"devDependencies": {
Expand Down
4 changes: 3 additions & 1 deletion plotly/io/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
from ._html import to_html, write_html
from ._renderers import renderers, show
from . import base_renderers
from ._kaleido import defaults
from ._kaleido import defaults, get_chrome

__all__ = [
"to_image",
Expand All @@ -38,6 +38,7 @@
"base_renderers",
"full_figure_for_development",
"defaults",
"get_chrome",
]
else:
__all__, __getattr__, __dir__ = relative_import(
Expand All @@ -59,6 +60,7 @@
"._renderers.renderers",
"._renderers.show",
"._kaleido.defaults",
"._kaleido.get_chrome",
],
)

Expand Down
76 changes: 52 additions & 24 deletions plotly/io/_kaleido.py
Original file line number Diff line number Diff line change
Expand Up @@ -775,11 +775,13 @@ def full_figure_for_development(
return go.Figure(fig, skip_invalid=True)


def get_chrome() -> None:
def plotly_get_chrome() -> None:
"""
Install Google Chrome for Kaleido (Required for Plotly image export).
This function can be run from the command line using the command `plotly_get_chrome`
defined in pyproject.toml
This function is a command-line wrapper for `plotly.io.get_chrome()`.

When running from the command line, use the command `plotly_get_chrome`;
when calling from Python code, use `plotly.io.get_chrome()`.
"""

usage = """
Expand Down Expand Up @@ -813,16 +815,60 @@ def get_chrome() -> None:

# Handle "--path" flag
chrome_install_path = None
user_specified_path = False
if "--path" in cli_args:
path_index = cli_args.index("--path") + 1
if path_index < len(cli_args):
chrome_install_path = cli_args[path_index]
cli_args.remove("--path")
cli_args.remove(chrome_install_path)
chrome_install_path = Path(chrome_install_path)
user_specified_path = True

# If any arguments remain, command syntax was incorrect -- print usage and exit
if len(cli_args) > 1:
print(usage)
sys.exit(1)

if not cli_yes:
print(
f"""
Plotly will install a copy of Google Chrome to be used for generating static images of plots.
Chrome will be installed at: {chrome_install_path}"""
)
response = input("Do you want to proceed? [y/n] ")
if not response or response[0].lower() != "y":
print("Cancelled")
return
print("Installing Chrome for Plotly...")
exe_path = get_chrome(chrome_install_path)
print("Chrome installed successfully.")
print(f"The Chrome executable is now located at: {exe_path}")


def get_chrome(path: Union[str, Path, None] = None) -> Path:
"""
Get the path to the Chrome executable for Kaleido.
This function is used by the `plotly_get_chrome` command line utility.

Parameters
----------
path: str or Path or None
The path to the directory where Chrome should be installed.
If None, the default download path will be used.
"""
if not kaleido_available() or kaleido_major() < 1:
raise ValueError(
"""
This command requires Kaleido v1.0.0 or greater.
Install it using `pip install 'kaleido>=1.0.0'` or `pip install 'plotly[kaleido]'`."
"""
)

# Use default download path if no path was specified
if path:
user_specified_path = True
chrome_install_path = Path(path) # Ensure it's a Path object
else:
user_specified_path = False
from choreographer.cli.defaults import default_download_path

chrome_install_path = default_download_path
Expand All @@ -848,25 +894,7 @@ def get_chrome() -> None:
"""
)

# If any arguments remain, command syntax was incorrect -- print usage and exit
if len(cli_args) > 1:
print(usage)
sys.exit(1)

if not cli_yes:
print(
f"""
Plotly will install a copy of Google Chrome to be used for generating static images of plots.
Chrome will be installed at: {chrome_install_path}"""
)
response = input("Do you want to proceed? [y/n] ")
if not response or response[0].lower() != "y":
print("Cancelled")
return
print("Installing Chrome for Plotly...")
exe_path = kaleido.get_chrome_sync(path=chrome_install_path)
print("Chrome installed successfully.")
print(f"The Chrome executable is now located at: {exe_path}")
return kaleido.get_chrome_sync(path=chrome_install_path)


__all__ = ["to_image", "write_image", "scope", "full_figure_for_development"]
4 changes: 2 additions & 2 deletions plotly/labextension/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
},
"dependencies": {
"lodash-es": "^4.17.21",
"plotly.js": "3.0.1",
"plotly.js": "3.0.3",
"@lumino/widgets": "~2.4.0"
},
"devDependencies": {
Expand All @@ -32,7 +32,7 @@
"mimeExtension": true,
"outputDir": "../plotly/labextension",
"_build": {
"load": "static/remoteEntry.ee69569354eef8c6803d.js",
"load": "static/remoteEntry.fafc1a00b6eac93ead89.js",
"mimeExtension": "./mimeExtension"
}
}
Expand Down
2 changes: 0 additions & 2 deletions plotly/labextension/static/340.2a23c8275d47a2531dae.js

This file was deleted.

2 changes: 2 additions & 0 deletions plotly/labextension/static/340.e13d674598350634d78a.js

Large diffs are not rendered by default.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion plotly/offline/_plotlyjs_version.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
# DO NOT EDIT
# This file is generated by the updatebundle commands.py command
__plotlyjs_version__ = "3.0.1"
__plotlyjs_version__ = "3.0.3"
132 changes: 66 additions & 66 deletions plotly/package_data/plotly.min.js

Large diffs are not rendered by default.

214 changes: 107 additions & 107 deletions plotly/package_data/widgetbundle.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ dev = [
]

[project.scripts]
plotly_get_chrome = "plotly.io._kaleido:get_chrome"
plotly_get_chrome = "plotly.io._kaleido:plotly_get_chrome"

[tool.pytest.ini_options]
markers = [
Expand Down
21 changes: 21 additions & 0 deletions tests/test_optional/test_kaleido/test_kaleido.py
Original file line number Diff line number Diff line change
Expand Up @@ -293,3 +293,24 @@ def test_fig_to_image():
mock_calc_fig.assert_called_once()
args, _ = mock_calc_fig.call_args
assert args[0] == test_fig.to_dict()


def test_get_chrome():
"""Test that plotly.io.get_chrome() can be called."""

if not kaleido_available() or kaleido_major() < 1:
# Test that ValueError is raised when Kaleido requirements aren't met
with pytest.raises(
ValueError, match="This command requires Kaleido v1.0.0 or greater"
):
pio.get_chrome()
else:
# Test normal operation when Kaleido v1+ is available
with patch(
"plotly.io._kaleido.kaleido.get_chrome_sync",
return_value="/mock/path/to/chrome",
) as mock_get_chrome:
pio.get_chrome()

# Verify that kaleido.get_chrome_sync was called
mock_get_chrome.assert_called_once()