-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathabout.html
More file actions
384 lines (318 loc) · 21.9 KB
/
about.html
File metadata and controls
384 lines (318 loc) · 21.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
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
111
112
113
114
115
116
117
118
119
120
121
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
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
<!DOCTYPE html><html><head><title>Modulo</title>
<meta charset="utf8">
<style>
x-TwoPanes {
max-width: 1000px;
margin: auto;
display: block;
}
x-TwoPanes h1 {
font-size: 4.5rem;
color: var(--color-fg-semidark);
text-align: center;
margin-top: 60px;
padding: 5px;
margin-right: 10px;
font-family: serif;
font-weight: 400;
background: linear-gradient(to right, #00000000 0%, #00000000 25%, var(--color-content-bg) 25.00001%, var(--color-content-bg) 75%, #00000000 75.00001%, #00000000 100%), linear-gradient(to bottom, var(--color-content-bg) 0%, var(--color-content-bg) 49%, var(--color-fg) 49.00001%, var(--color-fg) 51%, var(--color-content-bg) 51.00001%, var(--color-content-bg) 100%);
}
x-TwoPanes strong {
color: var(--color)
}
x-TwoPanes h3 span {
font-size: 100px;
color: var(--color);
font-weight: 100;
}
x-TwoPanes .pane {
display: block;
border: 1px solid var(--fg);
margin: 10px;
min-width: 200px;
padding: 10px;
}
x-TwoPanes section {
display: flex;
padding: 10px;
width: 100%;
justify-content: space-between;
}
</style>
<meta name="charset" charset="utf8" id="include_xxm0qoac"><meta name="content-type" http-equiv="Content-Type" content="text/html; charset=utf-8" id="include_xxnd8o0e"><meta name="viewport" content="width=device-width, initial-scale=1" id="include_x13l7u56"><meta name="robots" content="index, follow" id="include_xxriq75n"><meta name="revisit-after" content="30 days" id="include_x1m4jm9p"><link rel="stylesheet" href="build-xxnc164u.css">
<script defer="" src="build-xxx7rgps.js"></script>
</head><body>
<nav class="page-nav x_Page">
<ul class="x_Page">
<li class="x_Page"><a class="nav-link--modulo x_Page" href="index.html" title=" Modulo"> ᵐ°dᵘ⁄o</a></li>
<li class="x_Page"><a href="docs/index.html" class="x_Page"> Docs</a></li>
<li class="x_Page"><a href="playground.html" class="x_Page"> Playground</a></li>
<li class="x_Page"><a href="about.html" class="x_Page"> About</a></li>
<li class="x_Page"><a style="border:none" href="https://codeberg.org/modulo/modulo/" class="x_Page">Source (Git)</a></li>
<li class="x_Page"><a style="border:none" href="https://www.npmjs.com/package/create-modulo" class="x_Page">create-modulo (npmjs)</a></li>
<li style="margin-left: auto" class="x_Page">
<a style="padding:3px;" href="https://modu.lol/Modulo.html" download="Modulo.html" class="x_Page">↓ Modulo.html</a>
<textarea title="Run this command in a terminal to start a new Modulo project" style="background:var(--bg);color:var(--fg);border:none;width:200px;resize:none;font-size:18px;height: 25px" readonly="">npm init modulo</textarea>
</li>
<li class="x_Page">
<x-pagecontrols modulo-mount-html=""><div style="text-align: right; margin-top: 15px">
<input id="theme_id_slider" style="width: 80px" type="range" min="1" max="3" step="1" value="1" name="themenum">
</div>
<div class="page-toolbar" style="display: flex">
<label for="theme_id_slider"><span style="font-size:20px;font-family:monospace"><span title="Default">◐ </span><span title="Invert"> ◑ </span><span title="Custom"> ✱</span></span></label>
</div></x-pagecontrols>
</li>
</ul>
</nav>
<a class="a-hamburger x_Page" href="#">☰</a>
<slot class="">
<x-twopanes>
<h1>Modulo.html</h1>
<h2 style="color: var(--color-fg-semidark)">The Declarative HTML Web Component Framework</h2>
<ul>
<li>Beginner-friendly features inspired by Next.js, Svelte, React, and Vue.js</li>
<li>Only 2000 lines of dependency-free, self-building JavaScript</li>
<li>A “no fuss” drop-in for existing web apps or Jamstack static sites</li>
</ul>
</x-twopanes>
<x-twopanes>
<x-abstractart3d modulo-mount-html="">
<svg style="undefined" width="190.3mm" height="74.26mm" viewBox="0 0 190.3 74.26" version="1.1" xmlns="http://www.w3.org/2000/svg">
<svg xmlns="http://www.w3.org/2000/svg">
<g transform="translate(.2601 -55.68)" stroke="#000" stroke-dashoffset="39.68">
<g stroke-linecap="square">
<path d="m44.65 98.63a8.035 8.035 0 0 1-10.98 2.941 8.035 8.035 0 0 1-2.941-10.98 8.035 8.035 0 0 1 10.98-2.941 8.035 8.035 0 0 1 2.941 10.98z" fill="#b90183" stroke-linejoin="bevel" stroke-width=".8035" style="paint-order:stroke fill markers"></path>
<g transform="matrix(.4922 .2842 -.2842 .4922 29.72 24.73)" fill="#fff" fill-rule="evenodd" stroke-linejoin="round" style="paint-order:stroke fill markers">
<path d="m87.07 88.66 10.35-7.293v13.22l-10.35 5.891z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16v12.88l10.98 4.438v-11.82z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16 9.958-8.748 11.37 6.95-10.35 7.293z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 96.04 9.958-7.066 11.37 5.614-10.35 5.891z" style="paint-order:stroke fill markers"></path>
<path d="m86.05 74.42v14.56l11.37 5.614v-13.22z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16 9.958-8.748v14.56l-9.958 7.066z" style="paint-order:stroke fill markers"></path>
</g>
<path d="m62.66 96.22a8.405 8.405 45 0 1-11.48 3.077 8.405 8.405 45 0 1-3.077-11.48 8.405 8.405 45 0 1 11.48-3.077 8.405 8.405 45 0 1 3.077 11.48z" fill="#b90183" stroke-linejoin="bevel" stroke-width=".7389" style="paint-order:stroke fill markers"></path>
</g>
<g transform="matrix(.4922 .2842 -.2842 .4922 29.72 24.73)" fill="#fff" fill-rule="evenodd" stroke-linecap="round" stroke-linejoin="bevel" stroke-width="1.5" style="paint-order:stroke fill markers">
<path d="m112.5 71.22 15.7-10.69v19.38l-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17v18.87l16.66 6.505v-17.32z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82 17.25 10.19-15.7 10.69z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 82.04 15.11-10.36 17.25 8.227-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m110.9 50.34v21.34l17.25 8.227v-19.38z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82v21.34l-15.11 10.36z" style="paint-order:stroke fill markers"></path>
</g>
<g stroke-linecap="square">
<path d="m84.18 96.05a10.66 10.65 30 0 1-14.56 3.897 10.66 10.65 30 0 1-3.905-14.56 10.66 10.65 30 0 1 14.56-3.897 10.66 10.65 30 0 1 3.905 14.56z" fill="#b90183" stroke-linejoin="bevel" stroke-width="1.066" style="paint-order:stroke fill markers"></path>
<g transform="matrix(.9415 .5436 -.5433 .941 52.9 -41.09)" fill="#fff" fill-rule="evenodd" stroke-linejoin="round" style="paint-order:stroke fill markers">
<path d="m87.07 88.66 10.35-7.293v13.22l-10.35 5.891z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16v12.88l10.98 4.438v-11.82z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16 9.958-8.748 11.37 6.95-10.35 7.293z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 96.04 9.958-7.066 11.37 5.614-10.35 5.891z" style="paint-order:stroke fill markers"></path>
<path d="m86.05 74.42v14.56l11.37 5.614v-13.22z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16 9.958-8.748v14.56l-9.958 7.066z" style="paint-order:stroke fill markers"></path>
</g>
<path d="m115.9 95.61a16.08 16.07 30 0 1-21.96 5.877 16.08 16.07 30 0 1-5.89-21.96 16.08 16.07 30 0 1 21.96-5.877 16.08 16.07 30 0 1 5.89 21.96z" fill="#b90183" stroke-linejoin="bevel" stroke-width="1.413" style="paint-order:stroke fill markers"></path>
</g>
<g stroke-linejoin="bevel">
<g transform="matrix(.9415 .5436 -.5433 .941 52.9 -41.09)" fill="#fff" fill-rule="evenodd" stroke-linecap="round" stroke-width="1.5" style="paint-order:stroke fill markers">
<path d="m112.5 71.22 15.7-10.69v19.38l-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17v18.87l16.66 6.505v-17.32z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82 17.25 10.19-15.7 10.69z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 82.04 15.11-10.36 17.25 8.227-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m110.9 50.34v21.34l17.25 8.227v-19.38z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82v21.34l-15.11 10.36z" style="paint-order:stroke fill markers"></path>
</g>
<path d="m155.2 96.5a22.01 21.99 30 0 1-30.05 8.044 22.01 21.99 30 0 1-8.061-30.05 22.01 21.99 30 0 1 30.05-8.044 22.01 21.99 30 0 1 8.061 30.05z" fill="#b90183" stroke-linecap="square" stroke-width="1.934" style="paint-order:stroke fill markers"></path>
<g transform="matrix(1.289 .744 -.7436 1.288 68.92 -90.6)" fill="#fff" fill-rule="evenodd" stroke-linecap="round" stroke-width="1.5" style="paint-order:stroke fill markers">
<path d="m112.5 71.22 15.7-10.69v19.38l-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17v18.87l16.66 6.505v-17.32z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82 17.25 10.19-15.7 10.69z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 82.04 15.11-10.36 17.25 8.227-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m110.9 50.34v21.34l17.25 8.227v-19.38z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82v21.34l-15.11 10.36z" style="paint-order:stroke fill markers"></path>
</g>
</g>
<g transform="matrix(.4922 .2842 .2842 -.4922 -62.37 183.6)">
<g transform="matrix(.9341 0 0 .9341 6.477 126.3)" fill="#fff" fill-rule="evenodd" stroke-linecap="square" stroke-linejoin="round" style="paint-order:stroke fill markers">
<path d="m87.07 88.66 10.35-7.293v13.22l-10.35 5.891z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16v12.88l10.98 4.438v-11.82z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16 9.958-8.748 11.37 6.95-10.35 7.293z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 96.04 9.958-7.066 11.37 5.614-10.35 5.891z" style="paint-order:stroke fill markers"></path>
<path d="m86.05 74.42v14.56l11.37 5.614v-13.22z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16 9.958-8.748v14.56l-9.958 7.066z" style="paint-order:stroke fill markers"></path>
</g>
<path d="m112.1 201a13.81 13.81 0 0 1-13.81 13.81 13.81 13.81 0 0 1-13.81-13.81 13.81 13.81 0 0 1 13.81-13.81 13.81 13.81 0 0 1 13.81 13.81z" fill="#b90183" stroke-linecap="square" stroke-linejoin="bevel" stroke-width="1.214" style="paint-order:stroke fill markers"></path>
<g transform="matrix(.9341 0 0 .9341 6.477 126.3)" fill="#fff" fill-rule="evenodd" stroke-linecap="round" stroke-linejoin="bevel" stroke-width="1.5" style="paint-order:stroke fill markers">
<path d="m112.5 71.22 15.7-10.69v19.38l-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17v18.87l16.66 6.505v-17.32z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82 17.25 10.19-15.7 10.69z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 82.04 15.11-10.36 17.25 8.227-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m110.9 50.34v21.34l17.25 8.227v-19.38z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82v21.34l-15.11 10.36z" style="paint-order:stroke fill markers"></path>
</g>
<g transform="matrix(-.9341 0 0 -.9341 139.4 321)" fill="#fff" fill-rule="evenodd" stroke-linecap="square" stroke-linejoin="round" style="paint-order:stroke fill markers">
<path d="m87.07 88.66 10.35-7.293v13.22l-10.35 5.891z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16v12.88l10.98 4.438v-11.82z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16 9.958-8.748 11.37 6.95-10.35 7.293z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 96.04 9.958-7.066 11.37 5.614-10.35 5.891z" style="paint-order:stroke fill markers"></path>
<path d="m86.05 74.42v14.56l11.37 5.614v-13.22z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16 9.958-8.748v14.56l-9.958 7.066z" style="paint-order:stroke fill markers"></path>
</g>
<path d="m33.76 246.3a13.81 13.81 0 0 1 13.81-13.81 13.81 13.81 0 0 1 13.81 13.81 13.81 13.81 0 0 1-13.81 13.81 13.81 13.81 0 0 1-13.81-13.81z" fill="#b90183" stroke-linecap="square" stroke-linejoin="bevel" stroke-width="1.214" style="paint-order:stroke fill markers"></path>
<g transform="matrix(-.9341 0 0 -.9341 139.4 321)" fill="#fff" fill-rule="evenodd" stroke-linecap="round" stroke-linejoin="bevel" stroke-width="1.5" style="paint-order:stroke fill markers">
<path d="m112.5 71.22 15.7-10.69v19.38l-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17v18.87l16.66 6.505v-17.32z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82 17.25 10.19-15.7 10.69z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 82.04 15.11-10.36 17.25 8.227-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m110.9 50.34v21.34l17.25 8.227v-19.38z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82v21.34l-15.11 10.36z" style="paint-order:stroke fill markers"></path>
</g>
<g transform="matrix(-.9341 0 0 .9341 138.5 130.7)" fill="#fff" fill-rule="evenodd" stroke-linecap="square" stroke-linejoin="round" style="paint-order:stroke fill markers">
<path d="m87.07 88.66 10.35-7.293v13.22l-10.35 5.891z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16v12.88l10.98 4.438v-11.82z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16 9.958-8.748 11.37 6.95-10.35 7.293z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 96.04 9.958-7.066 11.37 5.614-10.35 5.891z" style="paint-order:stroke fill markers"></path>
<path d="m86.05 74.42v14.56l11.37 5.614v-13.22z" style="paint-order:stroke fill markers"></path>
<path d="m76.09 83.16 9.958-8.748v14.56l-9.958 7.066z" style="paint-order:stroke fill markers"></path>
</g>
<path d="m32.89 205.4a13.81 13.81 0 0 0 13.81 13.81 13.81 13.81 0 0 0 13.81-13.81 13.81 13.81 0 0 0-13.81-13.81 13.81 13.81 0 0 0-13.81 13.81z" fill="#b90183" stroke-linecap="square" stroke-linejoin="bevel" stroke-width="1.214" style="paint-order:stroke fill markers"></path>
<g transform="matrix(-.9341 0 0 .9341 138.5 130.7)" fill="#fff" fill-rule="evenodd" stroke-linecap="round" stroke-linejoin="bevel" stroke-width="1.5" style="paint-order:stroke fill markers">
<path d="m112.5 71.22 15.7-10.69v19.38l-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17v18.87l16.66 6.505v-17.32z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82 17.25 10.19-15.7 10.69z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 82.04 15.11-10.36 17.25 8.227-15.7 8.633z" style="paint-order:stroke fill markers"></path>
<path d="m110.9 50.34v21.34l17.25 8.227v-19.38z" style="paint-order:stroke fill markers"></path>
<path d="m95.83 63.17 15.11-12.82v21.34l-15.11 10.36z" style="paint-order:stroke fill markers"></path>
</g>
</g>
</g>
</svg>
</svg></x-abstractart3d>
<x-wordart3d text="Why use Modulo.html?" modulo-mount-html=""><h2 style="
text-shadow:
2px 2px 2px black
,0px 0px 0 black
,0px 0px 5px #00000022
,-1.5px -1.5px 0 black
,1px 1px 5px #00000022
,-3px -3px 0 #b90183
,2px 2px 5px #00000022
,-4.5px -4.5px 0 #b90183
,3px 3px 5px #00000022
,-6px -6px 0 black
,4px 4px 5px #00000022
,-7.5px -7.5px 0 #b90183
,5px 5px 5px #00000022
,-9px -9px 0 #b90183
,6px 6px 5px #00000022
,-10.5px -10.5px 0 #b90183
,7px 7px 5px #00000022
,-12px -12px 0 black
,8px 8px 5px #00000022
;
">Why use Modulo.html?</h2></x-wordart3d>
<section>
<aside class="pane">
<h3><span alt="Null set">∅</span></h3>
<h3>Fewer<br>assumptions</h3>
<!--<p><a href="/tutorial/ramping-up/part1.html">Get started now
»</a></p>-->
</aside>
<article class="pane">
<p><strong>Zero set-up</strong> - Like the "golden age" of jQuery,
just drop it into any HTML file. Unlike jQuery, that 1 file packs
in many of the creature-comforts of a modern component framework,
without any dependencies or new syntax to learn. You can even compile
to a single JS file, directly from your browser!</p>
<p><strong>A gentler learning curve</strong> - Modulo's declarative,
synchronous HTML-first approach was designed to be easier for coding
newbies to pick-up—in fact, useful components can be developed
without writing any JavaScript code!</p>
<p><strong><strike style="color: gray">Progressive Web Apps</strike>
Progressive Enhancement</strong> - Modulo makes few assumptions, and
renders components mixed with plain HTML for easier integration into
backend apps. SPA's and PWA's are fine and all, and Modulo could be
used for these as well, but what about all our existing server-side
apps in Ruby on Rails, Python, Go, or that one home-grown PHP monster
that will never go away? Sprinkle in some Modulo components to make
your "traditional" web apps
<em>shine</em>.</p>
</article>
</section>
</x-twopanes>
<x-twopanes>
<section>
<article class="pane">
<p><strong>Component Parts</strong> - Modular "Lego blocks" for
your components! Combine Script, Style, State, Props, and Templates to
make components that with these features.</p>
<p><strong>Everything is transparent and swappable</strong> -
Component Parts (CParts) are a flexible form of component middleware:
You can create custom CParts to support your backend APIs, "mix and
match" your favorite JS templating languages (e.g., JSX), or fine-tune
DOM-resolution behavior, either globally, or on a per-component basis.
Lifecycle callbacks are especially powerful, allowing you to hook your
own code into the DOM or any steps of the rendering process.</p>
<p><strong>A novel approach to component development</strong> -
Modulo's separation of component middleware development allows
JavaScript developers to write pure JS to wrap APIs, and
component developers to tie it all together with "low-code".</p>
</article>
<aside class="pane">
<h3><span alt="Sigma">Σ</span></h3>
<h3>More<br>modular</h3>
<!--<p><a href="/docs/">Read the docs »</a></p>-->
</aside>
</section>
</x-twopanes>
<x-twopanes>
<section>
<aside class="pane">
<h3><span alt="Modulo operator">%</span></h3>
<h3>Similar<br>(but simpler)</h3>
<!--<p><a href="/examples/">Play around with some examples
»</a></p>-->
</aside>
<article class="pane">
<p><strong>"It's like React or Vue"</strong> - Modulo is
"batteries-included" and uses familiar terminology. You get
encapsulated components with state management, two-way data
binding, props, computed values, smart DOM resolution, event
directives, and more. You even get a simple importing and
namespacing system, which can "self-pack" your components into a
single JS file!</p>
<p><strong>Clean & concise</strong> - The code-base of Modulo
itself is intentionally kept short & sweet: It ways in at
less than 2000 lines, (mostly) 80 char line limit, 4 spaces of
indent, and a <abbr title="Try to keep cyclomatic complexity of
functions to 3 or lower">low-complexity</abbr> imperative style.
When something goes
wrong (which it probably will since it's new), it's easier to
"<tt>git blame</tt>"
Modulo.</p>
<p><strong>A basis for whatever comes next</strong> - Writing your own
framework? Modulo's core is even smaller. Read the source code, fork
away, and swap the "batteries-included" for your own!</p>
</article>
</section>
</x-twopanes>
</slot>
<footer class="page-container x_Page" style="display: flex;">
<div>
<h2>ᵐ°dᵘ⁄o</h2>
</div>
<ul style="display:grid; grid-template-columns: 1fr 1fr; font-size: 1.1rem">
<li><a href="index.html"> Modulo</a></li>
<li><a href="docs/index.html"> Docs</a></li>
<li><a href="playground.html"> Playground</a></li>
<li><a href="about.html"> About</a></li>
<li><a href="https://codeberg.org/modulo/modulo/">Source (Git)</a></li>
<li><a href="https://www.npmjs.com/package/create-modulo">create-modulo (npmjs)</a></li>
</ul>
<div style="margin: auto 10px 10px auto; text-align: right; opacity:0.5">
<p class="x_Page">Sat Apr 18 2026 12:23:22 GMT-0700 (Pacific Daylight Time)</p>
<p class="x_Page">ᵐ°dᵘ⁄o <em>The Modulo Framework</em> © <tt title="Michael Bethencourt" class="x_Page">michaelb</tt></p>
<pre title="It is acceptable to link ('bundle') and distribute the Modulo Framework with other code as long as the LICENSE and NOTICE remains intact.">NO WARRANTEE OR IMPLIED UTILITY;
ANY MODIFICATIONS OR DERIVATIVES OF
THE MODULO FRAMEWORK MUST BE LGPLv3+</pre>
</div>
</footer></body></html>