Compare commits
	
		
			45 Commits
		
	
	
		
			Richards_B
			...
			20a39be10b
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 20a39be10b | |||
| d457b20f15 | |||
| 634d1ce805 | |||
| a9dede0974 | |||
| 7932c7e896 | |||
| a23a1695ad | |||
| ba70f484a7 | |||
| 9d7b981c22 | |||
| 28dcd4a7ab | |||
| 0a7f941d61 | |||
| 6e60fb1517 | |||
| 
						 | 
					6c13cb1873 | ||
| 
						 | 
					289617b9b7 | ||
| cd395d1982 | |||
| 
						 | 
					ea8beb9de5 | ||
| 
						 | 
					b74a983d9a | ||
| 
						 | 
					20700448af | ||
| 
						 | 
					5978a079bf | ||
| 
						 | 
					56f359a63a | ||
| 
						 | 
					d02acb89a4 | ||
| 
						 | 
					c08b0aece5 | ||
| 
						 | 
					4d6c2043d7 | ||
| 
						 | 
					6555f8f8bc | ||
| 
						 | 
					4559ad5036 | ||
| 
						 | 
					63d1030c7f | ||
| 846c2c392a | |||
| 40cc2b002a | |||
| e87bae35bc | |||
| 0b02c1c661 | |||
| b15b94e579 | |||
| 0d36d7718e | |||
| 
						 | 
					9b6d60a571 | ||
| 
						 | 
					f567320ec3 | ||
| 
						 | 
					324ce53bd4 | ||
| 
						 | 
					f71aba3505 | ||
| 
						 | 
					5ee0288736 | ||
| 72c2e9da16 | |||
| 
						 | 
					8927755462 | ||
| 636ac5ed3a | |||
| 
						 | 
					1c85261c7b | ||
| 
						 | 
					c57e65fadb | ||
| 
						 | 
					c890819be7 | ||
| 
						 | 
					c981fbca19 | ||
| 
						 | 
					2b5839f0ea | ||
| 
						 | 
					1a4d45aed4 | 
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							@@ -8,6 +8,7 @@ target/
 | 
			
		||||
.idea/jarRepositories.xml
 | 
			
		||||
.idea/compiler.xml
 | 
			
		||||
.idea/libraries/
 | 
			
		||||
.idea
 | 
			
		||||
*.iws
 | 
			
		||||
*.iml
 | 
			
		||||
*.ipr
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										3
									
								
								.idea/.gitignore
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.idea/.gitignore
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,3 @@
 | 
			
		||||
# Default ignored files
 | 
			
		||||
/shelf/
 | 
			
		||||
/workspace.xml
 | 
			
		||||
							
								
								
									
										7
									
								
								.idea/encodings.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								.idea/encodings.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							@@ -0,0 +1,7 @@
 | 
			
		||||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
<project version="4">
 | 
			
		||||
  <component name="Encoding">
 | 
			
		||||
    <file url="file://$PROJECT_DIR$/src/main/java" charset="UTF-8" />
 | 
			
		||||
    <file url="file://$PROJECT_DIR$/src/main/resources" charset="UTF-8" />
 | 
			
		||||
  </component>
 | 
			
		||||
</project>
 | 
			
		||||
							
								
								
									
										12
									
								
								.idea/misc.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								.idea/misc.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							@@ -0,0 +1,12 @@
 | 
			
		||||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
<project version="4">
 | 
			
		||||
  <component name="ExternalStorageConfigurationManager" enabled="true" />
 | 
			
		||||
  <component name="MavenProjectsManager">
 | 
			
		||||
    <option name="originalFiles">
 | 
			
		||||
      <list>
 | 
			
		||||
        <option value="$PROJECT_DIR$/pom.xml" />
 | 
			
		||||
      </list>
 | 
			
		||||
    </option>
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="ProjectRootManager" version="2" languageLevel="JDK_19" default="true" project-jdk-name="openjdk-19" project-jdk-type="JavaSDK" />
 | 
			
		||||
</project>
 | 
			
		||||
							
								
								
									
										4
									
								
								.idea/misc_.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4
									
								
								.idea/misc_.xml
									
									
									
										generated
									
									
									
								
							@@ -1,4 +0,0 @@
 | 
			
		||||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
<project version="4">
 | 
			
		||||
  <component name="ProjectRootManager" version="2" languageLevel="JDK_19" default="true" project-jdk-name="openjdk-19" project-jdk-type="JavaSDK" />
 | 
			
		||||
</project>
 | 
			
		||||
							
								
								
									
										425
									
								
								.idea/shelf/Uncommitted_changes_before_Update_at_30_01_2023_14_48_[Changes]/shelved.patch
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										425
									
								
								.idea/shelf/Uncommitted_changes_before_Update_at_30_01_2023_14_48_[Changes]/shelved.patch
									
									
									
										generated
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										4
									
								
								.idea/shelf/Uncommitted_changes_before_Update_at_30_01_2023_14_48__Changes_.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								.idea/shelf/Uncommitted_changes_before_Update_at_30_01_2023_14_48__Changes_.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							@@ -0,0 +1,4 @@
 | 
			
		||||
<changelist name="Uncommitted_changes_before_Update_at_30_01_2023_14_48_[Changes]" date="1675086496793" recycled="true" deleted="true">
 | 
			
		||||
  <option name="PATH" value="$PROJECT_DIR$/.idea/shelf/Uncommitted_changes_before_Update_at_30_01_2023_14_48_[Changes]/shelved.patch" />
 | 
			
		||||
  <option name="DESCRIPTION" value="Uncommitted changes before Update at 30.01.2023 14:48 [Changes]" />
 | 
			
		||||
</changelist>
 | 
			
		||||
							
								
								
									
										124
									
								
								.idea/uiDesigner.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								.idea/uiDesigner.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							@@ -0,0 +1,124 @@
 | 
			
		||||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
<project version="4">
 | 
			
		||||
  <component name="Palette2">
 | 
			
		||||
    <group name="Swing">
 | 
			
		||||
      <item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.svg" removable="false" auto-create-binding="false" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.svg" removable="false" auto-create-binding="false" can-attach-label="true">
 | 
			
		||||
        <default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.svg" removable="false" auto-create-binding="true" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
 | 
			
		||||
        <initial-values>
 | 
			
		||||
          <property name="text" value="Button" />
 | 
			
		||||
        </initial-values>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.svg" removable="false" auto-create-binding="true" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
 | 
			
		||||
        <initial-values>
 | 
			
		||||
          <property name="text" value="RadioButton" />
 | 
			
		||||
        </initial-values>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.svg" removable="false" auto-create-binding="true" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
 | 
			
		||||
        <initial-values>
 | 
			
		||||
          <property name="text" value="CheckBox" />
 | 
			
		||||
        </initial-values>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.svg" removable="false" auto-create-binding="false" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
 | 
			
		||||
        <initial-values>
 | 
			
		||||
          <property name="text" value="Label" />
 | 
			
		||||
        </initial-values>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
 | 
			
		||||
          <preferred-size width="150" height="-1" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
 | 
			
		||||
          <preferred-size width="150" height="-1" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
 | 
			
		||||
          <preferred-size width="150" height="-1" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.svg" removable="false" auto-create-binding="true" can-attach-label="true">
 | 
			
		||||
        <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
 | 
			
		||||
          <preferred-size width="150" height="50" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
 | 
			
		||||
        <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
 | 
			
		||||
          <preferred-size width="150" height="50" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
 | 
			
		||||
        <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
 | 
			
		||||
          <preferred-size width="150" height="50" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.svg" removable="false" auto-create-binding="true" can-attach-label="true">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.svg" removable="false" auto-create-binding="true" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
 | 
			
		||||
          <preferred-size width="150" height="50" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.svg" removable="false" auto-create-binding="true" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
 | 
			
		||||
          <preferred-size width="150" height="50" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.svg" removable="false" auto-create-binding="true" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
 | 
			
		||||
          <preferred-size width="150" height="50" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.svg" removable="false" auto-create-binding="true" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
 | 
			
		||||
          <preferred-size width="200" height="200" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.svg" removable="false" auto-create-binding="false" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
 | 
			
		||||
          <preferred-size width="200" height="200" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.svg" removable="false" auto-create-binding="true" can-attach-label="true">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.svg" removable="false" auto-create-binding="true" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.svg" removable="false" auto-create-binding="false" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
 | 
			
		||||
          <preferred-size width="-1" height="20" />
 | 
			
		||||
        </default-constraints>
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
 | 
			
		||||
      </item>
 | 
			
		||||
      <item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
 | 
			
		||||
        <default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
 | 
			
		||||
      </item>
 | 
			
		||||
    </group>
 | 
			
		||||
  </component>
 | 
			
		||||
</project>
 | 
			
		||||
							
								
								
									
										2
									
								
								.idea/vcs_.xml → .idea/vcs.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.idea/vcs_.xml → .idea/vcs.xml
									
									
									
										generated
									
									
									
								
							@@ -1,6 +1,6 @@
 | 
			
		||||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
<project version="4">
 | 
			
		||||
  <component name="VcsDirectoryMappings">
 | 
			
		||||
    <mapping directory="$PROJECT_DIR$" vcs="Git" />
 | 
			
		||||
    <mapping directory="" vcs="Git" />
 | 
			
		||||
  </component>
 | 
			
		||||
</project>
 | 
			
		||||
							
								
								
									
										130
									
								
								.idea/workspace.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										130
									
								
								.idea/workspace.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							@@ -0,0 +1,130 @@
 | 
			
		||||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
<project version="4">
 | 
			
		||||
  <component name="AutoImportSettings">
 | 
			
		||||
    <option name="autoReloadType" value="SELECTIVE" />
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="ChangeListManager">
 | 
			
		||||
    <list default="true" id="be8f30d3-089d-4d1c-bba3-da21b0466111" name="Changes" comment="Variablen und Attributen auf englisch umbennent">
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/.idea/shelf/Uncommitted_changes_before_Update_at_30_01_2023_14_48__Changes_.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/shelf/Uncommitted_changes_before_Update_at_30_01_2023_14_48__Changes_.xml" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/database.db" beforeDir="false" afterPath="$PROJECT_DIR$/database.db" afterDir="false" />
 | 
			
		||||
    </list>
 | 
			
		||||
    <option name="SHOW_DIALOG" value="false" />
 | 
			
		||||
    <option name="HIGHLIGHT_CONFLICTS" value="true" />
 | 
			
		||||
    <option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
 | 
			
		||||
    <option name="LAST_RESOLUTION" value="IGNORE" />
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="FileTemplateManagerImpl">
 | 
			
		||||
    <option name="RECENT_TEMPLATES">
 | 
			
		||||
      <list>
 | 
			
		||||
        <option value="Class" />
 | 
			
		||||
      </list>
 | 
			
		||||
    </option>
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="Git.Settings">
 | 
			
		||||
    <option name="RECENT_BRANCH_BY_REPOSITORY">
 | 
			
		||||
      <map>
 | 
			
		||||
        <entry key="$PROJECT_DIR$" value="Richards_Branch" />
 | 
			
		||||
      </map>
 | 
			
		||||
    </option>
 | 
			
		||||
    <option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="HighlightingSettingsPerFile">
 | 
			
		||||
    <setting file="file://$PROJECT_DIR$/src/main/resources/com/bib/essensbestellungsverwaltung/signUp-view.fxml" root0="FORCE_HIGHLIGHTING" />
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="MarkdownSettingsMigration">
 | 
			
		||||
    <option name="stateVersion" value="1" />
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="MavenImportPreferences">
 | 
			
		||||
    <option name="generalSettings">
 | 
			
		||||
      <MavenGeneralSettings>
 | 
			
		||||
        <option name="mavenHome" value="Use Maven wrapper" />
 | 
			
		||||
        <option name="useMavenConfig" value="true" />
 | 
			
		||||
      </MavenGeneralSettings>
 | 
			
		||||
    </option>
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="ProjectId" id="2L2y55tSt0XlzQa7s1gkzyAgxgu" />
 | 
			
		||||
  <component name="ProjectLevelVcsManager" settingsEditedManually="true" />
 | 
			
		||||
  <component name="ProjectViewState">
 | 
			
		||||
    <option name="hideEmptyMiddlePackages" value="true" />
 | 
			
		||||
    <option name="showLibraryContents" value="true" />
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="PropertiesComponent">{
 | 
			
		||||
  "keyToString": {
 | 
			
		||||
    "ASKED_ADD_EXTERNAL_FILES": "true",
 | 
			
		||||
    "ASKED_SHARE_PROJECT_CONFIGURATION_FILES": "true",
 | 
			
		||||
    "RunOnceActivity.OpenProjectViewOnStart": "true",
 | 
			
		||||
    "RunOnceActivity.ShowReadmeOnStart": "true"
 | 
			
		||||
  }
 | 
			
		||||
}</component>
 | 
			
		||||
  <component name="RunManager">
 | 
			
		||||
    <configuration name="SuperMain" type="Application" factoryName="Application" temporary="true" nameIsGenerated="true">
 | 
			
		||||
      <option name="MAIN_CLASS_NAME" value="com.bib.essensbestellungsverwaltung.SuperMain" />
 | 
			
		||||
      <module name="Essensbestellungsverwaltung" />
 | 
			
		||||
      <extension name="coverage">
 | 
			
		||||
        <pattern>
 | 
			
		||||
          <option name="PATTERN" value="com.bib.essensbestellungsverwaltung.*" />
 | 
			
		||||
          <option name="ENABLED" value="true" />
 | 
			
		||||
        </pattern>
 | 
			
		||||
      </extension>
 | 
			
		||||
      <method v="2">
 | 
			
		||||
        <option name="Make" enabled="true" />
 | 
			
		||||
      </method>
 | 
			
		||||
    </configuration>
 | 
			
		||||
    <recent_temporary>
 | 
			
		||||
      <list>
 | 
			
		||||
        <item itemvalue="Application.SuperMain" />
 | 
			
		||||
        <item itemvalue="Application.SuperMain" />
 | 
			
		||||
      </list>
 | 
			
		||||
    </recent_temporary>
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="SpellCheckerSettings" RuntimeDictionaries="0" Folders="0" CustomDictionaries="0" DefaultDictionary="application-level" UseSingleDictionary="true" transferred="true" />
 | 
			
		||||
  <component name="TaskManager">
 | 
			
		||||
    <task active="true" id="Default" summary="Default task">
 | 
			
		||||
      <changelist id="be8f30d3-089d-4d1c-bba3-da21b0466111" name="Changes" comment="" />
 | 
			
		||||
      <created>1675083287293</created>
 | 
			
		||||
      <option name="number" value="Default" />
 | 
			
		||||
      <option name="presentableId" value="Default" />
 | 
			
		||||
      <updated>1675083287293</updated>
 | 
			
		||||
    </task>
 | 
			
		||||
    <task id="LOCAL-00001" summary="StartViewApplication ist die Startpunkt des Projekt">
 | 
			
		||||
      <created>1675083679870</created>
 | 
			
		||||
      <option name="number" value="00001" />
 | 
			
		||||
      <option name="presentableId" value="LOCAL-00001" />
 | 
			
		||||
      <option name="project" value="LOCAL" />
 | 
			
		||||
      <updated>1675083679870</updated>
 | 
			
		||||
    </task>
 | 
			
		||||
    <task id="LOCAL-00002" summary="StartViewApplication ist die Startpunkt des Projekt">
 | 
			
		||||
      <created>1675083693484</created>
 | 
			
		||||
      <option name="number" value="00002" />
 | 
			
		||||
      <option name="presentableId" value="LOCAL-00002" />
 | 
			
		||||
      <option name="project" value="LOCAL" />
 | 
			
		||||
      <updated>1675083693484</updated>
 | 
			
		||||
    </task>
 | 
			
		||||
    <task id="LOCAL-00003" summary="singup mit Datebase verbunden und new Adresse">
 | 
			
		||||
      <created>1675241335793</created>
 | 
			
		||||
      <option name="number" value="00003" />
 | 
			
		||||
      <option name="presentableId" value="LOCAL-00003" />
 | 
			
		||||
      <option name="project" value="LOCAL" />
 | 
			
		||||
      <updated>1675241335793</updated>
 | 
			
		||||
    </task>
 | 
			
		||||
    <option name="localTasksCounter" value="4" />
 | 
			
		||||
    <servers />
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="Vcs.Log.Tabs.Properties">
 | 
			
		||||
    <option name="TAB_STATES">
 | 
			
		||||
      <map>
 | 
			
		||||
        <entry key="MAIN">
 | 
			
		||||
          <value>
 | 
			
		||||
            <State />
 | 
			
		||||
          </value>
 | 
			
		||||
        </entry>
 | 
			
		||||
      </map>
 | 
			
		||||
    </option>
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="VcsManagerConfiguration">
 | 
			
		||||
    <MESSAGE value="StartViewApplication ist die Startpunkt des Projekt" />
 | 
			
		||||
    <MESSAGE value="singup mit Datebase verbunden" />
 | 
			
		||||
    <MESSAGE value="singup mit Datebase verbunden und new Adresse" />
 | 
			
		||||
    <option name="LAST_COMMIT_MESSAGE" value="singup mit Datebase verbunden und new Adresse" />
 | 
			
		||||
  </component>
 | 
			
		||||
</project>
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								database.db
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								database.db
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							@@ -1,7 +1,4 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
import javax.crypto.SecretKeyFactory;
 | 
			
		||||
import javax.crypto.spec.PBEKeySpec;
 | 
			
		||||
@@ -13,12 +10,18 @@ import java.util.ArrayList;
 | 
			
		||||
import java.util.Base64;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * A collection of functions loosely related to account management
 | 
			
		||||
 * Acts as an abstraction layer to the database
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class AccountMgr {
 | 
			
		||||
    protected static double price = 5.0;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * creates a user with createUser(...) and adds its id to the 'worker' table
 | 
			
		||||
     * @param worker the worker to be created
 | 
			
		||||
     * @return userid or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static long createWorker(Worker worker){
 | 
			
		||||
        long id = createUser(worker);
 | 
			
		||||
@@ -29,7 +32,9 @@ public class AccountMgr {
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * creates a user with createUser(...) and adds its id to the 'parent' table
 | 
			
		||||
     * @param parent the parent to be created
 | 
			
		||||
     * @return userid or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static long createParent(Parent parent){
 | 
			
		||||
        long id = createUser(parent);
 | 
			
		||||
@@ -40,7 +45,9 @@ public class AccountMgr {
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * adds a user to the database
 | 
			
		||||
     * @param user the user to be created
 | 
			
		||||
     * @return userid or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static long createUser(User user) {
 | 
			
		||||
        String[] userH = {"name", "firstname", "addressid", "password", "email"};
 | 
			
		||||
@@ -56,6 +63,12 @@ public class AccountMgr {
 | 
			
		||||
        return Database.insert("user", userH, userD);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * adds an address to the database
 | 
			
		||||
     * @param address the address to be created
 | 
			
		||||
     * @return id or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static long createAddress(Address address){
 | 
			
		||||
        String[] addressH = {"street", "number", "plz", "city"};
 | 
			
		||||
        String[] addressD = {address.getStreet(),address.getNumber(),address.getPlz(),address.getCity()};
 | 
			
		||||
@@ -64,7 +77,9 @@ public class AccountMgr {
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * adds a child and allergies to the database
 | 
			
		||||
     * @param child the child to be created
 | 
			
		||||
     * @return id of child or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static long createChild(Child child){
 | 
			
		||||
        String[] childH = {"name","firstname","addressid"};
 | 
			
		||||
@@ -81,8 +96,17 @@ public class AccountMgr {
 | 
			
		||||
        return id;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * returns a User(Worker | Parent) for a given id or null if no unique id was found
 | 
			
		||||
     * @param id id of the User
 | 
			
		||||
     * @return User(Worker | Parent) or null
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static User getUserById(long id){
 | 
			
		||||
        List<String> entry = Database.getEntryById("user",id);
 | 
			
		||||
        if(entry.size() != 1){
 | 
			
		||||
            return null;
 | 
			
		||||
        }
 | 
			
		||||
        String[] parts = entry.get(0).split(":");
 | 
			
		||||
        Address address = getAddressById(id);
 | 
			
		||||
        if(isWorker(String.valueOf(id))){
 | 
			
		||||
@@ -100,8 +124,17 @@ public class AccountMgr {
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * returns a Child for a given id or null if no unique id was found
 | 
			
		||||
     * @param id id of child
 | 
			
		||||
     * @return Child or null
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static Child getChildById(long id){
 | 
			
		||||
        List<String> entry = Database.getEntryById("child",id);
 | 
			
		||||
        if(entry.size() != 1){
 | 
			
		||||
            return null;
 | 
			
		||||
        }
 | 
			
		||||
        String[] parts = entry.get(0).split(":");
 | 
			
		||||
        String[] child_allergyH = {"childid"};
 | 
			
		||||
        String[] child_allergyD = {String.valueOf(id)};
 | 
			
		||||
@@ -117,8 +150,17 @@ public class AccountMgr {
 | 
			
		||||
        return new Child(id,parts[1],parts[2],getAddressById(Long.parseLong(parts[3])),allergySeverities);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * returns an Address for a given id or null if no unique id was found
 | 
			
		||||
     * @param id id of the address
 | 
			
		||||
     * @return Address or null
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static Address getAddressById(long id){
 | 
			
		||||
        List<String> entry = Database.getEntryById("address",id);
 | 
			
		||||
        if(entry.size() != 1){
 | 
			
		||||
            return null;
 | 
			
		||||
        }
 | 
			
		||||
        String[] parts = entry.get(0).split(":");
 | 
			
		||||
        return new Address(Long.parseLong(parts[0]),parts[1],parts[2],parts[3],parts[4]);
 | 
			
		||||
    }
 | 
			
		||||
@@ -128,6 +170,7 @@ public class AccountMgr {
 | 
			
		||||
     * @param parentId id of parent
 | 
			
		||||
     * @param childId id of child
 | 
			
		||||
     * @return id of parent_child or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static long matchParentChild(String parentId, String childId){
 | 
			
		||||
        String[] parent_childH = {"parentuserid","childid"};
 | 
			
		||||
@@ -140,6 +183,7 @@ public class AccountMgr {
 | 
			
		||||
     * @param email email
 | 
			
		||||
     * @param pw password
 | 
			
		||||
     * @return id or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static long login(String email, String pw){
 | 
			
		||||
        String[] pwH = {"email"};
 | 
			
		||||
@@ -163,6 +207,7 @@ public class AccountMgr {
 | 
			
		||||
     * checks if id is in worker table
 | 
			
		||||
     * @param id userid
 | 
			
		||||
     * @return true if id is in worker table
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static boolean isWorker(String id){
 | 
			
		||||
        String[] workerH = {"userid"};
 | 
			
		||||
@@ -175,6 +220,7 @@ public class AccountMgr {
 | 
			
		||||
     * checks if id is in parent table
 | 
			
		||||
     * @param id userid
 | 
			
		||||
     * @return true if id is in parent table
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static boolean isParent(String id){
 | 
			
		||||
        String[] parentH = {"userid"};
 | 
			
		||||
@@ -187,6 +233,7 @@ public class AccountMgr {
 | 
			
		||||
     * returns a hashed and salted password
 | 
			
		||||
     * @param pw the password to hash
 | 
			
		||||
     * @return hashed and salted password
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    private static String hashAndSalt(String pw, String salt){
 | 
			
		||||
        Base64.Decoder dec = Base64.getDecoder();
 | 
			
		||||
@@ -205,6 +252,11 @@ public class AccountMgr {
 | 
			
		||||
        return hashedPw;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * generates a secure random salt, Base64 encoded
 | 
			
		||||
     * @return String Base64 encoded
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    private static String getSalt(){
 | 
			
		||||
        SecureRandom sec = new SecureRandom();
 | 
			
		||||
        byte[] salt = new byte[16];
 | 
			
		||||
@@ -218,11 +270,15 @@ public class AccountMgr {
 | 
			
		||||
     * @param date YYYY-MM the month
 | 
			
		||||
     * @param childId id of child
 | 
			
		||||
     * @return the invoice as a List
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static List<String> getInvoice(String date, String childId){
 | 
			
		||||
        List<String> invoice = new ArrayList<>();
 | 
			
		||||
        invoice.add("Monatsabrechnung " + date);
 | 
			
		||||
        List<String> child = Database.getEntryById("child", Long.parseLong(childId));
 | 
			
		||||
        if(child.size() != 1){
 | 
			
		||||
            return invoice;
 | 
			
		||||
        }
 | 
			
		||||
        invoice.add("Monatsabrechnung " + date);
 | 
			
		||||
        String[] childParts = child.get(0).split(":");
 | 
			
		||||
        invoice.add(childParts[1] + ", " + childParts[2]);
 | 
			
		||||
        String[] food_planH = {"date"};
 | 
			
		||||
@@ -241,18 +297,29 @@ public class AccountMgr {
 | 
			
		||||
                invoice.add(line);
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
        double price = getPrice();
 | 
			
		||||
        invoice.add("Total: " + (invoice.size()-2) + " X " + price + "€ = " + ((invoice.size()-2)*price) + "€");
 | 
			
		||||
        return invoice;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    protected static void getPriceFromDb(){
 | 
			
		||||
    /**
 | 
			
		||||
     * gets the price per meal from the database and converts it to double
 | 
			
		||||
     * @return double price
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static double getPrice(){
 | 
			
		||||
        List<String> priceEntry = Database.getEntryById("price",1);
 | 
			
		||||
        price = Double.parseDouble(priceEntry.get(0).split(":")[1])/100.0;
 | 
			
		||||
        return Double.parseDouble(priceEntry.get(0).split(":")[1])/100.0;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    protected static void setPriceInDb(){
 | 
			
		||||
    /**
 | 
			
		||||
     * converts the price per meal to integer and updates it in the database
 | 
			
		||||
     * @param price double
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static void setPrice(double price){
 | 
			
		||||
        String[] priceH = {"id","price"};
 | 
			
		||||
        String[] priceD = {"1", String.valueOf(price*100)};
 | 
			
		||||
        String[] priceD = {"1", String.valueOf((int)(price*100))};
 | 
			
		||||
        Database.update("price",priceH,priceD);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,8 +1,10 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * An Address, used by User and Child and intended as a way to identify a child if you want to match it to another parent
 | 
			
		||||
 * one constructor is used for creating new addresses the other is used to create existing addresses from database
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class Address {
 | 
			
		||||
    private long id;
 | 
			
		||||
    private String street;
 | 
			
		||||
@@ -44,4 +46,5 @@ public class Address {
 | 
			
		||||
        this.plz = plz;
 | 
			
		||||
        this.city = city;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,8 +1,9 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * An Allergy, used by Food and AllergySeverity, not intended to be changed
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class Allergy {
 | 
			
		||||
    private final long id;
 | 
			
		||||
    private final String name;
 | 
			
		||||
@@ -25,4 +26,5 @@ public class Allergy {
 | 
			
		||||
    public String getHandle() {
 | 
			
		||||
        return handle;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,8 +1,9 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Matching an Allergy to a Severity, used by Child
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class AllergySeverity {
 | 
			
		||||
    private Allergy allergy;
 | 
			
		||||
    private long severityId;
 | 
			
		||||
 
 | 
			
		||||
@@ -1,10 +1,12 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * A Child, used by Parent
 | 
			
		||||
 * one constructor is used to create new children the other is used to create existing children from database
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class Child {
 | 
			
		||||
    private long id;
 | 
			
		||||
    private String name;
 | 
			
		||||
 
 | 
			
		||||
@@ -1,12 +1,13 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
import java.util.Scanner;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * library for cli functions
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class ConsoleLib {
 | 
			
		||||
    public static void createWorkerPrompt(){
 | 
			
		||||
        Scanner sc = new Scanner(System.in);
 | 
			
		||||
@@ -320,7 +321,6 @@ public class ConsoleLib {
 | 
			
		||||
        Scanner sc = new Scanner(System.in);
 | 
			
		||||
        double price = sc.nextDouble();
 | 
			
		||||
        sc.nextLine();
 | 
			
		||||
        AccountMgr.price = price;
 | 
			
		||||
        AccountMgr.setPriceInDb();
 | 
			
		||||
        AccountMgr.setPrice(price);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,10 +1,11 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
import java.util.Scanner;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * simple cli showcase of the implemented functionality
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class ConsoleMain {
 | 
			
		||||
    static User currentUser = null;
 | 
			
		||||
    static boolean running = true;
 | 
			
		||||
@@ -15,7 +16,7 @@ public class ConsoleMain {
 | 
			
		||||
            Database.fillDb();
 | 
			
		||||
            ConsoleLib.createWorkerPrompt();
 | 
			
		||||
        }
 | 
			
		||||
        AccountMgr.getPriceFromDb();
 | 
			
		||||
        AccountMgr.getPrice();
 | 
			
		||||
        while (running){
 | 
			
		||||
            if(currentUser == null){
 | 
			
		||||
                defaultMenu();
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +1,4 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
import java.io.File;
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
@@ -10,13 +7,19 @@ import java.sql.*;
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Basic operations on the database
 | 
			
		||||
 * Use init() -> createDb() -> fillDb() to create the skeleton with some default values
 | 
			
		||||
 * Provides select, insert, update, delete, count operations and more
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class Database {
 | 
			
		||||
    private static final String dbLocation = "jdbc:sqlite:"+Path.of("").toAbsolutePath()+"/database.db";
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * creates new database.db if it doesn't exist
 | 
			
		||||
     * @return true if a new database has been created
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static boolean init(){
 | 
			
		||||
        File db = new File(Path.of("").toAbsolutePath()+"/database.db");
 | 
			
		||||
@@ -30,6 +33,7 @@ public class Database {
 | 
			
		||||
    /**
 | 
			
		||||
     * connects to the database
 | 
			
		||||
     * @return Connection to the database
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static Connection connect(){
 | 
			
		||||
        Connection conn = null;
 | 
			
		||||
@@ -43,6 +47,7 @@ public class Database {
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * creates the initial structure of the db
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static void createDb(){
 | 
			
		||||
        String[] sql = new String[15];
 | 
			
		||||
@@ -173,6 +178,7 @@ public class Database {
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * inserts fixed values into the database
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static void fillDb(){
 | 
			
		||||
        List<String> sqls = new ArrayList<>();
 | 
			
		||||
@@ -274,11 +280,12 @@ public class Database {
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * inserts data into table and returns its id
 | 
			
		||||
     * does not insert if the exact set already exists
 | 
			
		||||
     * simple duplication check
 | 
			
		||||
     * @param table name of the database table
 | 
			
		||||
     * @param header String[] order should match with values
 | 
			
		||||
     * @param values String[] order should match with header
 | 
			
		||||
     * @return id of dataset or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static long insert(String table, String[] header, String[] values){
 | 
			
		||||
        long id = -1;
 | 
			
		||||
@@ -320,6 +327,7 @@ public class Database {
 | 
			
		||||
     * @param header the header of the table, order should match with values
 | 
			
		||||
     * @param values the data you want the id of, order should match witch values
 | 
			
		||||
     * @return one id matching the given data or -1 if no match has been found
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static long getSingleId(String table, String[] header, String[] values){
 | 
			
		||||
        long id = -1;
 | 
			
		||||
@@ -372,6 +380,7 @@ public class Database {
 | 
			
		||||
     * deletes an entry from table with matching id
 | 
			
		||||
     * @param table the table that contains the entry you want to delete
 | 
			
		||||
     * @param id the id of the entry you want to delete
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static void delete(String table, long id){
 | 
			
		||||
        String sql = "DELETE FROM " + table + " WHERE id = ?;";
 | 
			
		||||
@@ -383,6 +392,21 @@ public class Database {
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * its a query builder it builds queries
 | 
			
		||||
     * exists:       checks if an entry with the given parameters exists in table
 | 
			
		||||
     * selectMatch:  returns all matching rows from table
 | 
			
		||||
     * insert:       inserts or ignores into table
 | 
			
		||||
     * count:        counts exact matches from table
 | 
			
		||||
     * update:       updates table, header/values[0] is used as WHERE, using id is recommended header/values[1+] are used
 | 
			
		||||
     *               as SET
 | 
			
		||||
     * @param type exists, selectMatch, insert, count, update
 | 
			
		||||
     * @param table table
 | 
			
		||||
     * @param header header
 | 
			
		||||
     * @param values values
 | 
			
		||||
     * @return sql statement as String
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    private static String queryBuilder(String type,String table, String[] header, String[] values){
 | 
			
		||||
        String sql;
 | 
			
		||||
        StringBuilder sb = new StringBuilder();
 | 
			
		||||
@@ -479,6 +503,7 @@ public class Database {
 | 
			
		||||
     * returns a list of all entries
 | 
			
		||||
     * @param table the table you want
 | 
			
		||||
     * @return a list of all entries as String with the fields separated by ":"
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static List<String> getTable(String table){
 | 
			
		||||
        List<String> data = new ArrayList<>();
 | 
			
		||||
@@ -510,6 +535,7 @@ public class Database {
 | 
			
		||||
     * @param header header for the WHERE portion, order should match with values
 | 
			
		||||
     * @param values values for the WHERE portion, order should match with header
 | 
			
		||||
     * @return a list of the matching data as String separated by ":"
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static List<String> select(String table,String[] header, String[] values){
 | 
			
		||||
        List<String> data = new ArrayList<>();
 | 
			
		||||
@@ -541,6 +567,7 @@ public class Database {
 | 
			
		||||
     * @param table the table you want the entry from
 | 
			
		||||
     * @param id the id of the entry you want
 | 
			
		||||
     * @return a list of String separated by ":"
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static List<String> getEntryById(String table, long id){
 | 
			
		||||
        List<String> data = new ArrayList<>();
 | 
			
		||||
@@ -574,6 +601,7 @@ public class Database {
 | 
			
		||||
     * @param header the properties you want to count on
 | 
			
		||||
     * @param values the values for the properties
 | 
			
		||||
     * @return the number of found rows
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static int count(String table,String[] header,String[] values){
 | 
			
		||||
        String sql = queryBuilder("count",table,header,values);
 | 
			
		||||
@@ -592,6 +620,7 @@ public class Database {
 | 
			
		||||
     * @param header [0] is used as WHERE, everything else in SET
 | 
			
		||||
     * @param values [0] is used as WHERE, everything else in SET
 | 
			
		||||
     * @return number of rows affected or -1 on error
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    protected static int update(String table,String[] header,String[] values){
 | 
			
		||||
        try(Connection conn = connect()) {
 | 
			
		||||
 
 | 
			
		||||
@@ -1,10 +1,12 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Food, used by FoodPlan
 | 
			
		||||
 * one constructor is used to create new foods the other is used to create existing foods from database
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class Food {
 | 
			
		||||
    private long id;
 | 
			
		||||
    private String name;
 | 
			
		||||
 
 | 
			
		||||
@@ -1,16 +1,19 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * A collection of functions loosely related to food management
 | 
			
		||||
 * Acts as an abstraction layer to the database
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class FoodMgr {
 | 
			
		||||
    /**
 | 
			
		||||
     * inserts a food int to the database and creates the food_restriction entries
 | 
			
		||||
     * @param food the food to be created
 | 
			
		||||
     * @return id of food or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static long createFood(Food food){
 | 
			
		||||
        String[] foodH = {"name","description","isDessert","food_typeid"};
 | 
			
		||||
@@ -29,7 +32,9 @@ public class FoodMgr {
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * inserts a food_plan into the database
 | 
			
		||||
     * @param foodPlan the foodPlan to be created
 | 
			
		||||
     * @return id of food_plan or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static long createFood_plan(FoodPlan foodPlan){
 | 
			
		||||
        String[] food_planH = {"date","food1","food2","dessert1","dessert2"};
 | 
			
		||||
@@ -45,6 +50,7 @@ public class FoodMgr {
 | 
			
		||||
     * returns all non desserts or all desserts
 | 
			
		||||
     * @param isDessert true for only desserts false for non desserts
 | 
			
		||||
     * @return a list of all non desserts or all desserts
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static List<Food> getFood(boolean isDessert){
 | 
			
		||||
        String[] foodH = {"isDessert"};
 | 
			
		||||
@@ -62,6 +68,7 @@ public class FoodMgr {
 | 
			
		||||
     * getFood but returns only vegan food
 | 
			
		||||
     * @param isDessert true for only desserts false for non desserts
 | 
			
		||||
     * @return a list of all vegan non desserts or all vegan desserts
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static List<Food> getVeganFood(boolean isDessert){
 | 
			
		||||
        String[] foodH = {"isDessert","food_typeid"};
 | 
			
		||||
@@ -79,6 +86,7 @@ public class FoodMgr {
 | 
			
		||||
     * returns a food_plan for a day
 | 
			
		||||
     * @param date YYYY-MM-DD one day
 | 
			
		||||
     * @return food_plan for date
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static FoodPlan getFoodPlan(String date){
 | 
			
		||||
        String[] food_planH = {"date"};
 | 
			
		||||
@@ -93,8 +101,17 @@ public class FoodMgr {
 | 
			
		||||
        return new FoodPlan(Long.parseLong(parts[0]),date,foodVegan,foodSecond,dessertVegan,dessertSecond,isSent);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * returns a FoodPlan for a given id or null if no unique id was found
 | 
			
		||||
     * @param id id of the FoodPlan
 | 
			
		||||
     * @return FoodPlan or null
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static FoodPlan getFoodPlanById(long id){
 | 
			
		||||
        List<String> entry = Database.getEntryById("food_plan",id);
 | 
			
		||||
        if(entry.size() != 1){
 | 
			
		||||
            return null;
 | 
			
		||||
        }
 | 
			
		||||
        String[] parts = entry.get(0).split(":");
 | 
			
		||||
        Food foodVegan = getFoodById(Long.parseLong(parts[2]));
 | 
			
		||||
        Food foodSecond = getFoodById(Long.parseLong(parts[3]));
 | 
			
		||||
@@ -104,8 +121,17 @@ public class FoodMgr {
 | 
			
		||||
        return new FoodPlan(id,parts[1], foodVegan,foodSecond,dessertVegan,dessertSecond,isSent);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * returns a Food for a given id or null if no unique id was found
 | 
			
		||||
     * @param id id of the Food
 | 
			
		||||
     * @return Food or null
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static Food getFoodById(long id){
 | 
			
		||||
        List<String> entry = Database.getEntryById("food",id);
 | 
			
		||||
        if(entry.size() != 1){
 | 
			
		||||
            return null;
 | 
			
		||||
        }
 | 
			
		||||
        String[] parts = entry.get(0).split(":");
 | 
			
		||||
        String name = parts[1];
 | 
			
		||||
        String description = parts[2];
 | 
			
		||||
@@ -116,20 +142,44 @@ public class FoodMgr {
 | 
			
		||||
        return new Food(id,name,description,isDessert,foodType,allergies);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * returns a FoodType for a given id or null if no unique id was found
 | 
			
		||||
     * @param id id of the FoodType
 | 
			
		||||
     * @return FoodType or null
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static FoodType getFoodTypeById(long id){
 | 
			
		||||
        List<String> entry = Database.getEntryById("food_type",id);
 | 
			
		||||
        if(entry.size() != 1){
 | 
			
		||||
            return null;
 | 
			
		||||
        }
 | 
			
		||||
        String[] typeParts = entry.get(0).split(":");
 | 
			
		||||
        return new FoodType(Long.parseLong(typeParts[0]),typeParts[1]);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * returns an Allergy for a given id or null if no unique id was found
 | 
			
		||||
     * @param id id of the Allergy
 | 
			
		||||
     * @return Allergy or null
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static Allergy getAllergyById(long id){
 | 
			
		||||
        String[] allergyH = {"id"};
 | 
			
		||||
        String[] allergyD = {String.valueOf(id)};
 | 
			
		||||
        List<String> allergies = Database.select("allergy",allergyH,allergyD);
 | 
			
		||||
        String[] allergyParts = allergies.get(0).split(":");
 | 
			
		||||
        List<String> entry = Database.select("allergy",allergyH,allergyD);
 | 
			
		||||
        if(entry.size() != 1){
 | 
			
		||||
            return null;
 | 
			
		||||
        }
 | 
			
		||||
        String[] allergyParts = entry.get(0).split(":");
 | 
			
		||||
        return new Allergy(id,allergyParts[1],allergyParts[2]);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * returns all Allergies for a given foodId
 | 
			
		||||
     * @param foodId the foodId you want the allergies from
 | 
			
		||||
     * @return a List of Allergy, can be empty
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static List<Allergy> getAllergies(long foodId){
 | 
			
		||||
        List<Allergy> allergies = new ArrayList<>();
 | 
			
		||||
        String[] restrictionsH = {"foodid"};
 | 
			
		||||
@@ -146,11 +196,12 @@ public class FoodMgr {
 | 
			
		||||
     * inserts the selected food into food_Selection if the food_plan has not been sent
 | 
			
		||||
     * @param food_selectionData childid, food_planid, foodid
 | 
			
		||||
     * @return id or -1
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static long createFood_selection(String[] food_selectionData){
 | 
			
		||||
        String[] food_selectionH = {"childid","food_planid","foodid"};
 | 
			
		||||
        FoodPlan food_plan = getFoodPlanById(Long.parseLong(food_selectionData[1]));
 | 
			
		||||
        if(!food_plan.isSent()){
 | 
			
		||||
        if(food_plan != null && !food_plan.isSent()){
 | 
			
		||||
            return Database.insert("food_selection",food_selectionH,food_selectionData);
 | 
			
		||||
        }else {
 | 
			
		||||
            return -1;
 | 
			
		||||
@@ -161,6 +212,7 @@ public class FoodMgr {
 | 
			
		||||
     * accumulates the selected food for a given day and locks the corresponding food_plan
 | 
			
		||||
     * @param date YYYY-MM-DD day
 | 
			
		||||
     * @return the accumulated orders
 | 
			
		||||
     * @author Malte Schulze Hobeling
 | 
			
		||||
     */
 | 
			
		||||
    public static List<String> getDayOrder(String date){
 | 
			
		||||
        List<String> orders = new ArrayList<>();
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,10 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * FoodPlan
 | 
			
		||||
 * one constructor is used to create new foodPlans the other is used to create existing foodPlans from database
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class FoodPlan {
 | 
			
		||||
    private long id;
 | 
			
		||||
    private String date;
 | 
			
		||||
 
 | 
			
		||||
@@ -1,8 +1,9 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * FoodType used by Food, not intended to be changed
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class FoodType {
 | 
			
		||||
    private long id;
 | 
			
		||||
    private String name;
 | 
			
		||||
@@ -19,4 +20,5 @@ public class FoodType {
 | 
			
		||||
    public String getName() {
 | 
			
		||||
        return name;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,34 +0,0 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
 | 
			
		||||
import javafx.fxml.FXML;
 | 
			
		||||
import javafx.scene.control.Alert;
 | 
			
		||||
import javafx.scene.control.Label;
 | 
			
		||||
import javafx.scene.control.TextField;
 | 
			
		||||
 | 
			
		||||
public class HelloController {
 | 
			
		||||
    /**
 | 
			
		||||
     * @autor: Reshad Meher
 | 
			
		||||
     * Username, Passwort , login
 | 
			
		||||
     */
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField unsernameEingabe;
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField passwortEingabe;
 | 
			
		||||
    @FXML
 | 
			
		||||
    private Label lblAusgabe;
 | 
			
		||||
    @FXML
 | 
			
		||||
    protected void onLoginButtonClick() {
 | 
			
		||||
        String benutzerEingabe = unsernameEingabe.getText();
 | 
			
		||||
        String kennwortEingabe = passwortEingabe.getText();
 | 
			
		||||
        if(benutzerEingabe.contains("Reshad") && kennwortEingabe.contains("test123")){
 | 
			
		||||
            lblAusgabe.setText("Herzlich Willkommen, " + benutzerEingabe + "!");
 | 
			
		||||
        }else {
 | 
			
		||||
            Alert alert = new Alert(Alert.AlertType.ERROR,
 | 
			
		||||
                    "Die Benutzername oder Passwort ist falsch");
 | 
			
		||||
            alert.showAndWait();
 | 
			
		||||
        }
 | 
			
		||||
        unsernameEingabe.setText("");
 | 
			
		||||
        passwortEingabe.setText("");
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -1,3 +1,4 @@
 | 
			
		||||
/*Reshad Meher*/
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
 | 
			
		||||
import javafx.fxml.FXML;
 | 
			
		||||
@@ -6,10 +7,8 @@ import javafx.scene.Scene;
 | 
			
		||||
import javafx.scene.control.Alert;
 | 
			
		||||
import javafx.scene.control.PasswordField;
 | 
			
		||||
import javafx.scene.control.TextField;
 | 
			
		||||
import javafx.stage.Stage;
 | 
			
		||||
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
import java.util.HashMap;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
public class LoginController {
 | 
			
		||||
    @FXML
 | 
			
		||||
@@ -17,27 +16,27 @@ public class LoginController {
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private PasswordField pfPassword;
 | 
			
		||||
 | 
			
		||||
    HashMap<String,String> benutzerMap = new HashMap<String,String>();
 | 
			
		||||
    @FXML
 | 
			
		||||
    protected void  onBtLoginClick() throws IOException {
 | 
			
		||||
        benutzerMap.put("Reshad","1234");
 | 
			
		||||
        String email = tfEmail.getText();
 | 
			
		||||
        String password = pfPassword.getText();
 | 
			
		||||
        if(benutzerMap.containsKey(email) && benutzerMap.containsValue(password)){
 | 
			
		||||
            // if user is worker: StartViewApplication.changeScene("workerMenu-view.fxml");
 | 
			
		||||
            StartViewApplication.changeScene("parentMenu-view.fxml");
 | 
			
		||||
 | 
			
		||||
        long loginPruefen = AccountMgr.login(email,password);
 | 
			
		||||
        if(loginPruefen > 0){
 | 
			
		||||
            FXMLLoader fxmlLoader = new FXMLLoader(StartViewApplication.class.getResource("menue-view.fxml"));
 | 
			
		||||
            Scene scene = new Scene(fxmlLoader.load(), 950,700);
 | 
			
		||||
            StartViewApplication.primary.setScene(scene);
 | 
			
		||||
        }else {
 | 
			
		||||
            Alert alert = new Alert(Alert.AlertType.ERROR,"Email oder Passwort ist falsch");
 | 
			
		||||
            alert.showAndWait();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        tfEmail.setText("");
 | 
			
		||||
        pfPassword.setText("");
 | 
			
		||||
    }
 | 
			
		||||
    @FXML
 | 
			
		||||
    protected void changeToSignUp() throws IOException {
 | 
			
		||||
        StartViewApplication.changeScene("signUp-view.fxml");
 | 
			
		||||
    protected void onBtSingnupClick() throws IOException {
 | 
			
		||||
        FXMLLoader fxmlLoader = new FXMLLoader(StartViewApplication.class.getResource("signUp-view.fxml"));
 | 
			
		||||
        Scene scene = new Scene(fxmlLoader.load(), 950,700);
 | 
			
		||||
        StartViewApplication.primary.setScene(scene);
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,11 +1,12 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * one constructor is used to create new parents the other is used to create existing parents from database
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class Parent extends User{
 | 
			
		||||
    List<Child> children;
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,12 +0,0 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
 | 
			
		||||
import javafx.fxml.FXMLLoader;
 | 
			
		||||
import javafx.scene.Parent;
 | 
			
		||||
import javafx.scene.Scene;
 | 
			
		||||
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
import java.util.Objects;
 | 
			
		||||
 | 
			
		||||
public class SceneController {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
@@ -1,4 +0,0 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
 | 
			
		||||
public class SettingsController {
 | 
			
		||||
}
 | 
			
		||||
@@ -1,27 +1,95 @@
 | 
			
		||||
/** Reshad Meher*/
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
 | 
			
		||||
import javafx.fxml.FXML;
 | 
			
		||||
import javafx.fxml.FXMLLoader;
 | 
			
		||||
import javafx.scene.Scene;
 | 
			
		||||
import javafx.scene.control.Alert;
 | 
			
		||||
import javafx.scene.control.PasswordField;
 | 
			
		||||
import javafx.scene.control.TextField;
 | 
			
		||||
import javafx.stage.Stage;
 | 
			
		||||
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
import java.util.HashMap;
 | 
			
		||||
 | 
			
		||||
public class SingUpController {
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField tfLastName;
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField tfFirstName;
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField tfEmail;
 | 
			
		||||
    @FXML
 | 
			
		||||
    private PasswordField pfPassword;
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField tfPostCode;
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField tfCity;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField tfStreet;
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField tfHousNumber;
 | 
			
		||||
    @FXML
 | 
			
		||||
    private void onKontoErstellenBtClick(){
 | 
			
		||||
        String lastName = tfLastName.getText();
 | 
			
		||||
        String firstNanme = tfFirstName.getText();
 | 
			
		||||
        String email = tfEmail.getText();
 | 
			
		||||
        String password = pfPassword.getText();
 | 
			
		||||
        String postCode = tfPostCode.getText();
 | 
			
		||||
        String city = tfCity.getText();
 | 
			
		||||
        String street = tfStreet.getText();
 | 
			
		||||
        String housNumber = tfHousNumber.getText();
 | 
			
		||||
        Alert alert;
 | 
			
		||||
        if(lastName.isEmpty() || firstNanme.isEmpty() || email.isEmpty() || password.isEmpty() || postCode.isEmpty() ||
 | 
			
		||||
                city.isEmpty() || street.isEmpty() || housNumber.isEmpty()){
 | 
			
		||||
 | 
			
		||||
            if(lastName.isEmpty()){
 | 
			
		||||
                alert = new Alert(Alert.AlertType.ERROR," Die Eingabefeld 'Name'  ist leer.");
 | 
			
		||||
                alert.showAndWait();
 | 
			
		||||
            } else if (firstNanme.isEmpty()) {
 | 
			
		||||
                alert = new Alert(Alert.AlertType.ERROR," Die Eingabefeld  'Vorname' ist leer.");
 | 
			
		||||
                alert.showAndWait();
 | 
			
		||||
            } else if (email.isEmpty()) {
 | 
			
		||||
                alert = new Alert(Alert.AlertType.ERROR," Die Eingabefeld 'E-Mail' ist leer.");
 | 
			
		||||
                alert.showAndWait();
 | 
			
		||||
            } else if (password.isEmpty()) {
 | 
			
		||||
                alert = new Alert(Alert.AlertType.ERROR," Die Eingabefeld 'Passwort' ist leer.");
 | 
			
		||||
                alert.showAndWait();
 | 
			
		||||
            } else if (postCode.isEmpty()) {
 | 
			
		||||
                alert = new Alert(Alert.AlertType.ERROR," Die Eingabefeld 'Postleitzahl' ist leer.");
 | 
			
		||||
                alert.showAndWait();
 | 
			
		||||
            } else if (city.isEmpty()) {
 | 
			
		||||
                alert = new Alert(Alert.AlertType.ERROR," Die Eingabefeld 'Stadt' ist leer.");
 | 
			
		||||
                alert.showAndWait();
 | 
			
		||||
            } else if (street.isEmpty()) {
 | 
			
		||||
                alert = new Alert(Alert.AlertType.ERROR," Die Eingabefeld  'Straße' ist leer.");
 | 
			
		||||
                alert.showAndWait();
 | 
			
		||||
            }else {
 | 
			
		||||
                alert = new Alert(Alert.AlertType.ERROR," Die Eingabefeld  'Hausnummer' ist leer.");
 | 
			
		||||
                alert.showAndWait();
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
        }else {
 | 
			
		||||
            Address newAdresse = new Address(street,housNumber,postCode,city);
 | 
			
		||||
            User newUser = new User(lastName,firstNanme,password,email,newAdresse);
 | 
			
		||||
            long creatNewUser = AccountMgr.createUser(newUser);
 | 
			
		||||
            if (creatNewUser > 0){
 | 
			
		||||
                alert = new Alert(Alert.AlertType.CONFIRMATION,"Ihrer Daten wurde gespeichert.");
 | 
			
		||||
                alert.showAndWait();
 | 
			
		||||
            }
 | 
			
		||||
            tfLastName.setText("");
 | 
			
		||||
            tfFirstName.setText("");
 | 
			
		||||
            tfEmail.setText("");
 | 
			
		||||
            pfPassword.setText("");
 | 
			
		||||
            tfPostCode.setText("");
 | 
			
		||||
            tfCity.setText("");
 | 
			
		||||
            tfStreet.setText("");
 | 
			
		||||
            tfHousNumber.setText("");
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private void onAnmeldenBtClick() throws IOException {
 | 
			
		||||
 | 
			
		||||
        FXMLLoader fxmlLoader = new FXMLLoader(StartViewApplication.class.getResource("login-view.fxml"));
 | 
			
		||||
        Scene scene = new Scene(fxmlLoader.load(), 950,700);
 | 
			
		||||
        StartViewApplication.primary.setScene(scene);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,4 +0,0 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
 | 
			
		||||
public class StartPageController {
 | 
			
		||||
}
 | 
			
		||||
@@ -7,7 +7,6 @@ package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
 | 
			
		||||
import javafx.application.Application;
 | 
			
		||||
import javafx.fxml.FXMLLoader;
 | 
			
		||||
import javafx.scene.Parent;
 | 
			
		||||
import javafx.scene.Scene;
 | 
			
		||||
import javafx.stage.Stage;
 | 
			
		||||
 | 
			
		||||
@@ -15,11 +14,10 @@ import java.io.IOException;
 | 
			
		||||
 | 
			
		||||
public class StartViewApplication extends Application {
 | 
			
		||||
    public static Stage primary;
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public void start(Stage stage) throws IOException {
 | 
			
		||||
        FXMLLoader fxmlLoader = new FXMLLoader(StartViewApplication.class.getResource("login-view.fxml"));
 | 
			
		||||
        Scene scene = new Scene(fxmlLoader.load(), 1200, 750);
 | 
			
		||||
        Scene scene = new Scene(fxmlLoader.load(), 950,700);
 | 
			
		||||
        primary = stage;
 | 
			
		||||
        stage.setTitle("Essen Bestellung im Kindergarten");
 | 
			
		||||
        stage.setScene(scene);
 | 
			
		||||
@@ -34,9 +32,4 @@ public class StartViewApplication extends Application {
 | 
			
		||||
        //Database.deleteSample();
 | 
			
		||||
        launch();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static void changeScene(String scene) throws IOException {
 | 
			
		||||
        Parent p = FXMLLoader.load(StartViewApplication.class.getResource(scene));
 | 
			
		||||
        primary.getScene().setRoot(p);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -1,5 +1,10 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Acts as a launcher required to make it a .jar
 | 
			
		||||
 * It is also used to select either the cli or the gui depending on starting arguments
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class SuperMain {
 | 
			
		||||
    public static void main(String[] args) {
 | 
			
		||||
        if(args.length > 0){
 | 
			
		||||
 
 | 
			
		||||
@@ -1,8 +1,9 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * one constructor is used to create new users the other is used to create existing users from database
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class User {
 | 
			
		||||
    private long id;
 | 
			
		||||
    private String name;
 | 
			
		||||
 
 | 
			
		||||
@@ -1,8 +1,9 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
/*
 | 
			
		||||
    @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * one constructor is used to create new worker the other is used to create existing worker from database
 | 
			
		||||
 * @author Malte Schulze Hobeling
 | 
			
		||||
 */
 | 
			
		||||
public class Worker extends User{
 | 
			
		||||
    public Worker(long id, String name, String firstname, String password, String email, Address address) {
 | 
			
		||||
        super(id, name, firstname, password, email, address);
 | 
			
		||||
 
 | 
			
		||||
@@ -1,95 +0,0 @@
 | 
			
		||||
package com.bib.essensbestellungsverwaltung;
 | 
			
		||||
 | 
			
		||||
import javafx.fxml.FXML;
 | 
			
		||||
import javafx.fxml.FXMLLoader;
 | 
			
		||||
import javafx.scene.Parent;
 | 
			
		||||
import javafx.scene.control.Button;
 | 
			
		||||
import javafx.scene.input.MouseEvent;
 | 
			
		||||
import javafx.scene.layout.BorderPane;
 | 
			
		||||
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
 | 
			
		||||
public class WorkerMenuController {
 | 
			
		||||
    @FXML
 | 
			
		||||
    public BorderPane contentView;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    Button tagesbestellungButton;
 | 
			
		||||
    @FXML
 | 
			
		||||
    Button wochenplanButton;
 | 
			
		||||
    @FXML
 | 
			
		||||
    Button monatsabrechnungButton;
 | 
			
		||||
    @FXML
 | 
			
		||||
    Button mitarbeiterButton;
 | 
			
		||||
    @FXML
 | 
			
		||||
    Button mahlzeitButton;
 | 
			
		||||
    @FXML
 | 
			
		||||
    Button einstellungenButton;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    public void initialize() {
 | 
			
		||||
        changePage("menue-view.fxml");
 | 
			
		||||
        setButtonActive(tagesbestellungButton);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    public void onTagesbestellungenClick(MouseEvent mouseEvent) {
 | 
			
		||||
        changePage("menue-view.fxml");
 | 
			
		||||
        setButtonActive(tagesbestellungButton);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    public void onWochenplanClick(MouseEvent mouseEvent) {
 | 
			
		||||
        changePage("createFoodplan-view.fxml");
 | 
			
		||||
        setButtonActive(wochenplanButton);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    public void onMonatsabrechnungClick(MouseEvent mouseEvent) {
 | 
			
		||||
        changePage("invoice-view.fxml");
 | 
			
		||||
        setButtonActive(monatsabrechnungButton);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    public void onMitarbeiterClick(MouseEvent mouseEvent) {
 | 
			
		||||
        changePage("createCoworker-view.fxml");
 | 
			
		||||
        setButtonActive(mitarbeiterButton);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    public void onMahlzeitClick(MouseEvent mouseEvent) {
 | 
			
		||||
        changePage("createFood-view.fxml");
 | 
			
		||||
        setButtonActive(mahlzeitButton);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    public void onEinstellungenClick(MouseEvent mouseEvent) {
 | 
			
		||||
        setButtonActive(einstellungenButton);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    public void onAusloggenClick(MouseEvent mouseEvent) throws IOException {
 | 
			
		||||
        StartViewApplication.changeScene("parentMenu-view.fxml");
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private void changePage(String page) {
 | 
			
		||||
        try {
 | 
			
		||||
            Parent root = FXMLLoader.load(getClass().getResource(page));
 | 
			
		||||
            contentView.setCenter(root);
 | 
			
		||||
        } catch (IOException e) {
 | 
			
		||||
            throw new RuntimeException(e);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private void setButtonActive(Button b) {
 | 
			
		||||
        tagesbestellungButton.getStyleClass().remove("active");
 | 
			
		||||
        monatsabrechnungButton.getStyleClass().remove("active");
 | 
			
		||||
        wochenplanButton.getStyleClass().remove("active");
 | 
			
		||||
        mahlzeitButton.getStyleClass().remove("active");
 | 
			
		||||
        mitarbeiterButton.getStyleClass().remove("active");
 | 
			
		||||
        einstellungenButton.getStyleClass().remove("active");
 | 
			
		||||
        b.getStyleClass().add("active");
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -23,4 +23,5 @@
 | 
			
		||||
        <Button id="btDeletConfim" layoutX="390.0" layoutY="315.0" mnemonicParsing="false" prefHeight="53.0" prefWidth="141.0" text="Bestätigen" />
 | 
			
		||||
        <Button id="btDeleteDeny" layoutX="71.0" layoutY="315.0" mnemonicParsing="false" prefHeight="53.0" prefWidth="141.0" text="zurück" />
 | 
			
		||||
    </children>
 | 
			
		||||
 | 
			
		||||
</AnchorPane>
 | 
			
		||||
 
 | 
			
		||||
@@ -56,7 +56,7 @@
 | 
			
		||||
                     <font>
 | 
			
		||||
                        <Font name="Microsoft Tai Le Bold" size="12.0" />
 | 
			
		||||
                     </font></Button>
 | 
			
		||||
                  <Button id="btSignUp" mnemonicParsing="false" prefHeight="25.0" prefWidth="101.0" style="-fx-background-color: tranparent;" text="Sign up" textFill="#7c7b7b" underline="true" onAction="#changeToSignUp" />
 | 
			
		||||
                  <Button id="btSignUp" mnemonicParsing="false" prefHeight="25.0" prefWidth="101.0" style="-fx-background-color: tranparent;" text="Sign up" textFill="#7c7b7b" underline="true" onAction="#onBtSingnupClick" />
 | 
			
		||||
               </children>
 | 
			
		||||
            </HBox>
 | 
			
		||||
         </children>
 | 
			
		||||
 
 | 
			
		||||
@@ -32,9 +32,9 @@
 | 
			
		||||
                        </Label>
 | 
			
		||||
                        <VBox prefHeight="200.0" prefWidth="100.0">
 | 
			
		||||
                            <children>
 | 
			
		||||
                                <Button id="btFoodChoice" fx:id="btFirstMealMon" alignment="CENTER" mnemonicParsing="false" onAction="#setButtonActive" prefHeight="78.0" prefWidth="218.0" text="Mahlzeit 1" />
 | 
			
		||||
                                <Button id="btFoodChoice" fx:id="btSecondMealMon" alignment="CENTER" mnemonicParsing="false" onAction="#setButtonActive" prefHeight="78.0" prefWidth="218.0" text="Mahlzeit 2" />
 | 
			
		||||
                                <Button id="btFoodChoice" fx:id="btNoMealMon" alignment="CENTER" mnemonicParsing="false" onAction="#setButtonActive" prefHeight="20.0" prefWidth="170.0" text="Keine Mahlzeit">
 | 
			
		||||
                                <Button id="btFoodChoice" fx:id="btFirstMealMon" alignment="CENTER" mnemonicParsing="false" onAction="#setButtonActive" prefHeight="78.0" prefWidth="218.0" styleClass="btFood" text="Mahlzeit 1" />
 | 
			
		||||
                                <Button id="btFoodChoice" fx:id="btSecondMealMon" alignment="CENTER" mnemonicParsing="false" onAction="#setButtonActive" prefHeight="78.0" prefWidth="218.0" styleClass="btFood" text="Mahlzeit 2" />
 | 
			
		||||
                                <Button id="btFoodChoice" fx:id="btNoMealMon" alignment="CENTER" mnemonicParsing="false" onAction="#setButtonActive" prefHeight="20.0" prefWidth="170.0" styleClass="btFood" text="Keine Mahlzeit">
 | 
			
		||||
                                    <VBox.margin>
 | 
			
		||||
                                        <Insets bottom="20.0" />
 | 
			
		||||
                                    </VBox.margin>
 | 
			
		||||
 
 | 
			
		||||
@@ -1,10 +1,33 @@
 | 
			
		||||
.sidebar-nav_button {
 | 
			
		||||
    -fx-background-color: #69b6ff;
 | 
			
		||||
    -fx-text-fill: #123;
 | 
			
		||||
    -fx-border-color: #000;
 | 
			
		||||
    -fx-border-radius: 20;
 | 
			
		||||
}
 | 
			
		||||
.sidebar-nav_button.active {
 | 
			
		||||
    -fx-background-color: #4e92b4;
 | 
			
		||||
#btFoodChoice{
 | 
			
		||||
    -fx-background-color: transparent;
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#btFoodChoice:hover{
 | 
			
		||||
    -fx-underline: true;
 | 
			
		||||
    -fx-text-fill: black;
 | 
			
		||||
}
 | 
			
		||||
#btPlaceOrder{
 | 
			
		||||
    -fx-background-color: lightblue;
 | 
			
		||||
    -fx-text-fill: white;
 | 
			
		||||
    -fx-background-radius: 25;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#btPlaceOrder:hover{
 | 
			
		||||
    -fx-border-width: 0;
 | 
			
		||||
    -fx-text-fill: black;
 | 
			
		||||
    -fx-underline: true;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#cbChooseChild{
 | 
			
		||||
    -fx-background-color: lightgray;
 | 
			
		||||
}
 | 
			
		||||
.btFood{
 | 
			
		||||
    -fx-background-color: transparent;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.btFood.active{
 | 
			
		||||
    -fx-background-color: rgba(97, 97, 232, 0.3);
 | 
			
		||||
    -fx-background-radius: 25;
 | 
			
		||||
}
 | 
			
		||||
@@ -75,8 +75,9 @@
 | 
			
		||||
            </padding></VBox>
 | 
			
		||||
        <HBox id="contentContainer2" alignment="CENTER_RIGHT" prefHeight="40.0" prefWidth="1200.0" stylesheets="@parentMenue.css">
 | 
			
		||||
            <children>
 | 
			
		||||
            <Button id="btLogOut" mnemonicParsing="false" stylesheets="@parentMenue.css" text="Abmelden" />
 | 
			
		||||
                <Button id="btLogOut" mnemonicParsing="false" text="Abmelden" />
 | 
			
		||||
            </children>
 | 
			
		||||
        </HBox>
 | 
			
		||||
    </children>
 | 
			
		||||
 | 
			
		||||
</AnchorPane>
 | 
			
		||||
 
 | 
			
		||||
@@ -31,7 +31,7 @@
 | 
			
		||||
        <Circle fill="#93c4f23d" layoutY="258.0" radius="106.0" stroke="BLACK" strokeType="INSIDE" strokeWidth="0.0" />
 | 
			
		||||
        <VBox layoutX="262.0" prefHeight="400.0" prefWidth="364.0" style="-fx-background-color: white;">
 | 
			
		||||
            <children>
 | 
			
		||||
            <TextField fx:id="tfEmail" alignment="TOP_LEFT" prefHeight="26.0" prefWidth="282.0" promptText="Name" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                <TextField fx:id="tfLastName" alignment="TOP_LEFT" prefHeight="26.0" prefWidth="282.0" promptText="Name" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                    <effect>
 | 
			
		||||
                        <Blend />
 | 
			
		||||
                    </effect>
 | 
			
		||||
@@ -42,7 +42,7 @@
 | 
			
		||||
                        <Insets bottom="10.0" left="10.0" right="10.0" top="10.0" />
 | 
			
		||||
                    </VBox.margin>
 | 
			
		||||
                </TextField>
 | 
			
		||||
            <TextField fx:id="tfBestätigungEmail" promptText="Vorname" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                <TextField fx:id="tfFirstName" promptText="Vorname" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                    <effect>
 | 
			
		||||
                        <Blend />
 | 
			
		||||
                    </effect>
 | 
			
		||||
@@ -53,21 +53,18 @@
 | 
			
		||||
                        <Insets bottom="10.0" left="10.0" right="10.0" top="10.0" />
 | 
			
		||||
                    </VBox.margin>
 | 
			
		||||
                </TextField>
 | 
			
		||||
            <PasswordField fx:id="pfPasswort" accessibleRole="TEXT_FIELD" promptText="Email" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
               <font>
 | 
			
		||||
                  <Font name="Microsoft Tai Le Bold" size="12.0" />
 | 
			
		||||
               </font>
 | 
			
		||||
               <opaqueInsets>
 | 
			
		||||
                  <Insets />
 | 
			
		||||
               </opaqueInsets>
 | 
			
		||||
                <TextField fx:id="tfEmail" promptText="Email" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                    <effect>
 | 
			
		||||
                        <Blend />
 | 
			
		||||
                    </effect>
 | 
			
		||||
                    <font>
 | 
			
		||||
                        <Font name="Microsoft Tai Le Bold" size="12.0" />
 | 
			
		||||
                    </font>
 | 
			
		||||
                    <VBox.margin>
 | 
			
		||||
                        <Insets bottom="10.0" left="10.0" right="10.0" top="10.0" />
 | 
			
		||||
                    </VBox.margin>
 | 
			
		||||
            </PasswordField>
 | 
			
		||||
            <PasswordField fx:id="pfBestätigungPassowrt" promptText="Passwort" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                </TextField>
 | 
			
		||||
                <PasswordField fx:id="pfPassword" accessibleRole="TEXT_FIELD" promptText="Passwort" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                    <font>
 | 
			
		||||
                        <Font name="Microsoft Tai Le Bold" size="12.0" />
 | 
			
		||||
                    </font>
 | 
			
		||||
@@ -83,7 +80,7 @@
 | 
			
		||||
                </PasswordField>
 | 
			
		||||
                <HBox prefHeight="100.0" prefWidth="200.0">
 | 
			
		||||
                    <children>
 | 
			
		||||
                  <TextField prefHeight="35.0" prefWidth="92.0" promptText="PLZ" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                        <TextField  fx:id="tfPostCode" prefHeight="35.0" prefWidth="92.0" promptText="PLZ" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                            <HBox.margin>
 | 
			
		||||
                                <Insets bottom="10.0" left="10.0" right="10.0" top="10.0" />
 | 
			
		||||
                            </HBox.margin>
 | 
			
		||||
@@ -91,7 +88,7 @@
 | 
			
		||||
                                <Font name="Microsoft Tai Le Bold" size="12.0" />
 | 
			
		||||
                            </font>
 | 
			
		||||
                        </TextField>
 | 
			
		||||
                  <TextField prefHeight="35.0" prefWidth="182.0" promptText="Stadt" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                        <TextField fx:id="tfCity" prefHeight="35.0" prefWidth="182.0" promptText="Stadt" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                            <HBox.margin>
 | 
			
		||||
                                <Insets bottom="10.0" left="10.0" right="10.0" top="10.0" />
 | 
			
		||||
                            </HBox.margin>
 | 
			
		||||
@@ -103,7 +100,7 @@
 | 
			
		||||
                </HBox>
 | 
			
		||||
                <HBox prefHeight="100.0" prefWidth="200.0">
 | 
			
		||||
                    <children>
 | 
			
		||||
                  <TextField prefHeight="27.0" prefWidth="134.0" promptText="Straße" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                        <TextField  fx:id="tfStreet" prefHeight="27.0" prefWidth="134.0" promptText="Straße" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                            <HBox.margin>
 | 
			
		||||
                                <Insets bottom="10.0" left="10.0" right="10.0" top="10.0" />
 | 
			
		||||
                            </HBox.margin>
 | 
			
		||||
@@ -111,7 +108,7 @@
 | 
			
		||||
                                <Font name="Microsoft Tai Le Bold" size="12.0" />
 | 
			
		||||
                            </font>
 | 
			
		||||
                        </TextField>
 | 
			
		||||
                  <TextField prefHeight="27.0" prefWidth="99.0" promptText="Hausnummer" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                        <TextField  fx:id="tfHousNumber" prefHeight="27.0" prefWidth="99.0" promptText="Hausnummer" style="-fx-background-color: transparent; -fx-border-color: lightgray; -fx-border-width: 0 0 1 0;">
 | 
			
		||||
                            <HBox.margin>
 | 
			
		||||
                                <Insets bottom="10.0" left="10.0" right="10.0" top="10.0" />
 | 
			
		||||
                            </HBox.margin>
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user