Welcome the channel on the development of Cro, a set of libraries for building reactive distributed systems, lovingly crafted to take advantage of all the Raku Programming Language has to offer (cro.services). This channel is being logged for historical purposes.
Set by lizmat on 24 May 2021.
00:32 summerisle_ left 00:33 summerisle joined 01:36 Pe_Elle joined 01:50 Pe_Elle left 02:05 Pe_Elle joined 02:23 Pe_Elle left 02:39 Pe_Elle joined
SmokeMachine would someone like to also play with components using Cro and Red? github.com/FCO/SmallComponentTest/...nt-test.p6 03:08
03:41 Pe_Elle left 03:51 Pe_Elle joined 04:05 librasteve_ left 04:54 Pe_Elle left 05:05 japhb left 05:07 Pe_Elle joined 05:09 japhb joined 06:10 Pe_Elle left 06:24 Pe_Elle joined 07:26 Pe_Elle left 07:33 Pe_Elle joined 07:57 guifa left 07:59 guifa joined 08:35 Pe_Elle left 08:40 guifa left 08:49 Pe_Elle joined 09:59 sena_kun joined 10:22 Pe_Elle left 10:33 Pe_Elle joined
librasteve SmokeMachine: I am replying on this channel since it is less noisy (yet) than the main raku-irc 10:43
thanks for the opportunity to take a look at your small component test, which, it seems to me is a quick "working sketch" of how you see HTML::Component going (?) 10:44
it is very useful to help shape my ideas in this area to see how much Red can do in the Model arena - so in fact I think my "ideal" Cro WebApp will be built in Red (even though jnthn has been going in the Django direction with the Cro / data modelling work - which has the advantage of incremental schema changes btw) - so this means my opinion right now is to enjoy the simplicity of Red at the potential cost of 10:48
having to work out how to do data upgrades and migration later (which you may already have, but I haven't looked closely enough)
OK - that said, my model of "how to do web in raku right" is currently lurking here github.com/librasteve/raku-HTMX-Ex...te.rakumod ... this is very very early design thoughts and some things here are missing such as the render method will be a multi that you can pass a body as Str or a Callable since HTML stuff is usually assembled the same way as a CroTmp macro 10:55
there is quite of lot of weird stuff going on in my head like "I think that the layout and style aspects of CSS should be specified via separate chains of roles does" so if that is too odd for you then I fully understand 10:57
so - the core points are that a Component (here called an Island) is like this:
class Island does Render { has Style $.style; has Layout $.layout; has Content $.content; has Model $.model; has Routes $.routes; } 10:58
so your model stuff fits right in here
must hop will take a deeper look later
11:36 Pe_Elle left 11:50 Pe_Elle joined
SmokeMachine librasteve: I think I’ll need some time to understand what you wrote. But about DB migrations, we plan to bring that to Red too… if you’d like to help on the discussion of how: github.com/FCO/Red/issues/15 (I also have done a presentation on Vegas trying to explain the plan and get help… but I wasn’t very able to explain that neither to grab people’s attention… (I think that was my worst presentation)) 12:06
12:51 Pe_Elle left 12:59 Pe_Elle joined 14:01 Pe_Elle left 14:06 Pe_Elle joined 14:14 guifa joined 14:57 Pe_Elle_ joined 15:00 Pe_Elle left 15:10 Pe_Elle_ left 15:33 Pe_Elle joined
librasteve good - sorry this is very early in my thought process ... that said, I think that your HTML::Component can fit well into my roles and so on ... if we can agree a common API ... since the business end of a component is the HTML / CSS / JS that it produces, I think that the API could be as simple as: 16:06
subset Html of Str; subset Css of Str; subset Js of Str; class Content { has Html $.html is required; has Css $.css; has Js $.js; } subset BodyCall of Callable; #<== returns Content object (not sure how to specify that) role HTML::Component::API { #| the render multi method takes a body (Str or Callable) multi method render(Content $ -> Content) { ... } multi method render(BodyCall $ -> 16:18
Content) { ... } } class HTML::Component does HTML::COmponent::API { ... #your simple code example would go here }
sooo _ I think the only thing this needs you to change is to rename your method Str to multi method render and to be prepared for it to take a Content body and, at minimum "pass through" the CSS and JS pieces provided (if any). 16:28
(apologies if this is scrambled on the IRC side!)
SmokeMachine Sorry, why would render (that if that’s something that need to be implemented by every component, I think it would more sense to be called RENDER) would receive anything? Shouldn’t it use only data from the component itself? 16:35
16:37 Pe_Elle left
librasteve good question 16:38
The idea of an Island is that it is an independent piece of web functionality that may have its own modek, views, routes and so on - think of a shopping cart maybe. Unlike a contiguous piece of HTML, 16:41
(oops hit return too early)
In this example you may have a small "icon" view that appears on every page (where the number of items is dynamically set bu the model), a box (maybe a modal) that pops up when you are on a product page and then some full page views that step through the payment and delivery. 16:43
Thinking of the icon, maybe that sits in something like <head><nav><ul><li>...</li><li><span id="icon"></span></li></ul></nav></head> 16:45
so in my early thinking, we want a systematic way to collect HTML so that ALL we need to do is specify <span id="icon"></> and that our shopping cart Component provides this when we ask it for the icon view. So the idea is that Components can be Nodes in a tree and that in this case we have a three levels of the tree - Head, Nav and Cart - so I am proposing that render of Head allows Nav to be passed in as its body 16:49
and that render of Nav allows Cart to be passed in as its body.
16:51 Pe_Elle joined
so in a simple HTML::Component - all it MUST do is return some HTML, but it MAY also take a body to allow it to be a participant in a wider framework ... as I have said this is very poorly thought throught so far and needs some time to do a proper design and prototype. 16:54
this is the purpose of a Cro Template macro cro.raku.org/docs/reference/cro-we...tax#Macros 16:55
also
SmokeMachine But in case of the component, shouldn’t the data used on the component be passed to it in construction time, and render only user the obj’s data to prepare the html? 16:58
librasteve SM: you have some excellent questions ... sorry to duck them but I am embarrassed how poorly thought out my ideas are ... and I am on a deadline to write my advent post ... can I suggest that we aim to do a prototype collaboratively. I think I need to spend a couple of days getting my ideas straight (as well as day job) so can revert back hopefully with my ducks in a row around the middle of the week 17:04
SmokeMachine I mean, you can crease that icon as an object (Icon.new: :src</bla/ble.jpg>) and pass that to shopping cart (or the tree), and the render of that tree would be to just visit every node and call it’s render. Each component could have its own children… 17:05
Sure! Sorry for keep interrupting you
librasteve no problem - its really an interesting problem and (with HTMX and Cro) I think we have a great opportunity to define best practice - ;-) 17:06
so I cant resist the interruptions ... 17:07
I suppose the call sequence is Site => Page => Head => Nav => Cart ... in each case the parent is a node in the tree with children (although Head and Nav is reused in most Pages) and can aggregate the HTML / CSS / JS back up ... so I think you are right that you can just call Project.new.render and get a new site dir back 17:13
17:45 guifa left 17:54 Pe_Elle left 18:08 Pe_Elle joined
SmokeMachine in my todo example, the todo objects already are a kind of island... when you click on the checkbox it calls the toggle method (on the server) and it rerenders only the affected todo comoponent... 18:29
19:22 Pe_Elle left 19:37 Pe_Elle joined 20:42 Pe_Elle left 20:56 Pe_Elle joined 21:17 Pe_Elle left 21:27 Pe_Elle joined 22:29 sena_kun left 22:30 Pe_Elle left 22:44 Pe_Elle joined 23:20 summerisle is now known as eof 23:47 Pe_Elle left 23:57 Pe_Elle joined