Improve this
Some checks are pending
/ release (push) Waiting to run
testing / backend-checks (push) Waiting to run
testing / frontend-checks (push) Waiting to run
testing / test-unit (push) Blocked by required conditions
testing / test-e2e (push) Blocked by required conditions
testing / test-remote-cacher (redis) (push) Blocked by required conditions
testing / test-remote-cacher (valkey) (push) Blocked by required conditions
testing / test-remote-cacher (garnet) (push) Blocked by required conditions
testing / test-remote-cacher (redict) (push) Blocked by required conditions
testing / test-mysql (push) Blocked by required conditions
testing / test-pgsql (push) Blocked by required conditions
testing / test-sqlite (push) Blocked by required conditions
testing / security-check (push) Blocked by required conditions
Some checks are pending
/ release (push) Waiting to run
testing / backend-checks (push) Waiting to run
testing / frontend-checks (push) Waiting to run
testing / test-unit (push) Blocked by required conditions
testing / test-e2e (push) Blocked by required conditions
testing / test-remote-cacher (redis) (push) Blocked by required conditions
testing / test-remote-cacher (valkey) (push) Blocked by required conditions
testing / test-remote-cacher (garnet) (push) Blocked by required conditions
testing / test-remote-cacher (redict) (push) Blocked by required conditions
testing / test-mysql (push) Blocked by required conditions
testing / test-pgsql (push) Blocked by required conditions
testing / test-sqlite (push) Blocked by required conditions
testing / security-check (push) Blocked by required conditions
Signed-off-by: Minecon724 <minecon724@noreply.git.m724.eu>
This commit is contained in:
parent
230e2de3de
commit
e82e33e116
2 changed files with 3 additions and 81 deletions
|
@ -26,38 +26,9 @@
|
||||||
<input name="full_name" value="{{.SignedUser.FullName}}" maxlength="100">
|
<input name="full_name" value="{{.SignedUser.FullName}}" maxlength="100">
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
<label id="label-pronouns" class="tw-hidden">
|
|
||||||
{{ctx.Locale.Tr "settings.pronouns"}}
|
|
||||||
<div id="pronouns-dropdown" class="ui selection dropdown" aria-labelledby="label-pronouns">
|
|
||||||
<input type="hidden" value="{{.SignedUser.Pronouns}}">
|
|
||||||
<div class="text">
|
|
||||||
{{if .PronounsAreCustom}}
|
|
||||||
{{ctx.Locale.Tr "settings.pronouns_custom"}}
|
|
||||||
{{else if eq "" .SignedUser.Pronouns}}
|
|
||||||
{{ctx.Locale.Tr "settings.pronouns_unspecified"}}
|
|
||||||
{{else}}
|
|
||||||
{{.SignedUser.Pronouns}}
|
|
||||||
{{end}}
|
|
||||||
</div>
|
|
||||||
{{svg "octicon-triangle-down" 14 "dropdown icon"}}
|
|
||||||
<div class="menu">
|
|
||||||
<div class="item{{if eq "" .SignedUser.Pronouns}} active selected{{end}}" data-value=""><p>{{ctx.Locale.Tr "settings.pronouns_unspecified"}}</p></div>
|
|
||||||
<div class="item{{if eq "he/him" .SignedUser.Pronouns}} active selected{{end}}" data-value="he/him">he/him</div>
|
|
||||||
<div class="item{{if eq "she/her" .SignedUser.Pronouns}} active selected{{end}}" data-value="she/her">she/her</div>
|
|
||||||
<div class="item{{if eq "they/them" .SignedUser.Pronouns}} active selected{{end}}" data-value="they/them">they/them</div>
|
|
||||||
<div class="item{{if eq "it/its" .SignedUser.Pronouns}} active selected{{end}}" data-value="it/its">it/its</div>
|
|
||||||
<div class="item{{if eq "any pronouns" .SignedUser.Pronouns}} active selected{{end}}" data-value="any pronouns">any pronouns</div>
|
|
||||||
{{if .PronounsAreCustom}}
|
|
||||||
<div class="item active selected" data-value="{{.SignedUser.Pronouns}}">{{ctx.Locale.Tr "settings.pronouns_custom"}}</div>
|
|
||||||
{{else}}
|
|
||||||
<div class="item" data-value="!"><i>{{ctx.Locale.Tr "settings.pronouns_custom"}}</i></div>
|
|
||||||
{{end}}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</label>
|
|
||||||
<label id="label-pronouns-custom">
|
<label id="label-pronouns-custom">
|
||||||
{{ctx.Locale.Tr "settings.pronouns_custom_label"}}
|
{{ctx.Locale.Tr "settings.pronouns"}}
|
||||||
<input name="pronouns" value="{{.SignedUser.Pronouns}}" maxlength="50">
|
<input name="pronouns" value="{{.SignedUser.Pronouns}}" maxlength="50" placeholder="{{ctx.Locale.Tr "settings.pronouns_unspecified"}}">
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
<label {{if .Err_Biography}}class="field error"{{end}}>
|
<label {{if .Err_Biography}}class="field error"{{end}}>
|
||||||
|
|
|
@ -1,50 +1 @@
|
||||||
import {hideElem, showElem} from '../utils/dom.js';
|
export function initUserSettings() {}
|
||||||
|
|
||||||
function onPronounsDropdownUpdate() {
|
|
||||||
const pronounsCustom = document.getElementById('label-pronouns-custom');
|
|
||||||
const pronounsCustomInput = pronounsCustom.querySelector('input');
|
|
||||||
const pronounsDropdown = document.getElementById('pronouns-dropdown');
|
|
||||||
const pronounsInput = pronounsDropdown.querySelector('input');
|
|
||||||
// must be kept in sync with `routers/web/user/setting/profile.go`
|
|
||||||
const isCustom = !(
|
|
||||||
pronounsInput.value === '' ||
|
|
||||||
pronounsInput.value === 'he/him' ||
|
|
||||||
pronounsInput.value === 'she/her' ||
|
|
||||||
pronounsInput.value === 'they/them' ||
|
|
||||||
pronounsInput.value === 'it/its' ||
|
|
||||||
pronounsInput.value === 'any pronouns'
|
|
||||||
);
|
|
||||||
if (isCustom) {
|
|
||||||
if (pronounsInput.value === '!') {
|
|
||||||
pronounsCustomInput.value = '';
|
|
||||||
} else {
|
|
||||||
pronounsCustomInput.value = pronounsInput.value;
|
|
||||||
}
|
|
||||||
showElem(pronounsCustom);
|
|
||||||
} else {
|
|
||||||
hideElem(pronounsCustom);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
function onPronounsCustomUpdate() {
|
|
||||||
const pronounsCustomInput = document.querySelector('#label-pronouns-custom input');
|
|
||||||
const pronounsInput = document.querySelector('#pronouns-dropdown input');
|
|
||||||
pronounsInput.value = pronounsCustomInput.value;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function initUserSettings() {
|
|
||||||
if (!document.querySelectorAll('.user.settings.profile').length) return;
|
|
||||||
|
|
||||||
const pronounsDropdown = document.getElementById('label-pronouns');
|
|
||||||
const pronounsCustomInput = document.querySelector('#label-pronouns-custom input');
|
|
||||||
const pronounsInput = pronounsDropdown.querySelector('input');
|
|
||||||
|
|
||||||
// If JS is disabled, the page will show the custom input, as the dropdown requires JS to work.
|
|
||||||
// JS progressively enhances the input by adding a dropdown, but it works regardless.
|
|
||||||
pronounsCustomInput.removeAttribute('name');
|
|
||||||
pronounsInput.setAttribute('name', 'pronouns');
|
|
||||||
showElem(pronounsDropdown);
|
|
||||||
|
|
||||||
onPronounsDropdownUpdate();
|
|
||||||
pronounsInput.addEventListener('change', onPronounsDropdownUpdate);
|
|
||||||
pronounsCustomInput.addEventListener('input', onPronounsCustomUpdate);
|
|
||||||
}
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue