mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-06-23 16:05:09 +00:00

# Description of Changes - **What was changed:** - Removed explicit constructor definitions annotated with `@Autowired` across services, controllers, filters, and schedulers. - Added Lombok’s `@RequiredArgsConstructor` to automatically generate required-args constructors and eliminate boilerplate. - Introduced other Lombok annotations (`@Data`, `@Getter`, `@Setter`, `@EqualsAndHashCode`, `@NoArgsConstructor`) on model and API classes to replace manual getters/setters and constructors. - Standardized string comparisons to use the constant-first form (e.g., `"value".equals(variable)`). - Cleaned up unused imports and organized OpenAPI configuration by extracting default title/description constants. - **Why the change was made:** - To reduce repetitive boilerplate code and improve maintainability. - To leverage Lombok for cleaner, more consistent dependency injection and data modeling. - To ensure a uniform coding style across the entire codebase. #3406 --- ## Checklist ### General - [x] I have read the [Contribution Guidelines](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/CONTRIBUTING.md) - [ ] I have read the [Stirling-PDF Developer Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/DeveloperGuide.md) (if applicable) - [ ] I have read the [How to add new languages to Stirling-PDF](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/HowToAddNewLanguage.md) (if applicable) - [x] I have performed a self-review of my own code - [x] My changes generate no new warnings ### Documentation - [ ] I have updated relevant docs on [Stirling-PDF's doc repo](https://github.com/Stirling-Tools/Stirling-Tools.github.io/blob/main/docs/) (if functionality has heavily changed) - [ ] I have read the section [Add New Translation Tags](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/HowToAddNewLanguage.md#add-new-translation-tags) (for new translation tags only) ### UI Changes (if applicable) - [ ] Screenshots or videos demonstrating the UI changes are attached ### Testing (if applicable) - [ ] I have tested my changes locally. Refer to the [Testing Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/DeveloperGuide.md#6-testing) for more details.
70 lines
2.6 KiB
Java
70 lines
2.6 KiB
Java
package stirling.software.SPDF.controller.api;
|
|
|
|
import java.io.IOException;
|
|
import java.io.PrintWriter;
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
import java.util.Set;
|
|
|
|
import org.springframework.web.bind.annotation.GetMapping;
|
|
import org.springframework.web.bind.annotation.RequestMapping;
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
|
|
import io.swagger.v3.oas.annotations.Hidden;
|
|
|
|
import jakarta.servlet.http.HttpServletResponse;
|
|
|
|
import lombok.RequiredArgsConstructor;
|
|
|
|
import stirling.software.SPDF.service.LanguageService;
|
|
|
|
@RestController
|
|
@RequestMapping("/js")
|
|
@RequiredArgsConstructor
|
|
public class AdditionalLanguageJsController {
|
|
|
|
private final LanguageService languageService;
|
|
|
|
@Hidden
|
|
@GetMapping(value = "/additionalLanguageCode.js", produces = "application/javascript")
|
|
public void generateAdditionalLanguageJs(HttpServletResponse response) throws IOException {
|
|
Set<String> supportedLanguages = languageService.getSupportedLanguages();
|
|
response.setContentType("application/javascript");
|
|
PrintWriter writer = response.getWriter();
|
|
// Erstelle das JavaScript dynamisch
|
|
writer.println(
|
|
"const supportedLanguages = "
|
|
+ toJsonArray(new ArrayList<>(supportedLanguages))
|
|
+ ";");
|
|
// Generiere die `getDetailedLanguageCode`-Funktion
|
|
writer.println(
|
|
"""
|
|
function getDetailedLanguageCode() {
|
|
const userLanguages = navigator.languages ? navigator.languages : [navigator.language];
|
|
for (let lang of userLanguages) {
|
|
let matchedLang = supportedLanguages.find(supportedLang => supportedLang.startsWith(lang.replace('-', '_')));
|
|
if (matchedLang) {
|
|
return matchedLang;
|
|
}
|
|
}
|
|
// Fallback
|
|
return "en_GB";
|
|
}
|
|
""");
|
|
writer.flush();
|
|
}
|
|
|
|
// Hilfsfunktion zum Konvertieren der Liste in ein JSON-Array
|
|
private String toJsonArray(List<String> list) {
|
|
StringBuilder jsonArray = new StringBuilder("[");
|
|
for (int i = 0; i < list.size(); i++) {
|
|
jsonArray.append("\"").append(list.get(i)).append("\"");
|
|
if (i < list.size() - 1) {
|
|
jsonArray.append(",");
|
|
}
|
|
}
|
|
jsonArray.append("]");
|
|
return jsonArray.toString();
|
|
}
|
|
}
|