gtsocial-umbx

Unnamed repository; edit this file 'description' to name the repository.
Log | Files | Refs | README | LICENSE

commit b6143c9ab8bb2aac6517b9580bf72ebe485eb738
parent e824e14705ddc6cdb29b19f86893716f475520a0
Author: f0x52 <f0x@cthu.lu>
Date:   Mon, 20 Feb 2023 16:29:29 +0100

[feature] About page (#1495)

* about page basics

* more info, styling

* update emoji sizing on about page contact card
Diffstat:
Ainternal/web/about.go | 50++++++++++++++++++++++++++++++++++++++++++++++++++
Minternal/web/domain-blocklist.go | 2+-
Minternal/web/web.go | 1+
Mweb/source/css/base.css | 51+++++++++++++++++++++++++++++++++++++++++++++++++++
Aweb/template/about.tmpl | 86+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
5 files changed, 189 insertions(+), 1 deletion(-)

diff --git a/internal/web/about.go b/internal/web/about.go @@ -0,0 +1,50 @@ +/* + GoToSocial + Copyright (C) 2021-2023 GoToSocial Authors admin@gotosocial.org + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +package web + +import ( + "net/http" + + "github.com/gin-gonic/gin" + apiutil "github.com/superseriousbusiness/gotosocial/internal/api/util" + "github.com/superseriousbusiness/gotosocial/internal/config" + "github.com/superseriousbusiness/gotosocial/internal/gtserror" +) + +const ( + aboutPath = "/about" +) + +func (m *Module) aboutGETHandler(c *gin.Context) { + instance, err := m.processor.InstanceGetV1(c.Request.Context()) + if err != nil { + apiutil.ErrorHandler(c, gtserror.NewErrorInternalError(err), m.processor.InstanceGetV1) + return + } + + c.HTML(http.StatusOK, "about.tmpl", gin.H{ + "instance": instance, + "ogMeta": ogBase(instance), + "blocklistExposed": config.GetInstanceExposeSuspendedWeb(), + "stylesheets": []string{ + assetsPathPrefix + "/Fork-Awesome/css/fork-awesome.min.css", + }, + "javascript": []string{distPathPrefix + "/frontend.js"}, + }) +} diff --git a/internal/web/domain-blocklist.go b/internal/web/domain-blocklist.go @@ -30,7 +30,7 @@ import ( ) const ( - domainBlockListPath = "/about/suspended" + domainBlockListPath = aboutPath + "/suspended" ) func (m *Module) domainBlockListGETHandler(c *gin.Context) { diff --git a/internal/web/web.go b/internal/web/web.go @@ -104,6 +104,7 @@ func (m *Module) Route(r router.Router, mi ...gin.HandlerFunc) { r.AttachHandler(http.MethodGet, rssFeedPath, m.rssFeedGETHandler) r.AttachHandler(http.MethodGet, confirmEmailPath, m.confirmEmailGETHandler) r.AttachHandler(http.MethodGet, robotsPath, m.robotsGETHandler) + r.AttachHandler(http.MethodGet, aboutPath, m.aboutGETHandler) r.AttachHandler(http.MethodGet, domainBlockListPath, m.domainBlockListGETHandler) // Attach redirects from old endpoints to current ones for backwards compatibility diff --git a/web/source/css/base.css b/web/source/css/base.css @@ -502,6 +502,57 @@ label { } } +.about { + display: flex; + flex-direction: column; + gap: 1rem; + + h2 { + margin: 0.5rem 0; + } + + ul { + margin-bottom: 0; + } + + .contact-account-card { + /* display: inline-grid; + grid-template-columns: 4rem auto; + grid-template-rows: 4rem; + gap: 1rem; + padding: 0.5rem; */ + display: inline-grid; + grid-template-columns: auto 1fr; + grid-template-rows: auto auto; + text-decoration: none; + gap: 0.5rem 1rem; + border-radius: $br; + padding: 0.5rem; + min-width: 40%; + margin-bottom: 0.3rem; + + background: $list-entry-bg; + + &:hover { + background: $list-entry-alternate-bg; + } + + h3 { + align-self: end; + margin: 0; + color: $fg; + } + + img.avatar { + border-radius: 0.5rem; + width: 5rem; + height: 5rem; + object-fit: cover; + grid-row: 1 / span 2; + } + } +} + @media screen and (max-width: 30rem) { .domain-blocklist .entry { grid-template-columns: 1fr; diff --git a/web/template/about.tmpl b/web/template/about.tmpl @@ -0,0 +1,85 @@ +{{- /* + GoToSocial + Copyright (C) 2021-2023 GoToSocial Authors admin@gotosocial.org + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ -}} + +{{ template "header.tmpl" .}} +<main> + <section class="about"> + <h1>About</h1> + <div> + {{.instance.Description |noescape}} + </div> + + <div> + <h2>Admin Contact</h2> + {{if .instance.ContactAccount}} + <a href="{{.instance.ContactAccount.URL}}" class="contact-account-card"> + <img class="avatar" src="{{.instance.ContactAccount.Avatar}}" alt="" /> + <h3> + {{if .instance.ContactAccount.DisplayName}}{{emojify .instance.ContactAccount.Emojis (escape .instance.ContactAccount.DisplayName)}}{{else}}{{.instance.ContactAccount.Username}}{{end}} + </h3> + <span>@{{.instance.ContactAccount.Username}}</span> + </a><br /> + {{end}} + {{if .instance.Email}} + Email: <a href="mailto:{{.instance.Email}}">{{.instance.Email}}</a> + {{end}} + </div> + + <div> + <h2>Features</h2> + <ul> + <li> + Registration is + {{if .instance.Registrations}} + enabled{{if .instance.ApprovalRequired}}, but requires admin approval{{end}}. + {{else}} + disabled. + {{end}} + </li> + {{if .instance.Configuration.Accounts.AllowCustomCSS}} + <li> + Users are allowed to set <a href="https://docs.gotosocial.org/en/latest/user_guide/custom_css/" + target="_blank" rel="noopener noreferrer">Custom CSS</a> for their profiles. + </li> + {{end}} + <li> + Toots can contain up to {{.instance.Configuration.Statuses.MaxCharacters}} characters and + {{.instance.Configuration.Statuses.MaxMediaAttachments}} media attachments. + </li> + <li> + Polls can have up to {{.instance.Configuration.Polls.MaxOptions}} options, with + {{.instance.Configuration.Polls.MaxCharactersPerOption}} characters each. + </li> + </ul> + </div> + <div> + <h2>Moderated servers</h2> + <p> + ActivityPub instances exchange (federate) data with other servers, including accounts and toots. + This can be prevented for specific domains by suspending them. None of their content is stored, + and interaction with their users is blocked both ways.</br> + {{if .blocklistExposed}} + <a href="/about/suspended">View the list of suspended domains</a> + {{else}} + This instance does not publically share this list. + {{end}} + </p> + </div> + </section> +</main> +{{ template "footer.tmpl" .}} +\ No newline at end of file