Add seasons’ relation, functions, and admin section
Seasons have a color to show on the calendar. I need them in HTML format
(e.g., #123abc) in order to set as value to `<input type="color">`, but
i did not want to save them as text in the database, as integers are
better representations of colors—in fact, that’s what the HTML syntax
also is: an integer.
I think the best would be to create an extension that adds an HTML color
type, with functions to convert from many representations (e.g., CSS’
rgb or even color names) to integer and back. However, that’s a lot of
work and i can satisfy Camper’s needs with just a couple of functions
and a domain.
To show the color on the index, at first tried to use a read-only
`<input type="color">`, but seems that this type of input can not be
read-only and must be disabled instead. However, i do not know whether
it makes sense to have a disabled input outside a form “just” to show
a color; i suspect it does not. Thus, at the end i use SVG with a
single circle, which is better that a 50%-rounded div with a background
color, even if the result is the same—SVG **is** intended for showing
pictures, which is this case.
2023-08-16 18:15:57 +00:00
|
|
|
<!--
|
|
|
|
SPDX-FileCopyrightText: 2023 jordi fita mas <jordi@tandem.blog>
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
-->
|
|
|
|
{{ define "title" -}}
|
|
|
|
{{- /*gotype: dev.tandem.ws/tandem/camper/pkg/season.seasonForm*/ -}}
|
|
|
|
{{ if .Slug}}
|
|
|
|
{{( pgettext "Edit Season" "title" )}}
|
|
|
|
{{ else }}
|
|
|
|
{{( pgettext "New Season" "title" )}}
|
|
|
|
{{ end }}
|
|
|
|
{{- end }}
|
|
|
|
|
|
|
|
{{ define "content" -}}
|
|
|
|
{{- /*gotype: dev.tandem.ws/tandem/camper/pkg/season.seasonForm*/ -}}
|
|
|
|
<form
|
|
|
|
{{ if .Slug }}
|
|
|
|
data-hx-put="/admin/seasons/{{ .Slug }}"
|
|
|
|
{{ else }}
|
|
|
|
action="/admin/seasons" method="post"
|
|
|
|
{{ end }}
|
|
|
|
>
|
|
|
|
<h2>
|
|
|
|
{{ if .Slug }}
|
|
|
|
{{( pgettext "Edit Season" "title" )}}
|
|
|
|
{{ else }}
|
|
|
|
{{( pgettext "New Season" "title" )}}
|
|
|
|
{{ end }}
|
|
|
|
</h2>
|
|
|
|
{{ CSRFInput }}
|
2024-01-12 19:26:45 +00:00
|
|
|
<fieldset {{template "init-lang" . }}>
|
Add seasons’ relation, functions, and admin section
Seasons have a color to show on the calendar. I need them in HTML format
(e.g., #123abc) in order to set as value to `<input type="color">`, but
i did not want to save them as text in the database, as integers are
better representations of colors—in fact, that’s what the HTML syntax
also is: an integer.
I think the best would be to create an extension that adds an HTML color
type, with functions to convert from many representations (e.g., CSS’
rgb or even color names) to integer and back. However, that’s a lot of
work and i can satisfy Camper’s needs with just a couple of functions
and a domain.
To show the color on the index, at first tried to use a read-only
`<input type="color">`, but seems that this type of input can not be
read-only and must be disabled instead. However, i do not know whether
it makes sense to have a disabled input outside a form “just” to show
a color; i suspect it does not. Thus, at the end i use SVG with a
single circle, which is better that a 50%-rounded div with a background
color, even if the result is the same—SVG **is** intended for showing
pictures, which is this case.
2023-08-16 18:15:57 +00:00
|
|
|
{{ if .Slug }}
|
|
|
|
{{ with .Active -}}
|
|
|
|
<label>
|
|
|
|
<input type="checkbox" name="{{ .Name }}" {{ if .Checked}}checked{{ end }}
|
|
|
|
{{ template "error-attrs" . }}>
|
|
|
|
{{( pgettext "Active" "season" )}}<br>
|
|
|
|
</label>
|
|
|
|
{{ template "error-message" . }}
|
|
|
|
{{- end }}
|
|
|
|
{{ else }}
|
|
|
|
<input type="hidden" name="{{ .Active.Name }}" value="true">
|
|
|
|
{{ end }}
|
|
|
|
{{ with .Name -}}
|
2024-01-12 19:26:45 +00:00
|
|
|
<fieldset>
|
|
|
|
<legend>{{( pgettext "Name" "input")}}</legend>
|
|
|
|
{{ template "lang-selector" . }}
|
|
|
|
{{ range $lang, $input := . -}}
|
|
|
|
<label x-cloak x-show="lang === '{{ $lang }}'"><span>{{ $lang }}</span><br>
|
|
|
|
<input type="text" name="{{ $input.Name }}" value="{{ $input.Val }}"
|
|
|
|
{{ template "error-attrs" $input }}><br>
|
|
|
|
</label>
|
|
|
|
{{- end }}
|
|
|
|
{{ template "error-message" . }}
|
|
|
|
</fieldset>
|
Add seasons’ relation, functions, and admin section
Seasons have a color to show on the calendar. I need them in HTML format
(e.g., #123abc) in order to set as value to `<input type="color">`, but
i did not want to save them as text in the database, as integers are
better representations of colors—in fact, that’s what the HTML syntax
also is: an integer.
I think the best would be to create an extension that adds an HTML color
type, with functions to convert from many representations (e.g., CSS’
rgb or even color names) to integer and back. However, that’s a lot of
work and i can satisfy Camper’s needs with just a couple of functions
and a domain.
To show the color on the index, at first tried to use a read-only
`<input type="color">`, but seems that this type of input can not be
read-only and must be disabled instead. However, i do not know whether
it makes sense to have a disabled input outside a form “just” to show
a color; i suspect it does not. Thus, at the end i use SVG with a
single circle, which is better that a 50%-rounded div with a background
color, even if the result is the same—SVG **is** intended for showing
pictures, which is this case.
2023-08-16 18:15:57 +00:00
|
|
|
{{- end }}
|
|
|
|
{{ with .Color -}}
|
|
|
|
<label>
|
|
|
|
{{( pgettext "Color" "input")}}<br>
|
|
|
|
<input type="color" name="{{ .Name }}" value="{{ .Val }}"
|
|
|
|
required {{ template "error-attrs" . }}><br>
|
|
|
|
</label>
|
|
|
|
{{ template "error-message" . }}
|
|
|
|
{{- end }}
|
|
|
|
</fieldset>
|
|
|
|
<footer>
|
|
|
|
<button type="submit">
|
|
|
|
{{ if .Slug }}
|
|
|
|
{{( pgettext "Update" "action" )}}
|
|
|
|
{{ else }}
|
|
|
|
{{( pgettext "Add" "action" )}}
|
|
|
|
{{ end }}
|
|
|
|
</button>
|
|
|
|
</footer>
|
|
|
|
</form>
|
|
|
|
{{- end }}
|