From 8c53b8b5742f475097711ddfba4af17956ccc2c0 Mon Sep 17 00:00:00 2001 From: Niicck Date: Mon, 22 Jan 2024 11:42:02 -0600 Subject: [PATCH 1/2] Add kwargs support to vite_react_refresh Co-authored-by: kevmo314 --- django_vite/core/asset_loader.py | 14 +++++--- django_vite/core/tag_generator.py | 13 ++++++-- django_vite/templatetags/django_vite.py | 13 ++++++-- .../templatetags/test_vite_react_refresh.py | 32 +++++++++++++++++++ 4 files changed, 64 insertions(+), 8 deletions(-) diff --git a/django_vite/core/asset_loader.py b/django_vite/core/asset_loader.py index 52642e3..f868ea0 100644 --- a/django_vite/core/asset_loader.py +++ b/django_vite/core/asset_loader.py @@ -13,7 +13,7 @@ DjangoViteAssetNotFoundError, DjangoViteConfigNotFoundError, ) -from django_vite.core.tag_generator import Tag, TagGenerator +from django_vite.core.tag_generator import Tag, TagGenerator, attrs_to_str DEFAULT_APP_NAME = "default" @@ -590,12 +590,16 @@ def generate_vite_ws_client(self, **kwargs: Dict[str, str]) -> str: attrs={"type": "module", **kwargs}, ) - def generate_vite_react_refresh_url(self) -> str: + def generate_vite_react_refresh_url(self, **kwargs: Dict[str, str]) -> str: """ Generates the script for the Vite React Refresh for HMR. Only used in development, in production this method returns an empty string. + Keyword Arguments: + **kwargs {Dict[str, str]} -- Adds new attributes to generated + script tags. + Returns: str -- The script or an empty string. config_key {str} -- Key of the configuration to use. @@ -605,8 +609,9 @@ def generate_vite_react_refresh_url(self) -> str: return "" url = self._get_dev_server_url(self.react_refresh_url) + attrs_str = attrs_to_str(kwargs) - return f"""' @@ -54,6 +63,6 @@ def stylesheet_preload(href: str) -> Tag: @staticmethod def preload(href: str, attrs: Dict[str, str]) -> Tag: - attrs_str = " ".join([f'{key}="{value}"' for key, value in attrs.items()]) + attrs_str = attrs_to_str(attrs) return f'' diff --git a/django_vite/templatetags/django_vite.py b/django_vite/templatetags/django_vite.py index f10d395..33aab81 100644 --- a/django_vite/templatetags/django_vite.py +++ b/django_vite/templatetags/django_vite.py @@ -178,13 +178,22 @@ def vite_legacy_asset( @register.simple_tag @mark_safe -def vite_react_refresh(app: str = DEFAULT_APP_NAME) -> str: +def vite_react_refresh( + app: str = DEFAULT_APP_NAME, + **kwargs: Dict[str, str], +) -> str: """ Generates the script for the Vite React Refresh for HMR. Only used in development, in production this method returns an empty string. + Keyword Arguments: + **kwargs {Dict[str, str]} -- Adds new attributes to generated + script tags. + Returns: str -- The script or an empty string. """ - return DjangoViteAssetLoader.instance().generate_vite_react_refresh_url(app) + return DjangoViteAssetLoader.instance().generate_vite_react_refresh_url( + app, **kwargs + ) diff --git a/tests/tests/templatetags/test_vite_react_refresh.py b/tests/tests/templatetags/test_vite_react_refresh.py index aa82cf6..c9058bb 100644 --- a/tests/tests/templatetags/test_vite_react_refresh.py +++ b/tests/tests/templatetags/test_vite_react_refresh.py @@ -106,3 +106,35 @@ def test_vite_react_refresh_url_setting(patch_settings): soup = BeautifulSoup(html, "html.parser") script_tag = soup.script assert "http://localhost:5173/static/foobar" in script_tag.text + + +@pytest.mark.parametrize( + "patch_settings", + [ + { + "DJANGO_VITE_DEV_MODE": True, + "DJANGO_VITE_REACT_REFRESH_URL": "foobar", + }, + { + "DJANGO_VITE": { + "default": { + "dev_mode": True, + "react_refresh_url": "foobar", + } + } + }, + ], + indirect=True, +) +def test_vite_react_refresh_uses_kwargs(patch_settings): + template = Template( + """ + {% load django_vite %} + {% vite_react_refresh nonce="woo-nonce" %} + """ + ) + html = template.render(Context({})) + soup = BeautifulSoup(html, "html.parser") + script_tag = soup.script + assert script_tag.has_attr("nonce") + assert script_tag["nonce"] == "woo-nonce" From ed074bac0aac5e2531245e0d81aa7ff2797d70a3 Mon Sep 17 00:00:00 2001 From: Niicck Date: Mon, 22 Jan 2024 11:56:43 -0600 Subject: [PATCH 2/2] add documentation for vite_react_refresh nonce --- README.md | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 31d8f1b..9ef623b 100644 --- a/README.md +++ b/README.md @@ -183,7 +183,13 @@ like the previous tag.** ``` {% vite_react_refresh %} ``` -If you're using React, this will generate the Javascript needed to support React HMR. +If you're using React, this will generate the Javascript `