demo web application

This commit is contained in:
Kathrine Simakov 2026-03-16 12:19:11 +11:00
commit 6022de3575
28 changed files with 931 additions and 0 deletions

10
.idea/.gitignore generated vendored Normal file
View File

@ -0,0 +1,10 @@
# Default ignored files
/shelf/
/workspace.xml
# Ignored default folder with query files
/queries/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml
# Editor-based HTTP Client requests
/httpRequests/

6
.idea/misc.xml generated Normal file
View File

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" project-jdk-name="openjdk-25" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

8
.idea/modules.xml generated Normal file
View File

@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/.idea/webbedsite.iml" filepath="$PROJECT_DIR$/.idea/webbedsite.iml" />
</modules>
</component>
</project>

6
.idea/vcs.xml generated Normal file
View File

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="" vcs="Git" />
</component>
</project>

9
.idea/webbedsite.iml generated Normal file
View File

@ -0,0 +1,9 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$" />
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

3
demo/.gitattributes vendored Normal file
View File

@ -0,0 +1,3 @@
/gradlew text eol=lf
*.bat text eol=crlf
*.jar binary

40
demo/.gitignore vendored Normal file
View File

@ -0,0 +1,40 @@
HELP.md
.gradle
build/
!gradle/wrapper/gradle-wrapper.jar
!**/src/main/**/build/
!**/src/test/**/build/
### STS ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
bin/
!**/src/main/**/bin/
!**/src/test/**/bin/
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
out/
!**/src/main/**/out/
!**/src/test/**/out/
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
### VS Code ###
.vscode/
### jte ###
/jte-classes/

49
demo/build.gradle Normal file
View File

@ -0,0 +1,49 @@
plugins {
id 'java'
id 'org.springframework.boot' version '4.0.3'
id 'io.spring.dependency-management' version '1.1.7'
id 'gg.jte.gradle' version '3.2.3'
}
group = 'com.example'
version = '0.0.1-SNAPSHOT'
description = 'Demo project for Spring Boot'
java {
toolchain {
languageVersion = JavaLanguageVersion.of(25)
}
}
repositories {
mavenCentral()
}
configurations {
compileOnly {
extendsFrom annotationProcessor
}
}
dependencies {
implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
implementation 'gg.jte:jte-spring-boot-starter-4:3.2.3'
implementation 'gg.jte:jte:3.2.3'
implementation 'org.springframework.boot:spring-boot-starter-webmvc'
runtimeOnly 'com.microsoft.sqlserver:mssql-jdbc'
testImplementation 'org.springframework.boot:spring-boot-starter-data-jpa-test'
testRuntimeOnly 'org.junit.platform:junit-platform-launcher'
annotationProcessor 'org.projectlombok:lombok'
compileOnly 'org.projectlombok:lombok'
}
jte {
generate()
binaryStaticContent = true
}
tasks.named('test') {
useJUnitPlatform()
}

BIN
demo/gradle/wrapper/gradle-wrapper.jar vendored Normal file

Binary file not shown.

View File

@ -0,0 +1,7 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-9.3.1-bin.zip
networkTimeout=10000
validateDistributionUrl=true
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists

248
demo/gradlew vendored Normal file
View File

@ -0,0 +1,248 @@
#!/bin/sh
#
# Copyright © 2015 the original authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# SPDX-License-Identifier: Apache-2.0
#
##############################################################################
#
# Gradle start up script for POSIX generated by Gradle.
#
# Important for running:
#
# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
# noncompliant, but you have some other compliant shell such as ksh or
# bash, then to run this script, type that shell name before the whole
# command line, like:
#
# ksh Gradle
#
# Busybox and similar reduced shells will NOT work, because this script
# requires all of these POSIX shell features:
# * functions;
# * expansions «$var», «${var}», «${var:-default}», «${var+SET}»,
# «${var#prefix}», «${var%suffix}», and «$( cmd )»;
# * compound commands having a testable exit status, especially «case»;
# * various built-in commands including «command», «set», and «ulimit».
#
# Important for patching:
#
# (2) This script targets any POSIX shell, so it avoids extensions provided
# by Bash, Ksh, etc; in particular arrays are avoided.
#
# The "traditional" practice of packing multiple parameters into a
# space-separated string is a well documented source of bugs and security
# problems, so this is (mostly) avoided, by progressively accumulating
# options in "$@", and eventually passing that to Java.
#
# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly;
# see the in-line comments for details.
#
# There are tweaks for specific operating systems such as AIX, CygWin,
# Darwin, MinGW, and NonStop.
#
# (3) This script is generated from the Groovy template
# https://github.com/gradle/gradle/blob/HEAD/platforms/jvm/plugins-application/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
# within the Gradle project.
#
# You can find Gradle at https://github.com/gradle/gradle/.
#
##############################################################################
# Attempt to set APP_HOME
# Resolve links: $0 may be a link
app_path=$0
# Need this for daisy-chained symlinks.
while
APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path
[ -h "$app_path" ]
do
ls=$( ls -ld "$app_path" )
link=${ls#*' -> '}
case $link in #(
/*) app_path=$link ;; #(
*) app_path=$APP_HOME$link ;;
esac
done
# This is normally unused
# shellcheck disable=SC2034
APP_BASE_NAME=${0##*/}
# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
APP_HOME=$( cd -P "${APP_HOME:-./}" > /dev/null && printf '%s\n' "$PWD" ) || exit
# Use the maximum available, or set MAX_FD != -1 to use that value.
MAX_FD=maximum
warn () {
echo "$*"
} >&2
die () {
echo
echo "$*"
echo
exit 1
} >&2
# OS specific support (must be 'true' or 'false').
cygwin=false
msys=false
darwin=false
nonstop=false
case "$( uname )" in #(
CYGWIN* ) cygwin=true ;; #(
Darwin* ) darwin=true ;; #(
MSYS* | MINGW* ) msys=true ;; #(
NONSTOP* ) nonstop=true ;;
esac
# Determine the Java command to use to start the JVM.
if [ -n "$JAVA_HOME" ] ; then
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
# IBM's JDK on AIX uses strange locations for the executables
JAVACMD=$JAVA_HOME/jre/sh/java
else
JAVACMD=$JAVA_HOME/bin/java
fi
if [ ! -x "$JAVACMD" ] ; then
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
else
JAVACMD=java
if ! command -v java >/dev/null 2>&1
then
die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
fi
# Increase the maximum file descriptors if we can.
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
case $MAX_FD in #(
max*)
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
# shellcheck disable=SC2039,SC3045
MAX_FD=$( ulimit -H -n ) ||
warn "Could not query maximum file descriptor limit"
esac
case $MAX_FD in #(
'' | soft) :;; #(
*)
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
# shellcheck disable=SC2039,SC3045
ulimit -n "$MAX_FD" ||
warn "Could not set maximum file descriptor limit to $MAX_FD"
esac
fi
# Collect all arguments for the java command, stacking in reverse order:
# * args from the command line
# * the main class name
# * -classpath
# * -D...appname settings
# * --module-path (only if needed)
# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables.
# For Cygwin or MSYS, switch paths to Windows format before running java
if "$cygwin" || "$msys" ; then
APP_HOME=$( cygpath --path --mixed "$APP_HOME" )
JAVACMD=$( cygpath --unix "$JAVACMD" )
# Now convert the arguments - kludge to limit ourselves to /bin/sh
for arg do
if
case $arg in #(
-*) false ;; # don't mess with options #(
/?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath
[ -e "$t" ] ;; #(
*) false ;;
esac
then
arg=$( cygpath --path --ignore --mixed "$arg" )
fi
# Roll the args list around exactly as many times as the number of
# args, so each arg winds up back in the position where it started, but
# possibly modified.
#
# NB: a `for` loop captures its iteration list before it begins, so
# changing the positional parameters here affects neither the number of
# iterations, nor the values presented in `arg`.
shift # remove old arg
set -- "$@" "$arg" # push replacement arg
done
fi
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
# Collect all arguments for the java command:
# * DEFAULT_JVM_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
# and any embedded shellness will be escaped.
# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
# treated as '${Hostname}' itself on the command line.
set -- \
"-Dorg.gradle.appname=$APP_BASE_NAME" \
-jar "$APP_HOME/gradle/wrapper/gradle-wrapper.jar" \
"$@"
# Stop when "xargs" is not available.
if ! command -v xargs >/dev/null 2>&1
then
die "xargs is not available"
fi
# Use "xargs" to parse quoted args.
#
# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
#
# In Bash we could simply go:
#
# readarray ARGS < <( xargs -n1 <<<"$var" ) &&
# set -- "${ARGS[@]}" "$@"
#
# but POSIX shell has neither arrays nor command substitution, so instead we
# post-process each arg (as a line of input to sed) to backslash-escape any
# character that might be a shell metacharacter, then use eval to reverse
# that process (while maintaining the separation between arguments), and wrap
# the whole thing up as a single "set" statement.
#
# This will of course break if any of these variables contains a newline or
# an unmatched quote.
#
eval "set -- $(
printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" |
xargs -n1 |
sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' |
tr '\n' ' '
)" '"$@"'
exec "$JAVACMD" "$@"

93
demo/gradlew.bat vendored Normal file
View File

@ -0,0 +1,93 @@
@rem
@rem Copyright 2015 the original author or authors.
@rem
@rem Licensed under the Apache License, Version 2.0 (the "License");
@rem you may not use this file except in compliance with the License.
@rem You may obtain a copy of the License at
@rem
@rem https://www.apache.org/licenses/LICENSE-2.0
@rem
@rem Unless required by applicable law or agreed to in writing, software
@rem distributed under the License is distributed on an "AS IS" BASIS,
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@rem See the License for the specific language governing permissions and
@rem limitations under the License.
@rem
@rem SPDX-License-Identifier: Apache-2.0
@rem
@if "%DEBUG%"=="" @echo off
@rem ##########################################################################
@rem
@rem Gradle startup script for Windows
@rem
@rem ##########################################################################
@rem Set local scope for the variables with windows NT shell
if "%OS%"=="Windows_NT" setlocal
set DIRNAME=%~dp0
if "%DIRNAME%"=="" set DIRNAME=.
@rem This is normally unused
set APP_BASE_NAME=%~n0
set APP_HOME=%DIRNAME%
@rem Resolve any "." and ".." in APP_HOME to make it shorter.
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
@rem Find java.exe
if defined JAVA_HOME goto findJavaFromJavaHome
set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
if %ERRORLEVEL% equ 0 goto execute
echo. 1>&2
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2
echo. 1>&2
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
echo location of your Java installation. 1>&2
goto fail
:findJavaFromJavaHome
set JAVA_HOME=%JAVA_HOME:"=%
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
if exist "%JAVA_EXE%" goto execute
echo. 1>&2
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2
echo. 1>&2
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
echo location of your Java installation. 1>&2
goto fail
:execute
@rem Setup the command line
@rem Execute Gradle
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -jar "%APP_HOME%\gradle\wrapper\gradle-wrapper.jar" %*
:end
@rem End local scope for the variables with windows NT shell
if %ERRORLEVEL% equ 0 goto mainEnd
:fail
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
rem the _cmd.exe /c_ return code!
set EXIT_CODE=%ERRORLEVEL%
if %EXIT_CODE% equ 0 set EXIT_CODE=1
if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE%
exit /b %EXIT_CODE%
:mainEnd
if "%OS%"=="Windows_NT" endlocal
:omega

1
demo/settings.gradle Normal file
View File

@ -0,0 +1 @@
rootProject.name = 'demo'

View File

@ -0,0 +1,13 @@
package com.example.demo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}

View File

@ -0,0 +1,35 @@
package com.example.demo.controller;
import com.example.demo.domain.Idn;
import lombok.RequiredArgsConstructor;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/api")
@RequiredArgsConstructor
public class IdnController
{
private final com.example.demo.service.IdnService idnService;
@GetMapping("/idn/{id}")
public ResponseEntity<Idn> getIdn(@PathVariable(value = "id") String id)
{
return ResponseEntity.ok(idnService.getIdn(Integer.parseInt(id)));
}
@GetMapping("/idns")
public ResponseEntity<Page<Idn>> getPageOfIdns(@RequestParam(value = "page", defaultValue = "0") int page,
@RequestParam(value = "size", defaultValue = "10") int size)
{
return ResponseEntity.ok(idnService.findAll(PageRequest.of(page, size)));
}
}

View File

@ -0,0 +1,39 @@
package com.example.demo.controller;
import gg.jte.CodeResolver;
import gg.jte.ContentType;
import gg.jte.TemplateEngine;
import gg.jte.resolve.DirectoryCodeResolver;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.ViewResolver;
import java.nio.file.Path;
import java.nio.file.Paths;
@Configuration
public class JteConfiguration {
@Bean
public ViewResolver jteViewResolve(TemplateEngine templateEngine) {
return new JteViewResolver(templateEngine);
}
@Bean
public TemplateEngine templateEngine() {
String profile = System.getenv("SPRING_ENV");
if ("prod".equals(profile)) {
// Templates will be compiled by the maven build task
return TemplateEngine.createPrecompiled(ContentType.Html);
} else {
// Here, a JTE file watcher will recompile the JTE templates upon file save (the web browser will auto-refresh)
// If using IntelliJ, use Ctrl-F9 to trigger an auto-refresh when editing non-JTE files.
// CodeResolver codeResolver = new DirectoryCodeResolver(Path.of("C:\\Users\\smkv\\Documents\\springdemo\\demo\\src\\main\\jte\\"));
CodeResolver codeResolver = new DirectoryCodeResolver(Path.of("src", "main", "jte"));
TemplateEngine templateEngine = TemplateEngine.create(codeResolver, Paths.get("jte-classes"), ContentType.Html, getClass().getClassLoader());
templateEngine.setBinaryStaticContent(true);
return templateEngine;
}
}
}

View File

@ -0,0 +1,37 @@
package com.example.demo.controller;
import gg.jte.TemplateEngine;
import gg.jte.output.Utf8ByteOutput;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import org.springframework.http.MediaType;
import org.springframework.web.servlet.view.AbstractTemplateView;
import java.nio.charset.StandardCharsets;
import java.util.Map;
public class JteView extends AbstractTemplateView {
private final TemplateEngine templateEngine;
public JteView(TemplateEngine templateEngine) {
this.templateEngine = templateEngine;
}
@Override
protected void renderMergedTemplateModel(Map<String, Object> model,
HttpServletRequest request,
HttpServletResponse response) throws Exception {
String url = this.getUrl();
Utf8ByteOutput output = new Utf8ByteOutput();
templateEngine.render(url, model, output);
response.setContentType(MediaType.TEXT_HTML_VALUE);
response.setCharacterEncoding(StandardCharsets.UTF_8.name());
response.setContentLength(output.getContentLength());
output.writeTo(response.getOutputStream());
}
}

View File

@ -0,0 +1,20 @@
package com.example.demo.controller;
import gg.jte.TemplateEngine;
import org.springframework.web.servlet.view.AbstractTemplateViewResolver;
import org.springframework.web.servlet.view.AbstractUrlBasedView;
public class JteViewResolver extends AbstractTemplateViewResolver {
private final TemplateEngine templateEngine;
public JteViewResolver(TemplateEngine templateEngine) {
this.setViewClass(this.requiredViewClass());
this.setSuffix(".jte");
this.templateEngine = templateEngine;
}
@Override
protected AbstractUrlBasedView instantiateView() {
return new JteView(templateEngine);
}
}

View File

@ -0,0 +1,55 @@
package com.example.demo.controller;
import com.example.demo.domain.Idn;
import com.example.demo.domain.Idn2;
import com.example.demo.service.IdnService;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import java.util.ArrayList;
import java.util.Base64;
import java.util.List;
@Controller
public class WebappController
{
private final IdnService idnService;
public WebappController(IdnService idnService)
{
this.idnService = idnService;
}
@GetMapping("/tools")
public String index(Model model) {
//hardcode single get for now
// Idn id1 = idnService.getIdn(1);
// byte[] imageByte1 = id1.getImage();
// String photo1 = Base64.getEncoder().encodeToString(imageByte1);
// imag1 = "data:image/png;base64," + photo1;
//ArrayList<Idn> idnlist = idnService.getAll(); //get all tools :D
ArrayList<Idn2> imglist = new ArrayList<Idn2>();
ArrayList<Idn> idnlist = idnService.getIdnByType(5);
String imag1 = "";
for (int i = 0; i < idnlist.size(); i++)
{
byte[] img = idnlist.get(i).getImage();
if (img != null)
{
String photo = Base64.getEncoder().encodeToString(img);
imag1 = "data:image/png;base64," + photo;
}
Idn2 idn2 = new Idn2();
idn2.id = idnlist.get(i).getId();
idn2.image_str = imag1;
idn2.date_created = idnlist.get(i).getCreationDate().toString();
idn2.date_modified = idnlist.get(i).getLastModificationDate().toString();
imglist.add(idn2);
}
model.addAttribute("idn_list", idnlist);
model.addAttribute("img_list", imglist);
return "index";
}
}

View File

@ -0,0 +1,72 @@
package com.example.demo.domain;
import com.fasterxml.jackson.annotation.JsonInclude;
import jakarta.persistence.*;
import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import java.util.Date;
@Entity
@Getter
@Setter
@NoArgsConstructor
@AllArgsConstructor
@JsonInclude(JsonInclude.Include.NON_DEFAULT)
@Table(name = "directory")
public class Idn
{
@Id
@Column(name = "dir_id", unique = true, updatable = false)
private Integer id;
@Column(name = "dir_parent_id")
private Integer parentId;
@Column(name = "dir_idn")
public String name;
@Column(name = "dir_type")
private Integer type;
@Column(name = "dir_user")
private String creator;
@Column(name = "dir_user_modified")
private String lastModified;
@Column(name = "dir_permissions")
private String permissions;
@Column(name = "dir_created")
@Temporal(TemporalType.TIMESTAMP)
private Date creationDate;
@Column(name = "dir_modified")
@Temporal(TemporalType.TIMESTAMP)
private Date lastModificationDate;
@Column(name = "dir_image")
private byte[] image;
@Column(name = "dir_note")
private String note;
@Column(name = "dir_created_version")
private String createdInVersion;
@Column(name = "dir_modified_version")
private String modifiedInVersion;
@Column(name = "dir_pdf_attachments")
private byte[] pdfAttachments;
@Column(name = "dir_idn_version")
private String idnVersion;
@Column(name = "dir_icon")
private byte[] icon;
}

View File

@ -0,0 +1,11 @@
package com.example.demo.domain;
public class Idn2
{
public Integer id;
public String image_str;
public String date_created;
public String date_modified;
public record NestTest(String name, String id, String d ) {}
}

View File

@ -0,0 +1,17 @@
package com.example.demo.repository;
import com.example.demo.domain.Idn;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
import java.util.ArrayList;
import java.util.Optional;
@Repository
public interface IdnRepository
extends JpaRepository<Idn, Integer>
{
Optional<Idn> findById(Integer id);
ArrayList<Idn> findIdnByType(Integer type);
}

View File

@ -0,0 +1,45 @@
package com.example.demo.service;
import com.example.demo.domain.Idn;
import com.example.demo.repository.IdnRepository;
import jakarta.transaction.Transactional;
import lombok.RequiredArgsConstructor;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.stereotype.Service;
import java.util.ArrayList;
import java.util.List;
@Service
@Transactional(rollbackOn = Exception.class)
@RequiredArgsConstructor
public class IdnService
{
private final IdnRepository idnRepository;
public Page<Idn> findAll(Pageable page)
{
return idnRepository.findAll(page);
}
//casting- ok?
public ArrayList<Idn> getAll()
{
return (ArrayList<Idn>) idnRepository.findAll();
}
public Idn getIdn(Integer id)
{
return idnRepository.findById(id).orElseThrow(()->new RuntimeException(id+" not found"));
}
public ArrayList<Idn> getIdnByType(Integer type)
{
return idnRepository.findIdnByType(type);
}
}

BIN
demo/src/main/jte/idn.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 236 KiB

BIN
demo/src/main/jte/idn.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 MiB

View File

@ -0,0 +1,87 @@
@import com.example.demo.domain.Idn
@import com.example.demo.domain.Idn2
@import org.springframework.data.domain.Page
@import java.util.ArrayList
@import java.util.List
@param com.example.demo.domain.Idn idn_test
@param String image_string_1
@param String test_string
@param ArrayList<Idn> idn_list
@param ArrayList<Idn2> img_list
<html lang="en">
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Raleway">
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Kartika">
<script type="module" src="https://ajax.googleapis.com/ajax/libs/model-viewer/4.2.0/model-viewer.min.js"></script>
<body>
<style>
h1,h2,h3,h4,h5,h6 {font-family: "Raleway", sans-serif}
p, body {font-family: "Kartika", sans-serif}
body {
margin: 0;
background-color: #1C1C1C;
}
.header {
display: -webkit-flex;
display: flex;
}
.topnav {
overflow: hidden;
background-color: steelblue;
}
* {
box-sizing: border-box;
}
.column {
float: left;
width: 33.33%;
padding: 25px;
background-color: rgba(4, 170, 109, 0.1);
}
h2 {text-align: center;}
/* Clearfix (clear floats) */
.row::after {
content: "";
clear: both;
display: table;
}
</style>
<div class="topnav">
<h2>IDN Viewer: Tools</h2>
</div>
<p> IDN List size: ${idn_list.size()}! </p>
<div class="column">
<model-viewer
alt="Spacesuit"
src="https://modelviewer.dev/shared-assets/models/NeilArmstrong.glb"
camera-controls
auto-rotate>
</model-viewer>
</div>
@for(int i = 0; i < 65; i++)
<div class="row">
<div class="column">
<p style="color:ghostwhite;"> Name: ${idn_list.get(i).getName()} <br>
ID: ${idn_list.get(i).getId()} <br>
Ver: ${idn_list.get(i).getModifiedInVersion()} <br>
Date Created: ${img_list.get(i).date_created} <br>
Date Modified: ${img_list.get(i).date_modified} </p>
</div>
<div class="column">
<img src="${img_list.get(i).image_str}" alt="${img_list.get(i).id}">
</div>
</div>
@endfor
</body>
</html>

View File

@ -0,0 +1,7 @@
gg.jte.development-mode=true
spring.application.name=demo
gg.jte.templateLocation=src/main/jte
gg.jte.templateSuffix=.jte
spring.datasource.url=jdbc:sqlserver://AMS-SERVER;instanceName=TOOLSTUDIO;databaseName=Test_DB_ALL;trustServerCertificate=true
spring.datasource.username=ToolStudioUser
spring.datasource.password=ts

View File

@ -0,0 +1,13 @@
package com.example.demo;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
class DemoApplicationTests {
@Test
void contextLoads() {
}
}