mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-05-24 02:42:02 +00:00

# Description This pull request includes several changes aimed at improving the code structure and removing redundant code. The most significant changes involve reordering methods, removing unnecessary annotations, and refactoring constructors to use dependency injection. Autowired now comes via constructor (which also doesn't need autowired annotation as its done by default for configuration) ## Checklist - [ ] I have read the [Contribution Guidelines](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/CONTRIBUTING.md) - [ ] I have performed a self-review of my own code - [ ] I have attached images of the change if it is UI based - [ ] I have commented my code, particularly in hard-to-understand areas - [ ] If my code has heavily changed functionality I have updated relevant docs on [Stirling-PDFs doc repo](https://github.com/Stirling-Tools/Stirling-Tools.github.io/blob/main/docs/) - [ ] My changes generate no new warnings - [ ] 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)
65 lines
2.5 KiB
Java
65 lines
2.5 KiB
Java
package stirling.software.SPDF.controller.api;
|
|
|
|
import java.io.IOException;
|
|
import java.io.PrintWriter;
|
|
import java.util.List;
|
|
|
|
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 stirling.software.SPDF.service.LanguageService;
|
|
|
|
@RestController
|
|
@RequestMapping("/js")
|
|
public class AdditionalLanguageJsController {
|
|
|
|
private final LanguageService languageService;
|
|
|
|
public AdditionalLanguageJsController(LanguageService languageService) {
|
|
this.languageService = languageService;
|
|
}
|
|
|
|
@Hidden
|
|
@GetMapping(value = "/additionalLanguageCode.js", produces = "application/javascript")
|
|
public void generateAdditionalLanguageJs(HttpServletResponse response) throws IOException {
|
|
List<String> supportedLanguages = languageService.getSupportedLanguages();
|
|
response.setContentType("application/javascript");
|
|
PrintWriter writer = response.getWriter();
|
|
// Erstelle das JavaScript dynamisch
|
|
writer.println("const supportedLanguages = " + toJsonArray(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();
|
|
}
|
|
}
|