Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implemented GenUI for NiGui #5

Open
wants to merge 7 commits into
base: master
Choose a base branch
from
Open

Conversation

PMunch
Copy link
Contributor

@PMunch PMunch commented Jul 11, 2017

This is an implementation of the GenUI macro for NiGui. It includes an example and an explanation of how to use it and what it is.

@ghost
Copy link

ghost commented Jul 11, 2017

Wow, very good work!

@ghost
Copy link

ghost commented Jul 11, 2017

But I think you need to make "genui" available when installing from nimble.
Maybe move it under nigui directory?

…ucture. Also added it as an include in nigui.nim, might not be wanted but not sure how to make it require an explicit include from it's new position.
@PMunch
Copy link
Contributor Author

PMunch commented Jul 12, 2017

Sorry, my bad. It was made with the old folder structure, and I forgot to check when I merged in your changes to my fork. Should be fixed now.

@ghost
Copy link

ghost commented Jul 12, 2017

Is there a way to export variable from @Result?

genui:
  Window[width = 800, height = 600, show]("Nickel"):
    LayoutContainer(Layout_Vertical):
      {var guiLog* = @result} TextArea()

this doesn't work.
But I know that there's a workaround:

genui:
  Window[width = 800, height = 600, show]("Nickel"):
    LayoutContainer(Layout_Vertical):
      {var temp = @result} TextArea()
var guiLog* = temp

@ghost
Copy link

ghost commented Jul 12, 2017

Currently I need to use this as I need to export two variables:

genui:
  {var tempWin = @result} Window[width = 800, height = 600, show]("Nickel"):
    LayoutContainer(Layout_Vertical):
      {var temp = @result} TextArea()

var window* = tempWin
var guiLog* = temp

@ghost
Copy link

ghost commented Jul 12, 2017

Also I did a quick port of NiCalc gui to genui:
I think @Result can be shortcutted to "@" maybe? Because it takes many space

genui:
  {var window = @result} Window[width = 600, height = 450]("NiCalc"):
    LayoutContainer[padding = 6](Layout_Vertical):
      LayoutContainer(Layout_Horizontal):
        Label("Input:") [minWidth = labelWidth, heightMode = HeightMode_Fill]
        {var inputTextBox = @result} TextBox() [fontSize = editFontSize, fontFamily = editFontFamily]
        {var clearButton = @result} = Button("Clear") [minWidth = buttonWidth, heightMode = HeightMode_Fill]
      LayoutContainer(Layout_Horizontal):
        Label("Result:") [minWidth = labelWidth, heightMode = HeightMode_Fill]
        {var resultTextBox = @result} TextBox() [fontSize = editFontSize, fontFamily = editFontFamily]
      {var historyContainer = @result} LayoutContainer(Layout_Vertical)[frame = newFrame("History")]:
        {var historyTextArea = @result} TextArea() [fontSize = historyFontSize, fontFamily = editFontFamily]

But overall this looks much more clear than usual style (because you can immediatly see type of layout, and order of GUI elements)

@PMunch
Copy link
Contributor Author

PMunch commented Jul 12, 2017

Ah yeah. The {} code thing is still a work in progress. Previous versions of genui used identifier % Button to assign a new button to the identifier "identifier". This was limited to only that though and couldn't be used for thing like array assignment and such. The plan with {} was to allow any code to be inserted but it proved a bit hard because of how Nim parses things before the macro gets a look at it. I'll try to work out something a bit more robust though. The @Result was also a bit of a necesitty of the same reason, Nim refuses to parse only @. I was also thinking that maybe different @ values could be used to get different things, like using @children in a loop for a repeating section for example. But I agree that it's a bit long and clumsy.

@ghost
Copy link

ghost commented Jul 12, 2017

@PMunch anyway genui is a great addition to NiGui

@PMunch
Copy link
Contributor Author

PMunch commented Jul 12, 2017

Oh thanks, I think so too. By the way, another workaround for your specific problem which might be better is to simply define the variable before assigning to it in the curly brackets like so:

var myButton*: Button
genui:
  Window[width=800, height=600]:
    {myButton = @result} Button("Hello world")

@PMunch
Copy link
Contributor Author

PMunch commented Jul 12, 2017

Okay, I've now added a small check to the handling of pure code. If the only node in the code is a string literal it parses it as code instead of inserting it directly as code. This means that you can now do:

genui:
  Window[width=800, height=600]:
    {"var myButton* = @result"} Button("Hello world")

And that would be parsed into code and work as you would expect. It's not perfect but it should work for now.

@ghost
Copy link

ghost commented Jul 12, 2017

@PMunch thanks!

@PMunch
Copy link
Contributor Author

PMunch commented Jul 12, 2017

Hmm, just talked to some guys over in the IRC channel and it seems like the error is with how curly brackets are parsed. I checked and if you simply add parenthesis like {(code)} then it also works fine (plus you get syntax highlighting).

@ghost
Copy link

ghost commented Jul 12, 2017

@PMunch thanks for this workaround!
works perfectly

@PMunch
Copy link
Contributor Author

PMunch commented Jul 12, 2017

How was the porting experience by the way? One thing I feel is important with genui is how it is a fairly simple conversion to actual code so you should be able to easily port examples over. I hate when working with Gtk and the GUI builder just to Google something and only finding code snippets which I can't easily convert, or vice versa.

@ghost
Copy link

ghost commented Jul 12, 2017

@PMunch porting NiCalc gui to genui was fairly simple.

genui is the best for projects where GUI code is larger than one screen in length.
For example NiCalc has 47 lines of gui creating code (including some spaces between different sections)

And also for now nigui doesn't contain many widgets, but I think this will improve in the future.
Maybe this is the GUI framework for Nim that we've waited for :)

@PMunch
Copy link
Contributor Author

PMunch commented Jul 12, 2017

I'm definitely hoping so, which is why I wanted to port genui to it as quickly as possible. I added a shorthand @r now by the way that can be used instead of @result, is that a fair compromise?

@ghost
Copy link

ghost commented Jul 12, 2017

@PMunch yeah, thanks again!

@ghost
Copy link

ghost commented Jul 12, 2017

So, let's wait for @trustable-code :)

@oskca
Copy link

oskca commented Dec 16, 2017

Great work 👍

@ghost
Copy link

ghost commented May 7, 2018

@trustable-code so what is the status of this PR?

@simonkrauter
Copy link
Owner

@Yardanico I don't like additional complexity and don't see an advantage of using such macros as of now.

@PMunch
Copy link
Contributor Author

PMunch commented May 7, 2018

I wrote a bit about the benefits of this system in my post here(primarily under the "A simple GUI DSL" heading). The macro in play here is actually fairly simple as long as the general interface is kept fairly uniform. It maps 1:1 from the DSL input to generated code, and doesn't really do a whole lot more than structure the code. The entire implementation is only about 150 lines, and could probably be shortened even more, plus it would probably not have to be changed at all for the foreseeable future unless you add some widgets which acts completely different than the ones you've got.

Copy link

@misolietavec misolietavec left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Cannot be GenUI made as package outside of NiGui,wxnim etc.?

@PMunch
Copy link
Contributor Author

PMunch commented Jul 1, 2018

Well technically yes. The wxNim version of genui was made a part of wxNim simply because I had to make changes to the code in order to make it work for all widgets. For NiGui on the other hand it could easily be implemented as an entirely different package. Although there are benefits to keeping it as a single thing. First of people making changes to NiGui would have to be aware of it, second it would make testing a whole lot easier.

@andrewgohlk
Copy link

andrewgohlk commented Jun 19, 2021

I tried to add "genui:" & add the various ui elements for nigui's example_02_controls.nim but hit:
Error: undeclared identifier: 'genui'

@PMunch
Copy link
Contributor Author

PMunch commented Jun 29, 2021

@andrewgohlk, on my fork, or the main repository? This PR is pretty outdated by now, no idea if it still works or not.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants