2024-06-03 13:56:20 +02:00
|
|
|
|
import { t, T } from "./utils/index.js";
|
2024-05-22 21:43:49 +02:00
|
|
|
|
export const info= {
|
|
|
|
|
href: "./",
|
2024-06-03 13:56:20 +02:00
|
|
|
|
title: t`Introduction`,
|
|
|
|
|
description: t`Introducing a library.`,
|
2024-05-22 21:43:49 +02:00
|
|
|
|
};
|
2023-11-06 20:20:32 +01:00
|
|
|
|
|
2023-11-24 16:16:08 +01:00
|
|
|
|
import { el } from "deka-dom-el";
|
2024-05-22 21:43:49 +02:00
|
|
|
|
import { simplePage } from "./layout/simplePage.html.js";
|
2024-06-03 13:56:20 +02:00
|
|
|
|
import { h3 } from "./components/pageUtils.html.js";
|
2023-11-21 14:37:57 +01:00
|
|
|
|
import { example } from "./components/example.html.js";
|
2024-06-03 13:56:20 +02:00
|
|
|
|
import { code } from "./components/code.html.js";
|
|
|
|
|
/** @param {string} url */
|
|
|
|
|
const fileURL= url=> new URL(url, import.meta.url);
|
|
|
|
|
const references= {
|
2024-06-03 16:20:42 +02:00
|
|
|
|
w_mvv:{
|
|
|
|
|
title: t`Wikipedia: Model–view–viewmodel`,
|
|
|
|
|
href: "https://en.wikipedia.org/wiki/Model%E2%80%93view%E2%80%93viewmodel",
|
|
|
|
|
},
|
|
|
|
|
w_mvc: {
|
|
|
|
|
title: t`Wikipedia: Model–view–controller`,
|
|
|
|
|
href: "https://en.wikipedia.org/wiki/Model%E2%80%93view%E2%80%93controller",
|
|
|
|
|
},
|
2024-06-03 13:56:20 +02:00
|
|
|
|
};
|
2023-11-07 15:10:55 +01:00
|
|
|
|
/** @param {import("./types.d.ts").PageAttrs} attrs */
|
2023-11-10 17:15:59 +01:00
|
|
|
|
export function page({ pkg, info }){
|
2023-11-07 15:10:55 +01:00
|
|
|
|
const page_id= info.id;
|
2023-11-24 16:16:08 +01:00
|
|
|
|
return el(simplePage, { info, pkg }).append(
|
2024-06-03 13:56:20 +02:00
|
|
|
|
el("p", t`The library tries to provide pure JavaScript tool(s) to create reactive interfaces using …`),
|
|
|
|
|
el(h3, t`Event-driven programming (3 parts separation ≡ 3PS)`),
|
|
|
|
|
el("p").append(t`
|
|
|
|
|
Let's introduce the basic principle on which the library is built. We'll use the JavaScript listener as
|
|
|
|
|
a starting point.
|
|
|
|
|
`),
|
|
|
|
|
el(code, { src: fileURL("./components/examples/introducing/3ps.js"), page_id }),
|
2024-06-03 16:20:42 +02:00
|
|
|
|
el("p").append(...T`
|
|
|
|
|
As we can see, in the code at location “A” we define ${el("em", t`how to react`)} when the function
|
|
|
|
|
is called with any event as an argument. At that moment, we ${el("em", t`don't care who/why/how`)}
|
|
|
|
|
the function was called. Similarly, at point “B”, we reference to a function to be called on the event
|
|
|
|
|
${el("em", t`without caring`)} what the function will do at that time. Finally, at point “C”, we tell
|
|
|
|
|
the application that a change has occurred, in the input, and we ${el("em", t`don't care if/how someone`)}
|
|
|
|
|
is listening for the event.
|
2024-06-03 13:56:20 +02:00
|
|
|
|
`),
|
2024-06-03 16:20:42 +02:00
|
|
|
|
el(example, { src: fileURL("./components/examples/introducing/helloWorld.js"), page_id }),
|
2024-06-03 13:56:20 +02:00
|
|
|
|
el("p").append(...T`
|
2024-06-03 16:20:42 +02:00
|
|
|
|
The library introduces a new “type” of variable/constant called ${el("em", t`signal`)} allowing us to
|
|
|
|
|
to use introduced 3PS pattern in our applications. As you can see it in the example above.
|
2024-06-03 13:56:20 +02:00
|
|
|
|
`),
|
|
|
|
|
el("p").append(...T`
|
2024-06-03 16:20:42 +02:00
|
|
|
|
Also please notice that there is very similar 3PS pattern used for separate creation of UI and business logic.
|
2024-06-03 13:56:20 +02:00
|
|
|
|
`),
|
|
|
|
|
el("p").append(...T`
|
2024-06-03 16:20:42 +02:00
|
|
|
|
The 3PS is very simplified definition of the pattern. There are more deep/academic definitions more precisely
|
|
|
|
|
describe usage in specific situations, see for example ${el("a", { textContent: t`MVVM`, ...references.w_mvv })}
|
|
|
|
|
or ${el("a", { textContent: t`MVC`, ...references.w_mvc })}.
|
2024-06-03 13:56:20 +02:00
|
|
|
|
`),
|
2024-06-03 16:20:42 +02:00
|
|
|
|
el(h3, t`Organization of the documentation`),
|
2023-09-26 16:02:10 +02:00
|
|
|
|
);
|
|
|
|
|
}
|