settings_show.go 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
  2. // SPDX-License-Identifier: Apache-2.0
  3. package ui // import "miniflux.app/v2/internal/ui"
  4. import (
  5. "net/http"
  6. "miniflux.app/v2/internal/http/request"
  7. "miniflux.app/v2/internal/http/response/html"
  8. "miniflux.app/v2/internal/locale"
  9. "miniflux.app/v2/internal/model"
  10. "miniflux.app/v2/internal/ui/form"
  11. "miniflux.app/v2/internal/ui/session"
  12. "miniflux.app/v2/internal/ui/view"
  13. )
  14. func (h *handler) showSettingsPage(w http.ResponseWriter, r *http.Request) {
  15. user, err := h.store.UserByID(request.UserID(r))
  16. if err != nil {
  17. html.ServerError(w, r, err)
  18. return
  19. }
  20. settingsForm := form.SettingsForm{
  21. Username: user.Username,
  22. Theme: user.Theme,
  23. Language: user.Language,
  24. Timezone: user.Timezone,
  25. EntryDirection: user.EntryDirection,
  26. EntryOrder: user.EntryOrder,
  27. EntriesPerPage: user.EntriesPerPage,
  28. KeyboardShortcuts: user.KeyboardShortcuts,
  29. ShowReadingTime: user.ShowReadingTime,
  30. CustomCSS: user.Stylesheet,
  31. CustomJS: user.CustomJS,
  32. ExternalFontHosts: user.ExternalFontHosts,
  33. EntrySwipe: user.EntrySwipe,
  34. GestureNav: user.GestureNav,
  35. DisplayMode: user.DisplayMode,
  36. DefaultReadingSpeed: user.DefaultReadingSpeed,
  37. CJKReadingSpeed: user.CJKReadingSpeed,
  38. DefaultHomePage: user.DefaultHomePage,
  39. CategoriesSortingOrder: user.CategoriesSortingOrder,
  40. MarkReadBehavior: form.MarkAsReadBehavior(user.MarkReadOnView, user.MarkReadOnMediaPlayerCompletion),
  41. MediaPlaybackRate: user.MediaPlaybackRate,
  42. BlockFilterEntryRules: user.BlockFilterEntryRules,
  43. KeepFilterEntryRules: user.KeepFilterEntryRules,
  44. }
  45. timezones, err := h.store.Timezones()
  46. if err != nil {
  47. html.ServerError(w, r, err)
  48. return
  49. }
  50. creds, err := h.store.WebAuthnCredentialsByUserID(user.ID)
  51. if err != nil {
  52. html.ServerError(w, r, err)
  53. return
  54. }
  55. sess := session.New(h.store, request.SessionID(r))
  56. view := view.New(h.tpl, r, sess)
  57. view.Set("form", settingsForm)
  58. // In order to keep the continuity between form and model, I pass adhoc constants to the view
  59. view.Set("const", map[string]interface{}{
  60. "NoAutoMarkAsRead": form.NoAutoMarkAsRead,
  61. "MarkAsReadOnView": form.MarkAsReadOnView,
  62. "MarkAsReadOnViewButWaitForPlayerCompletion": form.MarkAsReadOnViewButWaitForPlayerCompletion,
  63. "MarkAsReadOnlyOnPlayerCompletion": form.MarkAsReadOnlyOnPlayerCompletion,
  64. })
  65. view.Set("themes", model.Themes())
  66. view.Set("languages", locale.AvailableLanguages())
  67. view.Set("timezones", timezones)
  68. view.Set("menu", "settings")
  69. view.Set("user", user)
  70. view.Set("countUnread", h.store.CountUnreadEntries(user.ID))
  71. view.Set("countErrorFeeds", h.store.CountUserFeedsWithErrors(user.ID))
  72. view.Set("default_home_pages", model.HomePages())
  73. view.Set("categories_sorting_options", model.CategoriesSortingOptions())
  74. view.Set("countWebAuthnCerts", h.store.CountWebAuthnCredentialsByUserID(user.ID))
  75. view.Set("webAuthnCerts", creds)
  76. html.OK(w, r, view.Render("settings"))
  77. }