Skip to content
This repository has been archived by the owner on Sep 8, 2023. It is now read-only.

Possible features (ongoing) #1

Open
3 of 12 tasks
Allendar opened this issue Oct 31, 2017 · 7 comments
Open
3 of 12 tasks

Possible features (ongoing) #1

Allendar opened this issue Oct 31, 2017 · 7 comments

Comments

@Allendar
Copy link
Contributor

Allendar commented Oct 31, 2017

@atomi Thanks so much for making this! I never really dived into making VSCode extensions, but this is already so much better than just HTML mapping qtpl file to basic HTML.

Already love the markup. These were some things that instantly popped into my mind;

  • VSCode Go extension interpreter partially inside the template:

  • Automatically resolve imports and sort them by name ({% import "strconv" %} etc.)

  • Understanding structs/types for auto-completion

  • Jump to definition when CMD(CTRL) + Click on a var/struct/function

  • Other features:

  • Logic for the {% %}, {%s %}, {%s= %} type auto-completion and checking if the type matches

  • Making the Extended pages understand what functions they can implement. Say I'm extending a BasePage and have a Stylesheets block (function), this could auto-complete while typing {% func (p *ForgotPasswordPage) Stylesheets() %}. This probably is via {% interface (Page interface > BasePage struct > ForgotPasswordPage struct)

  • Automatically generate endings for things like {% if obj.Something() %} to pop-in {% endif %} after. Same for {% for _, user := range p.Users %} > {% endfor %}

  • {% func Stylesheets %}{% endfunc %} auto-completion

  • I have a helpers.qtpl file (kind of like Macros in Twig/Django). Reading those function definitions from other qtpl files in the same folder (e.a. {%s= FormEmailField(p.Form.Field("email")) %})

  • Make CMD(CTRL) + / actually wrap a {% comment %}{% endcomment %} instead of normal HTML commenting

  • An action via SHIFT + CMD(CTRL) + P to wrap the selected code with {% stripspace %}

  • Beautification on save (settings to turn behaviour on/off) to automatically indent the combination of QuickTemplate and HTML/CSS/JS. Making it honour the normal HTML/CSS/JS indentation and afterwards indenting QuickTemplate if/else and for definitions

  • Force a newline at the end of each file

I'll keep updating this list for things that I might see.

Thanks again!

@atomi
Copy link
Owner

atomi commented Oct 31, 2017

Holy cow that's quite a list. The original scope of this project was just to add syntax highlighting.

It was rather simple to just run yo code and create the template project for a language definition. Outside of that will require some typescript and it's not a language I've delved into much.

Edit: But don't let that dissuade you from updating the list. I can probably do a few of those at some point.

@Allendar
Copy link
Contributor Author

That's ok :) I'm diving into the building extensions docs too this week. So I will do Pull Requests where I can to help out! :)

@atomi
Copy link
Owner

atomi commented Oct 31, 2017

Great. Cheers.

@Allendar
Copy link
Contributor Author

Allendar commented Nov 1, 2017

@atomi Not sure if it automatically picks up updates, but if not so, can you submit release 0.0.2 to the Visual Studio Marketplace?

@atomi
Copy link
Owner

atomi commented Nov 1, 2017

Sorry for the late reply (Halloween/Dodgers parties)... But yeah, I need to figure out a way to do CI in the marketplace or add contributors. I'll work on that today.

@atomi
Copy link
Owner

atomi commented Nov 1, 2017

@Allendar I believe I added you to the marketplace project on the visualstudio.com site.

Since I didn't see an easy way to add CI for the github repo these are the instructions for publishing in the meantime: https://code.visualstudio.com/docs/extensions/publish-extension

@Allendar
Copy link
Contributor Author

Allendar commented Nov 3, 2017

Had two very busy days. Long weekend now. I'll dive into it more tomorrow :)

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

No branches or pull requests

2 participants