mirror of
https://github.com/BookStackApp/BookStack.git
synced 2024-11-22 09:18:23 +08:00
Added env option for setting dark mode default
Also allowed config-centralised default user settings for this change and bought existing user-level view options into that default settings system to be cleaner in code usage. For #2081
This commit is contained in:
parent
af032f8993
commit
b0f4500c34
|
@ -246,11 +246,15 @@ AVATAR_URL=
|
||||||
DRAWIO=true
|
DRAWIO=true
|
||||||
|
|
||||||
# Default item listing view
|
# Default item listing view
|
||||||
# Used for public visitors and user's without a preference
|
# Used for public visitors and user's without a preference.
|
||||||
# Can be 'list' or 'grid'
|
# Can be 'list' or 'grid'.
|
||||||
APP_VIEWS_BOOKS=list
|
APP_VIEWS_BOOKS=list
|
||||||
APP_VIEWS_BOOKSHELVES=grid
|
APP_VIEWS_BOOKSHELVES=grid
|
||||||
|
|
||||||
|
# Use dark mode by default
|
||||||
|
# Will be overriden by any user/session preference.
|
||||||
|
APP_DEFAULT_DARK_MODE=false
|
||||||
|
|
||||||
# Page revision limit
|
# Page revision limit
|
||||||
# Number of page revisions to keep in the system before deleting old revisions.
|
# Number of page revisions to keep in the system before deleting old revisions.
|
||||||
# If set to 'false' a limit will not be enforced.
|
# If set to 'false' a limit will not be enforced.
|
||||||
|
|
|
@ -19,13 +19,6 @@ return [
|
||||||
// private configuration variables so should remain disabled in public.
|
// private configuration variables so should remain disabled in public.
|
||||||
'debug' => env('APP_DEBUG', false),
|
'debug' => env('APP_DEBUG', false),
|
||||||
|
|
||||||
// Set the default view type for various lists. Can be overridden by user preferences.
|
|
||||||
// These will be used for public viewers and users that have not set a preference.
|
|
||||||
'views' => [
|
|
||||||
'books' => env('APP_VIEWS_BOOKS', 'list'),
|
|
||||||
'bookshelves' => env('APP_VIEWS_BOOKSHELVES', 'grid'),
|
|
||||||
],
|
|
||||||
|
|
||||||
// The number of revisions to keep in the database.
|
// The number of revisions to keep in the database.
|
||||||
// Once this limit is reached older revisions will be deleted.
|
// Once this limit is reached older revisions will be deleted.
|
||||||
// If set to false then a limit will not be enforced.
|
// If set to false then a limit will not be enforced.
|
||||||
|
|
|
@ -24,4 +24,11 @@ return [
|
||||||
'app-custom-head' => false,
|
'app-custom-head' => false,
|
||||||
'registration-enabled' => false,
|
'registration-enabled' => false,
|
||||||
|
|
||||||
|
// User-level default settings
|
||||||
|
'user' => [
|
||||||
|
'dark-mode-enabled' => env('APP_DEFAULT_DARK_MODE', false),
|
||||||
|
'bookshelves_view_type' => env('APP_VIEWS_BOOKSHELVES', 'grid'),
|
||||||
|
'books_view_type' => env('APP_VIEWS_BOOKS', 'grid'),
|
||||||
|
],
|
||||||
|
|
||||||
];
|
];
|
||||||
|
|
|
@ -30,7 +30,7 @@ class BookController extends Controller
|
||||||
*/
|
*/
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$view = setting()->getForCurrentUser('books_view_type', config('app.views.books'));
|
$view = setting()->getForCurrentUser('books_view_type');
|
||||||
$sort = setting()->getForCurrentUser('books_sort', 'name');
|
$sort = setting()->getForCurrentUser('books_sort', 'name');
|
||||||
$order = setting()->getForCurrentUser('books_sort_order', 'asc');
|
$order = setting()->getForCurrentUser('books_sort_order', 'asc');
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,7 @@ class BookshelfController extends Controller
|
||||||
*/
|
*/
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$view = setting()->getForCurrentUser('bookshelves_view_type', config('app.views.bookshelves', 'grid'));
|
$view = setting()->getForCurrentUser('bookshelves_view_type');
|
||||||
$sort = setting()->getForCurrentUser('bookshelves_sort', 'name');
|
$sort = setting()->getForCurrentUser('bookshelves_sort', 'name');
|
||||||
$order = setting()->getForCurrentUser('bookshelves_sort_order', 'asc');
|
$order = setting()->getForCurrentUser('bookshelves_sort_order', 'asc');
|
||||||
$sortOptions = [
|
$sortOptions = [
|
||||||
|
@ -103,7 +103,7 @@ class BookshelfController extends Controller
|
||||||
|
|
||||||
Views::add($shelf);
|
Views::add($shelf);
|
||||||
$this->entityContextManager->setShelfContext($shelf->id);
|
$this->entityContextManager->setShelfContext($shelf->id);
|
||||||
$view = setting()->getForCurrentUser('bookshelf_view_type', config('app.views.books'));
|
$view = setting()->getForCurrentUser('bookshelf_view_type');
|
||||||
|
|
||||||
$this->setPageTitle($shelf->getShortName());
|
$this->setPageTitle($shelf->getShortName());
|
||||||
return view('shelves.show', [
|
return view('shelves.show', [
|
||||||
|
|
|
@ -56,7 +56,7 @@ class HomeController extends Controller
|
||||||
// Add required list ordering & sorting for books & shelves views.
|
// Add required list ordering & sorting for books & shelves views.
|
||||||
if ($homepageOption === 'bookshelves' || $homepageOption === 'books') {
|
if ($homepageOption === 'bookshelves' || $homepageOption === 'books') {
|
||||||
$key = $homepageOption;
|
$key = $homepageOption;
|
||||||
$view = setting()->getForCurrentUser($key . '_view_type', config('app.views.' . $key));
|
$view = setting()->getForCurrentUser($key . '_view_type');
|
||||||
$sort = setting()->getForCurrentUser($key . '_sort', 'name');
|
$sort = setting()->getForCurrentUser($key . '_sort', 'name');
|
||||||
$order = setting()->getForCurrentUser($key . '_sort_order', 'asc');
|
$order = setting()->getForCurrentUser($key . '_sort_order', 'asc');
|
||||||
|
|
||||||
|
|
|
@ -29,9 +29,9 @@ class SettingService
|
||||||
* Gets a setting from the database,
|
* Gets a setting from the database,
|
||||||
* If not found, Returns default, Which is false by default.
|
* If not found, Returns default, Which is false by default.
|
||||||
*/
|
*/
|
||||||
public function get(string $key, $default = false)
|
public function get(string $key, $default = null)
|
||||||
{
|
{
|
||||||
if ($default === false) {
|
if (is_null($default)) {
|
||||||
$default = config('setting-defaults.' . $key, false);
|
$default = config('setting-defaults.' . $key, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,8 +57,12 @@ class SettingService
|
||||||
/**
|
/**
|
||||||
* Get a user-specific setting from the database or cache.
|
* Get a user-specific setting from the database or cache.
|
||||||
*/
|
*/
|
||||||
public function getUser(User $user, string $key, $default = false)
|
public function getUser(User $user, string $key, $default = null)
|
||||||
{
|
{
|
||||||
|
if (is_null($default)) {
|
||||||
|
$default = config('setting-defaults.user.' . $key, false);
|
||||||
|
}
|
||||||
|
|
||||||
if ($user->isDefault()) {
|
if ($user->isDefault()) {
|
||||||
return $this->getFromSession($key, $default);
|
return $this->getFromSession($key, $default);
|
||||||
}
|
}
|
||||||
|
@ -68,7 +72,7 @@ class SettingService
|
||||||
/**
|
/**
|
||||||
* Get a value for the current logged-in user.
|
* Get a value for the current logged-in user.
|
||||||
*/
|
*/
|
||||||
public function getForCurrentUser(string $key, $default = false)
|
public function getForCurrentUser(string $key, $default = null)
|
||||||
{
|
{
|
||||||
return $this->getUser(user(), $key, $default);
|
return $this->getUser(user(), $key, $default);
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,5 +57,6 @@
|
||||||
<server name="LOG_FAILED_LOGIN_MESSAGE" value=""/>
|
<server name="LOG_FAILED_LOGIN_MESSAGE" value=""/>
|
||||||
<server name="LOG_FAILED_LOGIN_CHANNEL" value="testing"/>
|
<server name="LOG_FAILED_LOGIN_CHANNEL" value="testing"/>
|
||||||
<server name="WKHTMLTOPDF" value="false"/>
|
<server name="WKHTMLTOPDF" value="false"/>
|
||||||
|
<server name="APP_DEFAULT_DARK_MODE" value="false"/>
|
||||||
</php>
|
</php>
|
||||||
</phpunit>
|
</phpunit>
|
||||||
|
|
|
@ -25,7 +25,6 @@ body {
|
||||||
line-height: 1.6;
|
line-height: 1.6;
|
||||||
@include lightDark(color, #444, #AAA);
|
@include lightDark(color, #444, #AAA);
|
||||||
-webkit-font-smoothing: antialiased;
|
-webkit-font-smoothing: antialiased;
|
||||||
background-color: #F2F2F2;
|
|
||||||
height: 100%;
|
height: 100%;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
|
|
|
@ -59,7 +59,7 @@ class BookShelfTest extends TestCase
|
||||||
public function test_book_not_visible_in_shelf_list_view_if_user_cant_view_shelf()
|
public function test_book_not_visible_in_shelf_list_view_if_user_cant_view_shelf()
|
||||||
{
|
{
|
||||||
config()->set([
|
config()->set([
|
||||||
'app.views.bookshelves' => 'list',
|
'setting-defaults.user.bookshelves_view_type' => 'list',
|
||||||
]);
|
]);
|
||||||
$shelf = Bookshelf::query()->first();
|
$shelf = Bookshelf::query()->first();
|
||||||
$book = $shelf->books()->first();
|
$book = $shelf->books()->first();
|
||||||
|
|
|
@ -92,4 +92,17 @@ class UserPreferencesTest extends TestCase
|
||||||
$home->assertDontSee('Dark Mode');
|
$home->assertDontSee('Dark Mode');
|
||||||
$home->assertSee('Light Mode');
|
$home->assertSee('Light Mode');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function test_dark_mode_defaults_to_config_option()
|
||||||
|
{
|
||||||
|
config()->set('setting-defaults.user.dark-mode-enabled', false);
|
||||||
|
$this->assertEquals(false, setting()->getForCurrentUser('dark-mode-enabled'));
|
||||||
|
$home = $this->get('/login');
|
||||||
|
$home->assertElementNotExists('.dark-mode');
|
||||||
|
|
||||||
|
config()->set('setting-defaults.user.dark-mode-enabled', true);
|
||||||
|
$this->assertEquals(true, setting()->getForCurrentUser('dark-mode-enabled'));
|
||||||
|
$home = $this->get('/login');
|
||||||
|
$home->assertElementExists('.dark-mode');
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user