fix: adds download preference to form
This commit is contained in:
@@ -90,7 +90,14 @@ class SeedDatabaseCommand extends Command
|
|||||||
'description' => null,
|
'description' => null,
|
||||||
'enabled' => true,
|
'enabled' => true,
|
||||||
'type' => 'media',
|
'type' => 'media',
|
||||||
]
|
],
|
||||||
|
[
|
||||||
|
'id' => 'movie_folder',
|
||||||
|
'name' => 'Create new folder for Movies',
|
||||||
|
'description' => 'When downloading a movie, store it in a new folder in your base \'movies\' folder. (e.g.: .../movies/Inception/Inception.2160p.h265.mkv)',
|
||||||
|
'enabled' => true,
|
||||||
|
'type' => 'download'
|
||||||
|
],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -32,6 +32,7 @@ class PreferencesController extends AbstractController
|
|||||||
public function mediaPreferences(): Response
|
public function mediaPreferences(): Response
|
||||||
{
|
{
|
||||||
$mediaPreferences = $this->getUser()->getMediaPreferences();
|
$mediaPreferences = $this->getUser()->getMediaPreferences();
|
||||||
|
$downloadPreferences = $this->getUser()->getDownloadPreferences();
|
||||||
$languages = CountryLanguages::$languages;
|
$languages = CountryLanguages::$languages;
|
||||||
sort($languages);
|
sort($languages);
|
||||||
|
|
||||||
@@ -42,6 +43,7 @@ class PreferencesController extends AbstractController
|
|||||||
'languages' => $languages,
|
'languages' => $languages,
|
||||||
'providers' => ProviderList::$providers,
|
'providers' => ProviderList::$providers,
|
||||||
'mediaPreferences' => $mediaPreferences,
|
'mediaPreferences' => $mediaPreferences,
|
||||||
|
'downloadPreferences' => $downloadPreferences,
|
||||||
]
|
]
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -77,4 +79,36 @@ class PreferencesController extends AbstractController
|
|||||||
]
|
]
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[Route('/user/preferences/download', 'app_save_download_preferences', methods: ['POST'])]
|
||||||
|
public function saveDownloadPreferences(
|
||||||
|
Request $request,
|
||||||
|
SaveUserMediaPreferencesInput $input,
|
||||||
|
): Response
|
||||||
|
{
|
||||||
|
$userPreferences = $this->saveUserMediaPreferencesHandler->handle($input->toCommand())->userPreferences;
|
||||||
|
$userPreferences = Map::from($userPreferences)->rekey(fn($preference) => $preference->getPreference()->getId());
|
||||||
|
|
||||||
|
$languages = CountryLanguages::$languages;
|
||||||
|
sort($languages);
|
||||||
|
|
||||||
|
$this->hub->publish(new Update(
|
||||||
|
$request->getSession()->get('mercure_alert_topic'),
|
||||||
|
$this->renderView('broadcast/Alert.stream.html.twig', [
|
||||||
|
'alert_id' => uniqid(),
|
||||||
|
'title' => 'Success',
|
||||||
|
'message' => 'Your media preferences have been saved.',
|
||||||
|
])
|
||||||
|
));
|
||||||
|
|
||||||
|
return $this->render(
|
||||||
|
'user/preferences.html.twig',
|
||||||
|
[
|
||||||
|
'preferences' => $this->preferencesRepository->findEnabled(),
|
||||||
|
'languages' => $languages,
|
||||||
|
'providers' => ProviderList::$providers,
|
||||||
|
'userPreferences' => $userPreferences->toArray(),
|
||||||
|
]
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -281,6 +281,15 @@ class User implements UserInterface, PasswordAuthenticatedUserInterface
|
|||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getDownloadPreferences()
|
||||||
|
{
|
||||||
|
return Map::from($this->userPreferences)
|
||||||
|
->rekey(fn(UserPreference $userPreference) => $userPreference->getPreference()->getId())
|
||||||
|
->filter(fn(UserPreference $userPreference) => $userPreference->getPreference()->getType() === 'download')
|
||||||
|
->toArray()
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return Collection<int, Download>
|
* @return Collection<int, Download>
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -3,9 +3,9 @@
|
|||||||
{% block h2 %}Preferences{% endblock %}
|
{% block h2 %}Preferences{% endblock %}
|
||||||
|
|
||||||
{% block body %}
|
{% block body %}
|
||||||
<div class="p-4 flex flex-col">
|
<div class="p-4 flex flex-row gap-2">
|
||||||
<twig:Card title="Choose your preferences">
|
<twig:Card title="Media Preferences" class="w-full">
|
||||||
<p class="text-gray-50 mb-2">Define a set of filters to apply to your media download option results.</p>
|
<p class="text-gray-50 mb-2">Define a filter to be pre-applied to your download options.</p>
|
||||||
<form id="media_preferences" class="flex flex-col max-w-64" name="media_preferences" method="post" action="{{ path('app_save_media_preferences') }}">
|
<form id="media_preferences" class="flex flex-col max-w-64" name="media_preferences" method="post" action="{{ path('app_save_media_preferences') }}">
|
||||||
<label class="text-gray-50" for="resolution">Resolution</label>
|
<label class="text-gray-50" for="resolution">Resolution</label>
|
||||||
<select class="p-1.5 rounded-md mb-2" name="resolution" id="resolution" value="{{ mediaPreferences['resolution'].getPreferenceValue() }}">
|
<select class="p-1.5 rounded-md mb-2" name="resolution" id="resolution" value="{{ mediaPreferences['resolution'].getPreferenceValue() }}">
|
||||||
@@ -63,10 +63,18 @@
|
|||||||
>{{ language }}</option>
|
>{{ language }}</option>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
|
|
||||||
<button class="px-1.5 py-1 max-w-20 rounded-md bg-green-600 text-white" type="submit">Submit</button>
|
<button class="px-1.5 py-1 max-w-20 rounded-md bg-green-600 text-white" type="submit">Submit</button>
|
||||||
</form>
|
</form>
|
||||||
</twig:Card>
|
</twig:Card>
|
||||||
|
|
||||||
|
<twig:Card title="Download Preferences" class="w-full">
|
||||||
|
<p class="text-gray-50 mb-2">Change how your downloads are stored.</p>
|
||||||
|
<form id="media_preferences" class="flex flex-col" name="media_preferences" method="post" action="{{ path('app_save_download_preferences') }}">
|
||||||
|
<div class="flex flex-row gap-2">
|
||||||
|
<input type="checkbox" name="movie_folder" id="movie_folder" {{ downloadPreferences['movie_folder'].getPreferenceValue() == true ? 'checked' }} />
|
||||||
|
<label class="text-gray-50" for="movie_folder">Store movies in a new directory?</label>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</twig:Card>
|
||||||
</div>
|
</div>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
Reference in New Issue
Block a user