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

fix(web): extra spaces in HTML attribute #21855

Closed
wants to merge 20 commits into from

Conversation

kecrily
Copy link
Contributor

@kecrily kecrily commented Nov 18, 2022

Remove extra spaces in class attributes caused by conditional statements

Example:

<div class="{{if .Source.IsLDAP}}required{{end}} field">

When IsLDAP is false, will render <div class=" field"> not <div class="field">. So should put space in conditional statements.


Changes are made by VS Code regex replace and are checked manually.

  • class="\{\{if (.*)\{\{end\}\} -> class="{{if $1 {{end}\}
  • class="(.*) \{\{if (.*)\}\}(.*)\{\{end\}\} -> class="$1{{if $2}} $3{{end}}

Copy link
Member

@delvh delvh left a comment

Choose a reason for hiding this comment

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

Your automatic check seems not to have included all cases.

Should we also include the other case char {{<something>}}class in this PR, or do we open another PR for it?

templates/repo/issue/view_content/sidebar.tmpl Outdated Show resolved Hide resolved
templates/repo/issue/view_content/sidebar.tmpl Outdated Show resolved Hide resolved
templates/repo/issue/view_content/sidebar.tmpl Outdated Show resolved Hide resolved
templates/repo/issue/view_content/sidebar.tmpl Outdated Show resolved Hide resolved
templates/repo/issue/list.tmpl Outdated Show resolved Hide resolved
@GiteaBot GiteaBot added the lgtm/need 2 This PR needs two approvals by maintainers to be considered for merging. label Nov 18, 2022
@silverwind
Copy link
Member

silverwind commented Nov 18, 2022

If you are really sure about your regexes, you could put them below this one as a sed replacement for auto-formatting during make fmt:

gitea/Makefile

Line 271 in 0b993a0

@$(SED_INPLACE) -e 's/{{[ ]\{1,\}/{{/g' -e '/^[ ]\{1,\}}}/! s/[ ]\{1,\}}}/}}/g' $(TEMPLATES)

@kecrily
Copy link
Contributor Author

kecrily commented Nov 18, 2022

In fact I'm not very confident in my regex. I was afraid it would inadvertently destroy something.

@silverwind
Copy link
Member

Need to rebase.

@silverwind
Copy link
Member

silverwind commented Nov 20, 2022

Test failures do seem related, but it's not immediately clear to my why.

@zeripath
Copy link
Contributor

Test failures do seem related, but it's not immediately clear to my why.

--- FAIL: TestPullCompare (0.43s)
    testlogger.go:78: 2022/11/20 15:36:35 ...eb/routing/logger.go:99:func1() [I] [637a4983] router: completed GET /user2/repo1/pulls for , 200 OK in 98.0ms @ repo/issue.go:408(repo.Issues)
    pull_compare_test.go:27: 
        	Error Trace:	/drone/src/integration_test.go:337
        	            				/drone/src/integration_test.go:166
        	            				/drone/src/pull_compare_test.go:27
        	Error:      	Not equal: 
        	            	expected: 200
        	            	actual  : 404
        	Test:       	TestPullCompare
        	Messages:   	Request: GET /user2/repo1/compare/master...master%20
    pull_compare_test.go:27: Response: Not found.

In particular:

Messages:   	Request: GET /user2/repo1/compare/master...master%20

I suspect the changes have broken the url somehow.

@zeripath
Copy link
Contributor

The above two things should fix the problem but we should really go through this PR and double check that it's doing the correct thing.

@kecrily
Copy link
Contributor Author

kecrily commented Nov 21, 2022

The issue was constructed with so many files (a mind-boggling 148) that regex were my only option. My regex isn't very good, therefore it could have resulted in an incorrect alteration.

I also made an effort to go back and revert any incorrect alterations, but it was simply too much. Inevitably, something is missed, and we can only rely on the keen eye of the reviewer.

@kecrily kecrily changed the title fix(web): extra spaces in the class attribute fix(web): extra spaces in HTML attribute Nov 21, 2022
@silverwind
Copy link
Member

First failure on CI is odd because it's being seen outside this PR too, so I think it may be flaky/unrelated. See #21854.

@silverwind
Copy link
Member

Can you get the tests to pass please? Then I'm happy to review.

@zeripath
Copy link
Contributor

There were two more mistakenly added spaces.

@wxiaoguang
Copy link
Contributor

wxiaoguang commented Feb 14, 2023

I have objection to this change, and suggest to stick to class="c1 {{if $var}}c2{{end}}"

The readability and maintainability should be applied to the code which is read by developers, but not for the generated outputs.

The template code is the code for developers, while the generated HTML are only for browsers.

The class="c1 {{if $var}}c2{{end}}" style is clearer for developers and more intuitive, and the generated HTML also makes browsers happy (a few spaces do not affect anything)

Think about a more complex case:

  • class="{{if $active}}active{{end}} menu item {{if $show}}show{{end}} {{if $warn}}warn{{end}}"
  • --vs--
  • class="{{if $active}}active {{end}}menu item{{if $show}} show{{end}}{{if $warn}} warn{{end}}"

The first style make it clearer to see each CSS class name with its {{if}} block.

@zeripath
Copy link
Contributor

I do agree with @wxiaoguang here - I know we've done a lot of work elsewhere getting rid of the extra spaces but I'm just not sure it's worth it given the confusion and potential for bugs it adds.

Who is looking at the HTML anyway? We'd potentially be better off passing the output of our HTML renderer through a lightweight html parser that would minimize and remove the extra spaces instead.

@silverwind
Copy link
Member

Not sure if postprocessing the HTML is worth it, it'll impact performance for neglible gain.

BTW, In JS land, there is the classnames module that's used to join together class names, maybe something similar could be done for go templates as well, thought it'll never be as elegant as the JS solution.

lunny added a commit that referenced this pull request Mar 5, 2023
### The CustomEvent prefix

There was already `ce-quick-submit`, the `ce-` prefix seems better than
`us-`. Rename the only `us-` prefixed `us-load-context-popup` to `ce-`
prefixed.

### Styles and Attributes in Go HTML Template

#21855 (comment)

Suggest to stick to `class="c1 {{if $var}}c2{{end}}"`

The readability and maintainability should be applied to the code which
is read by developers, but not for the generated outputs.

The template code is the code for developers, while the generated HTML
are only for browsers.

The `class="c1 {{if $var}}c2{{end}}"` style is clearer for developers
and more intuitive, and the generated HTML also makes browsers happy (a
few spaces do not affect anything)

Think about a more complex case:

* `class="{{if $active}}active{{end}} menu item {{if $show}}show{{end}}
{{if $warn}}warn{{end}}"`
* --vs--
* `class="{{if $active}}active {{end}}menu item{{if $show}}
show{{end}}{{if $warn}} warn{{end}}"`

The first style make it clearer to see each CSS class name with its
`{{if}}` block.

Co-authored-by: Lunny Xiao <[email protected]>
@wolfogre
Copy link
Member

Now that #23298 has been merged, I suggest closing this PR. @kecrily, thank you for your effort; it prompted us to think more deeply..

@wolfogre wolfogre closed this Mar 20, 2023
@go-gitea go-gitea locked and limited conversation to collaborators May 3, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
lgtm/need 2 This PR needs two approvals by maintainers to be considered for merging.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants