pharo and ui again

Previous Topic Next Topic
 
classic Classic list List threaded Threaded
31 messages Options
12
Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

Sebastian Heidbrink-2
Hi Stephan, Hi All,

Joachim and I come from the same, commercial world, and we are not used
to initial problems regarding the UI we are used to huge limitations
once your models become more and more complex and custom vizualisations
are desired.

On first sight the videos and examples are tempting and give a beginner
the feeling that everythign is possible in Pharo/Squeak.
Well it definitely is and I myself are also more the "do it your self" guy.
But there are simple tasks that should not need a huge involvement to
accomplish a visualization and manipulation of a model.

I think there is most stuff out there in Pharo that is needed to built a
nice UI with Model interaction.
It took me jsut a few hours to built a nice Glamour based data model
browser.
So why do I struggle to built a login view?!
I think this is because Glamour is its own example.... It is implemented
in one way and there are few distractions.
GTSpotter is already too difficult to understand again....

What Pharo needs and I do not think that this is a too huge task is.
A clear destiction of M, V and C accomplished by ClassNamingConvertions
and package sub-division of these.
A browser that just lists all the available basic morphs and their examples
A sushi store demo according to the current Pharo release.
A clear documentation what, Spec, Polymorph, Morphic,... are
representing and on which "layer" they are positioned. OS-Layer,
Common-Layer, Layout-Layer, Event-Layer.

Based on first steps experiance with Seaside I can still remember that
the only reason why I was able to get started fast and even during the
early days of Seaside were the two examples, Scriptacoulous demo site
and the Sushi Store.
With the help of those I even learnt some CSS and JS ...
The jQuery example was already to much limited to the usage of jQuery
and it was much more difficult to use the exampel site as an example to
go on with an own project.

How much time would it cost to implement a small sushi store with in
image persitsancy?
Also,.... a documentation on how to deplay this store and make a real
Pharo app.

I think such a demo would also show the community how huge a impact a
new Pharo release does to a commercial product.
A steady update from release to release would be useful as a pharo
version migration guide.
It could also start a discussion on how to do things and show each of us
where things are unclear and under specified.

We should take what we have and put an example together instead of
thinking/discussing what kind of framework might be best or better.
There are so many books an Smalltalk patterns, MVC,.... but there are
actually no real official examples available

Stephan! Thank you so much for starting this!
I will have a look asap.
Right now I am more focused on the local Software group.
I would like to have some application "WITH UI" and even 3D where I can
show off live programming!

I admire the energy the community and the board puts into Pharo and I
can only imagine how difficult it must be to find and lead into a
certain direction.
  Thank you!

So and now her eis the question that I think needs to be discussed since
it is the most controversial answered to me.
"Spec or not to Spec?"

I am kidding!
But my current counter is 5 for Spec and 5 against Spec.
I think some rason could be that Spec is misunderstood, or still under
development/inmature.
I can't tell, but  a beginner wants to know:
"WHAT AM I SUPPOSED TO DO!?"

Thanks for reading!
Sebastian






Am 12.02.2015 um 07:22 schrieb Stephan Eggermont:

> Sebastian wrote:
>> After 5 days I can tell ,that I am lost in Morphic, UIManager, Traits/No-Traits, Spec, GLMMorphic, Poly....
>> And sometimes things are even mixed up and I am not able to decide which approach to follow,...
> If your goal is a "Maya Editor"-like UI, I've put together something that could be useful as
> a starting point. I would be interested in how to encapsulate this in Spec, and in what should
> change in Bloc. The idea is to grow it into a tutorial.
>
> http://smalltalkhub.com/#!/~StephanEggermont/MorphicDraw
>
> Stephan
>
>
>
>
>
>
>


Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

Sven Van Caekenberghe-2
In reply to this post by pdigonzelli1
They are not yet public but soon will be.

> On 12 Feb 2015, at 17:09, Pablo R. Digonzelli <[hidden email]> wrote:
>
> where can i watch it?
>
> Pablo
>
> ----- Mensaje original -----
> De: "Sven Van Caekenberghe" <[hidden email]>
> Para: [hidden email], "Any question about pharo is welcome" <[hidden email]>
> Enviados: Jueves, 12 de Febrero 2015 3:29:42
> Asunto: Re: [Pharo-users] pharo and ui again
>
>> On 12 Feb 2015, at 00:46, Nicolai Hess <[hidden email]> wrote:
>>
>> But much howtos or tutorials widely scattered and aren't up to date.
>
> Johan Fabry's talk at the Pharo Days was an excellent introduction to Spec, watch it.
>


Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

Sven Van Caekenberghe-2
In reply to this post by jfabry
BTW, Johan, I cannot find your slides in http://www.slideshare.net/pharoproject/presentations ?

> On 12 Feb 2015, at 13:45, Johan Fabry <[hidden email]> wrote:
>
>
>> On Feb 12, 2015, at 07:29, Sven Van Caekenberghe <[hidden email]> wrote:
>>
>>
>>> On 12 Feb 2015, at 00:46, Nicolai Hess <[hidden email]> wrote:
>>>
>>> But much howtos or tutorials widely scattered and aren't up to date.
>>
>> Johan Fabry's talk at the Pharo Days was an excellent introduction to Spec, watch it.
>
>
> Well, thank you very much for the recommendation :-). Are the videos of the talks online? I did not see an announcement for that, and I’d like to see some of the talks I missed on Friday due to being stuck in the Douai snow ...
>
>
> ---> Save our in-boxes! http://emailcharter.org <---
>
> Johan Fabry   -   http://pleiad.cl/~jfabry
> PLEIAD lab  -  Computer Science Department (DCC)  -  University of Chile
>
>


Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

Marcus Denker-4

> On 12 Feb 2015, at 17:53, Sven Van Caekenberghe <[hidden email]> wrote:
>
> BTW, Johan, I cannot find your slides in http://www.slideshare.net/pharoproject/presentations ?
>
I have the .key files.. I will double check and upload the missings…


>> On 12 Feb 2015, at 13:45, Johan Fabry <[hidden email]> wrote:
>>
>>
>>> On Feb 12, 2015, at 07:29, Sven Van Caekenberghe <[hidden email]> wrote:
>>>
>>>
>>>> On 12 Feb 2015, at 00:46, Nicolai Hess <[hidden email]> wrote:
>>>>
>>>> But much howtos or tutorials widely scattered and aren't up to date.
>>>
>>> Johan Fabry's talk at the Pharo Days was an excellent introduction to Spec, watch it.
>>
>>
>> Well, thank you very much for the recommendation :-). Are the videos of the talks online? I did not see an announcement for that, and I’d like to see some of the talks I missed on Friday due to being stuck in the Douai snow ...
>>
>>
>> ---> Save our in-boxes! http://emailcharter.org <---
>>
>> Johan Fabry   -   http://pleiad.cl/~jfabry
>> PLEIAD lab  -  Computer Science Department (DCC)  -  University of Chile
>>
>>
>
>


Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

Ben Coman
In reply to this post by Sven Van Caekenberghe-2
About the architecture of Spec, as I understand it, Spec is a layer on top of Morphic, written such that later Morphic could be swapped out from under it and something else sued in place of Morphic.
Now could their possibly be some common widget-models sitting underneath Spec, Morpi, MVC or any other new system ?
cheers -ben

On Fri, Feb 13, 2015 at 12:37 AM, Sven Van Caekenberghe <[hidden email]> wrote:
They are not yet public but soon will be.

> On 12 Feb 2015, at 17:09, Pablo R. Digonzelli <[hidden email]> wrote:
>
> where can i watch it?
>
> Pablo
>
> ----- Mensaje original -----
> De: "Sven Van Caekenberghe" <[hidden email]>
> Para: [hidden email], "Any question about pharo is welcome" <[hidden email]>
> Enviados: Jueves, 12 de Febrero 2015 3:29:42
> Asunto: Re: [Pharo-users] pharo and ui again
>
>> On 12 Feb 2015, at 00:46, Nicolai Hess <[hidden email]> wrote:
>>
>> But much howtos or tutorials widely scattered and aren't up to date.
>
> Johan Fabry's talk at the Pharo Days was an excellent introduction to Spec, watch it.
>



Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

jfabry
In reply to this post by kilon.alios

Kilon, your second paragraph can be understood as a description of Spec. There is a low level code and an extensions API, and ALL widgets are implemented as such extensions and you can assemble a GUI framework. What you propose as your ideal solution is reimplementing this wheel all over again.

In the end, you never clearly stated why you don’t like Spec. I mean, beyond the questions that I provided you an answer for some time ago. So please, instead of saying ‘I don’t like X’ clarify exactly what it is that you don’t like and why. Otherwise there will never be advances and it’s annoying to hear the same vague complaints all over again ...

On Feb 12, 2015, at 15:28, kilon alios <[hidden email]> wrote:

Frankly big libraries dont make much sense for me when it comes to Pharo. Sure if we were talking about Python I would say yes. I do believe however that Pharo makes it already very easy to combine libraries together. 

So for me the ideal solution would be a very low level core that comes with very well documented extensions API and then widgets are implemented as third party extensions that will allow you to assemble a GUI framework tailor made to your own needs. Unfortunately making such a complex core will require quite some effort . So my idea is not without its own problems. 

So I would have to say no , I dont agree,  at least I think we imagine very different things.

The goal of Spec may not be to replace Morphic but then the goal of the human race was not to go to the moon until one day scientists told us its possible. The same can happen with Spec, keep improving it , extending it and people will keep using it more and more in place of Morphic even if Spec still keeps relying in Morphic.   Afterall its not difficult to imagine Spec one day in the distant future coming with its own backend. None can predict the future afterall, even if you invent it (sorry Alan). But then this what makes future so exciting , its unpredictable nature. 

---> Save our in-boxes! http://emailcharter.org <---

Johan Fabry   -   http://pleiad.cl/~jfabry
PLEIAD lab  -  Computer Science Department (DCC)  -  University of Chile

Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

jfabry
In reply to this post by Marcus Denker-4

In any case, my slides are pretty useless without me giving the complete song and dance routine as well ;-) Best to see them together with the video ...

> On Feb 12, 2015, at 17:59, Marcus Denker <[hidden email]> wrote:
>
>
>> On 12 Feb 2015, at 17:53, Sven Van Caekenberghe <[hidden email]> wrote:
>>
>> BTW, Johan, I cannot find your slides in http://www.slideshare.net/pharoproject/presentations ?
>>
> I have the .key files.. I will double check and upload the missings…
>



---> Save our in-boxes! http://emailcharter.org <---

Johan Fabry   -   http://pleiad.cl/~jfabry
PLEIAD lab  -  Computer Science Department (DCC)  -  University of Chile


Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

kilon.alios
In reply to this post by jfabry
If Spec was what imagine the ideal GUI API to be then I would certainly love it to death. But thats besides the point , I have already explained what I dont like about Spec in another thread as you already mentioned. You cannot debate personal taste, sure you can clear misconceptions but in then end personal taste goes a lot deeper than that. There will be people who love Spec and people who hate it, and the rest will be somewhere in the between. You claimed how harmful is for Pharo to have a fragmentation for GUI APIs , I expressed the opposite opinion , its not as if we will agree in the end. We wont, we are clearly two people with different philosophies. For you reimplementing/reinventing the wheel is a waste of time, for me its the source of the human intelligence. Also I find reinventing the wheel a great way to learn the inner mechanics of the wheel and gain a deeper understanding. 

You dont need my approval to move Spec forward nor my permission. You will do just fine without me and I sincerely hope you find those 4 developers and move Spec light years ahead. I dont promise to like it but I will definitely keep an open mind and follow your progress. Who knows maybe one day I may be one of those 4 developers or even many more.  But in the end I hope people never polarise on specific libraries and keep coming up with new fresh ideas and approaches even on the same problems. GTSpotter is one such example that has been a great addition to my workflow. 

And its not as if Spec is the only thing I dont like in Pharo. I dont like the design of new Playground and Inspector at least some parts of it I have already mentioned in other threads. I hated the white theme  and I am glad I have no need to use it anymore. I dont like monticello GUI design. Auto completion is messy at times etc etc. I am sure other Pharo developers have their own likes and dislikes.

PS: I did not complain about Spec, I only said that I don't like it and in the context of explaining why we need alternative solutions for GUI creation, or at least why I need them. 

On Thu, Feb 12, 2015 at 7:57 PM, Johan Fabry <[hidden email]> wrote:

Kilon, your second paragraph can be understood as a description of Spec. There is a low level code and an extensions API, and ALL widgets are implemented as such extensions and you can assemble a GUI framework. What you propose as your ideal solution is reimplementing this wheel all over again.

In the end, you never clearly stated why you don’t like Spec. I mean, beyond the questions that I provided you an answer for some time ago. So please, instead of saying ‘I don’t like X’ clarify exactly what it is that you don’t like and why. Otherwise there will never be advances and it’s annoying to hear the same vague complaints all over again ...

On Feb 12, 2015, at 15:28, kilon alios <[hidden email]> wrote:

Frankly big libraries dont make much sense for me when it comes to Pharo. Sure if we were talking about Python I would say yes. I do believe however that Pharo makes it already very easy to combine libraries together. 

So for me the ideal solution would be a very low level core that comes with very well documented extensions API and then widgets are implemented as third party extensions that will allow you to assemble a GUI framework tailor made to your own needs. Unfortunately making such a complex core will require quite some effort . So my idea is not without its own problems. 

So I would have to say no , I dont agree,  at least I think we imagine very different things.

The goal of Spec may not be to replace Morphic but then the goal of the human race was not to go to the moon until one day scientists told us its possible. The same can happen with Spec, keep improving it , extending it and people will keep using it more and more in place of Morphic even if Spec still keeps relying in Morphic.   Afterall its not difficult to imagine Spec one day in the distant future coming with its own backend. None can predict the future afterall, even if you invent it (sorry Alan). But then this what makes future so exciting , its unpredictable nature. 

---> Save our in-boxes! http://emailcharter.org <---

Johan Fabry   -   http://pleiad.cl/~jfabry
PLEIAD lab  -  Computer Science Department (DCC)  -  University of Chile


Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

jfabry
In reply to this post by Sebastian Heidbrink-2
Some restricted comments inline

> On Feb 12, 2015, at 17:15, Sebastian Heidbrink <[hidden email]> wrote:
>
> I think there is most stuff out there in Pharo that is needed to built a nice UI with Model interaction.
> It took me jsut a few hours to built a nice Glamour based data model browser.
> So why do I struggle to built a login view?!
> I think this is because Glamour is its own example.... It is implemented in one way and there are few distractions.

Glamour is excellent! But only as long as you want to do something that fits the overall philosophy of it. That’s the advantages and the disadvantages of a domain-specific solution. Spec is a general-purpose solution.

Your login UI should be able to be built in Spec in less than 20 minutes. (Supposing it is more or less like a traditional login UI).

> What Pharo needs and I do not think that this is a too huge task is.
> A clear destiction of M, V and C accomplished by ClassNamingConvertions and package sub-division of these.
> A browser that just lists all the available basic morphs and their examples

Browse the hierarchy of ComposableModel and you have all the Spec widgets and UIs that are in the image.

> A sushi store demo according to the current Pharo release.

I don’t know this example, can you give a link to an example app?

> A clear documentation what, Spec, Polymorph, Morphic,... are representing and on which "layer" they are positioned. OS-Layer, Common-Layer, Layout-Layer, Event-Layer.

Have a look at the Spec book chapter (in progress). It also relates the position of Spec with respect to Morphic https://ci.inria.fr/pharo-contribution/view/Books/job/PharoBookWorkInProgress/lastSuccessfulBuild/artifact/Spec/

[…]

> So and now her eis the question that I think needs to be discussed since it is the most controversial answered to me.
> "Spec or not to Spec?"
>
> I am kidding!
> But my current counter is 5 for Spec and 5 against Spec.
> I think some rason could be that Spec is misunderstood, or still under development/inmature.
> I can't tell, but  a beginner wants to know:
> "WHAT AM I SUPPOSED TO DO!?"

To answer your BIG QUESTION ;-) Read the book chapter that I linked to above, or at least the first few sections, and try to build the login UI with Spec. Then you will have better information that can serve to make a choice for or against your use of Spec.

---> Save our in-boxes! http://emailcharter.org <---

Johan Fabry   -   http://pleiad.cl/~jfabry
PLEIAD lab  -  Computer Science Department (DCC)  -  University of Chile


Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

jfabry
In reply to this post by kilon.alios
Kilon, I repeat and paraphrase from my previous mail:

In the end, you never clearly stated why you don’t like Spec. You did not provide any more concrete information except that your taste is different. So please, instead of saying ‘I don’t like X’ clarify exactly what it is that you don’t like and why. Otherwise there will never be advances and it’s annoying to hear the same vague complaints all over again …

On Feb 12, 2015, at 19:46, kilon alios <[hidden email]> wrote:

If Spec was what imagine the ideal GUI API to be then I would certainly love it to death. But thats besides the point , I have already explained what I dont like about Spec in another thread as you already mentioned. You cannot debate personal taste, sure you can clear misconceptions but in then end personal taste goes a lot deeper than that. There will be people who love Spec and people who hate it, and the rest will be somewhere in the between. You claimed how harmful is for Pharo to have a fragmentation for GUI APIs , I expressed the opposite opinion , its not as if we will agree in the end. We wont, we are clearly two people with different philosophies. For you reimplementing/reinventing the wheel is a waste of time, for me its the source of the human intelligence. Also I find reinventing the wheel a great way to learn the inner mechanics of the wheel and gain a deeper understanding. 

You dont need my approval to move Spec forward nor my permission. You will do just fine without me and I sincerely hope you find those 4 developers and move Spec light years ahead. I dont promise to like it but I will definitely keep an open mind and follow your progress. Who knows maybe one day I may be one of those 4 developers or even many more.  But in the end I hope people never polarise on specific libraries and keep coming up with new fresh ideas and approaches even on the same problems. GTSpotter is one such example that has been a great addition to my workflow. 

And its not as if Spec is the only thing I dont like in Pharo. I dont like the design of new Playground and Inspector at least some parts of it I have already mentioned in other threads. I hated the white theme  and I am glad I have no need to use it anymore. I dont like monticello GUI design. Auto completion is messy at times etc etc. I am sure other Pharo developers have their own likes and dislikes.

PS: I did not complain about Spec, I only said that I don't like it and in the context of explaining why we need alternative solutions for GUI creation, or at least why I need them. 



---> Save our in-boxes! http://emailcharter.org <---

Johan Fabry   -   http://pleiad.cl/~jfabry
PLEIAD lab  -  Computer Science Department (DCC)  -  University of Chile

Reply | Threaded
Open this post in threaded view
|

Re: pharo and ui again

Sebastian Heidbrink-2
In reply to this post by jfabry
Hi!

Well, I never understood that decision but the SushiStore was once removed from the Seaside repository.
But it might be stil lavailable here: http://www.squeaksource.com/SeasideExamples.html have a look under Store.
It was also used by James Foster while he did his tutorials for Seaside on Gemstone/Glass. So ther emight be a version here.
http://seaside.gemtalksystems.com/ss/GemStoneExamples.html
But I have no idea how outdated they are.

I just remebered the shift centermouse button ui context menu access. (on Windows)
I took these screenshots from a Pharo 4 image:


Click the red menu button and you get:



There you have all the menus to manipulate the look and feel of your morphic.
Unfortunately the export to .morp files seems to be no more available in Pharo http://wiki.squeak.org/squeak/2236
I wonder if one could introduce a export to Spec ...

I think it would be easy enoug for prototyping to just create a ui with this.
The only thing missing would be a menu entry that allows to select events and add according announment symbols... and the receivers...

It is all there for rapid protoyping it seems but is is not hooked up somehow.

20 minutes for a login screen with Spec is not yet competitive but especially if I need to know it first to be able to make it in 20 minutes...
Thank you for the document link. I am already reading it.

Sebastian




Am 12.02.2015 um 10:53 schrieb Johan Fabry:
Some restricted comments inline

On Feb 12, 2015, at 17:15, Sebastian Heidbrink [hidden email] wrote:

I think there is most stuff out there in Pharo that is needed to built a nice UI with Model interaction.
It took me jsut a few hours to built a nice Glamour based data model browser.
So why do I struggle to built a login view?!
I think this is because Glamour is its own example.... It is implemented in one way and there are few distractions.
Glamour is excellent! But only as long as you want to do something that fits the overall philosophy of it. That’s the advantages and the disadvantages of a domain-specific solution. Spec is a general-purpose solution.

Your login UI should be able to be built in Spec in less than 20 minutes. (Supposing it is more or less like a traditional login UI).

What Pharo needs and I do not think that this is a too huge task is.
A clear destiction of M, V and C accomplished by ClassNamingConvertions and package sub-division of these.
A browser that just lists all the available basic morphs and their examples
Browse the hierarchy of ComposableModel and you have all the Spec widgets and UIs that are in the image.

A sushi store demo according to the current Pharo release.
I don’t know this example, can you give a link to an example app?

A clear documentation what, Spec, Polymorph, Morphic,... are representing and on which "layer" they are positioned. OS-Layer, Common-Layer, Layout-Layer, Event-Layer.
Have a look at the Spec book chapter (in progress). It also relates the position of Spec with respect to Morphic https://ci.inria.fr/pharo-contribution/view/Books/job/PharoBookWorkInProgress/lastSuccessfulBuild/artifact/Spec/

[…]

So and now her eis the question that I think needs to be discussed since it is the most controversial answered to me.
"Spec or not to Spec?"

I am kidding!
But my current counter is 5 for Spec and 5 against Spec.
I think some rason could be that Spec is misunderstood, or still under development/inmature.
I can't tell, but  a beginner wants to know:
"WHAT AM I SUPPOSED TO DO!?"
To answer your BIG QUESTION ;-) Read the book chapter that I linked to above, or at least the first few sections, and try to build the login UI with Spec. Then you will have better information that can serve to make a choice for or against your use of Spec.

---> Save our in-boxes! http://emailcharter.org <---

Johan Fabry   -   http://pleiad.cl/~jfabry
PLEIAD lab  -  Computer Science Department (DCC)  -  University of Chile




12