util ¤
Modules:
cache ¤
Functions:
-
lazy_cache
–Decorator that caches the given function similarly to
functools.lru_cache
.
lazy_cache ¤
Decorator that caches the given function similarly to functools.lru_cache
. But the cache is instantiated only at first invocation.
cache
argument is a function that generates the cache function, e.g. functools.lru_cache()
.
Source code in src/django_components/util/cache.py
html ¤
Functions:
-
parse_document_or_nodes
–Use this if you do NOT know whether the given HTML is a full document
-
parse_multiroot_html
–Use this when you know the given HTML is a multiple nodes like
-
parse_node
–Use this when you know the given HTML is a single node like
parse_document_or_nodes ¤
Use this if you do NOT know whether the given HTML is a full document with <html>
, <head>
, and <body>
tags, or an HTML fragment.
Source code in src/django_components/util/html.py
parse_multiroot_html ¤
Use this when you know the given HTML is a multiple nodes like
<div> Hi </div> <span> Hello </span>
Source code in src/django_components/util/html.py
parse_node ¤
parse_node(html: str) -> LexborNode
Use this when you know the given HTML is a single node like
<div> Hi </div>
Source code in src/django_components/util/html.py
loader ¤
Classes:
-
ComponentFileEntry
–Result returned by
get_component_files()
.
Functions:
-
get_component_dirs
–Get directories that may contain component files.
-
get_component_files
–Search for files within the component directories (as defined in
ComponentFileEntry ¤
get_component_dirs ¤
Get directories that may contain component files.
This is the heart of all features that deal with filesystem and file lookup. Autodiscovery, Django template resolution, static file resolution - They all use this.
Parameters:
-
include_apps
(bool
, default:True
) –Include directories from installed Django apps. Defaults to
True
.
Returns:
get_component_dirs()
searches for dirs set in COMPONENTS.dirs
settings. If none set, defaults to searching for a "components"
app.
In addition to that, also all installed Django apps are checked whether they contain directories as set in COMPONENTS.app_dirs
(e.g. [app]/components
).
Notes:
-
Paths that do not point to directories are ignored.
-
BASE_DIR
setting is required. -
The paths in
COMPONENTS.dirs
must be absolute paths.
Source code in src/django_components/util/loader.py
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 |
|
get_component_files ¤
get_component_files(suffix: Optional[str] = None) -> List[ComponentFileEntry]
Search for files within the component directories (as defined in get_component_dirs()
).
Requires BASE_DIR
setting to be set.
Parameters:
-
suffix
(Optional[str]
, default:None
) –The suffix to search for. E.g.
.py
,.js
,.css
. Defaults toNone
, which will search for all files.
Returns:
-
List[ComponentFileEntry]
–List[ComponentFileEntry] A list of entries that contain both the filesystem path and the python import path (dot path).
Example:
Source code in src/django_components/util/loader.py
122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 |
|
logger ¤
Functions:
-
trace
–TRACE level logger.
-
trace_msg
–TRACE level logger with opinionated format for tracing interaction of components,
trace ¤
TRACE level logger.
To display TRACE logs, set the logging level to 5.
Example:
LOGGING = {
"version": 1,
"disable_existing_loggers": False,
"handlers": {
"console": {
"class": "logging.StreamHandler",
"stream": sys.stdout,
},
},
"loggers": {
"django_components": {
"level": 5,
"handlers": ["console"],
},
},
}
Source code in src/django_components/util/logger.py
trace_msg ¤
trace_msg(
action: Literal["PARSE", "RENDR", "GET", "SET"],
node_type: Literal["COMP", "FILL", "SLOT", "PROVIDE", "N/A"],
node_name: str,
node_id: str,
msg: str = "",
component_id: Optional[str] = None,
) -> None
TRACE level logger with opinionated format for tracing interaction of components, nodes, and slots. Formats messages like so:
"ASSOC SLOT test_slot ID 0088 TO COMP 0087"
Source code in src/django_components/util/logger.py
misc ¤
Functions:
-
gen_id
–Generate a unique ID that can be associated with a Node
-
get_import_path
–Get the full import path for a class or a function, e.g.
"path.to.MyClass"
gen_id ¤
gen_id() -> str
Generate a unique ID that can be associated with a Node
Source code in src/django_components/util/misc.py
get_import_path ¤
Get the full import path for a class or a function, e.g. "path.to.MyClass"
Source code in src/django_components/util/misc.py
tag_parser ¤
types ¤
Classes:
-
EmptyDict
–TypedDict with no members.
Attributes:
-
EmptyTuple
–Tuple with no members.
EmptyTuple module-attribute
¤
EmptyTuple = Tuple[]
Tuple with no members.
You can use this to define a Component that accepts NO positional arguments:
from django_components import Component, EmptyTuple
class Table(Component(EmptyTuple, Any, Any, Any, Any, Any))
...
After that, when you call Component.render()
or Component.render_to_response()
, the args
parameter will raise type error if args
is anything else than an empty tuple.
Omitting args
is also fine:
Other values are not allowed. This will raise an error with MyPy:
EmptyDict ¤
Bases: TypedDict
TypedDict with no members.
You can use this to define a Component that accepts NO kwargs, or NO slots, or returns NO data from Component.get_context_data()
/ Component.get_js_data()
/ Component.get_css_data()
:
Accepts NO kwargs:
from django_components import Component, EmptyDict
class Table(Component(Any, EmptyDict, Any, Any, Any, Any))
...
Accepts NO slots:
from django_components import Component, EmptyDict
class Table(Component(Any, Any, EmptyDict, Any, Any, Any))
...
Returns NO data from get_context_data()
:
from django_components import Component, EmptyDict
class Table(Component(Any, Any, Any, EmptyDict, Any, Any))
...
Going back to the example with NO kwargs, when you then call Component.render()
or Component.render_to_response()
, the kwargs
parameter will raise type error if kwargs
is anything else than an empty dict.
Omitting kwargs
is also fine:
Other values are not allowed. This will raise an error with MyPy: