17 Commits

Author SHA1 Message Date
laurimaaninka 2ed9f81f75 Merge remote-tracking branch 'origin/master' 2026-05-31 14:51:22 +03:00
laurimaaninka ebd76ab728 Versio 4.0.0
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-31 14:50:54 +03:00
laurimaaninka c8b0ae911a Versio 4.0.0
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-31 14:43:54 +03:00
laurimaaninka f192efda05 Koontiraportti ryhmitellään asiakkaan IDn, eikä nimen perusteella...
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-31 14:39:33 +03:00
laurimaaninka 127c9d671b Yhtenäinen TV_COLUMN_STYLE
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-31 14:18:15 +03:00
laurimaaninka 0634e8a13b Merge remote-tracking branch 'origin/master' 2026-05-31 14:15:59 +03:00
laurimaaninka 15c935d6b7 Kuljetusmäärät pois asiakashallinnasta
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-31 14:15:50 +03:00
laurimaaninka a6ea5890a1 Kuljetusmäärät pois asiakashallinnasta
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-31 14:15:31 +03:00
laurimaaninka d19142da97 Merge pull request 'Lounas-päivällinen erottelu kuljetuksiin' (#34) from lounas-päivällinen into master
Reviewed-on: #34
2026-05-31 14:00:14 +03:00
laurimaaninka ed76bab9a1 #27 Kuljetusraportittien näkymä vaihdettu lajiteltavaksi ja nollarivit pois raportilta
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-31 13:54:52 +03:00
laurimaaninka f5c37241ad #27 Lisätty oletusarvo kuljetustyypille tietokannan päivitystä varten
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-30 01:43:27 +03:00
laurimaaninka 892b75b18f #27 Ominaisuus muodollisesti valmis, vaatii vielä perusteellisempaa testausta
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-30 01:36:22 +03:00
laurimaaninka 13110641b3 Merge remote-tracking branch 'origin/lounas-päivällinen' into lounas-päivällinen 2026-05-30 01:34:08 +03:00
laurimaaninka 7fa2ccfd25 #27 Kuljetustyyppi raporteille
Ominaisuus muodollisesti valmis, vaatii vielä testausta

Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-30 01:34:01 +03:00
laurimaaninka 67b2b92b51 Kuljetustyyppi raporteille
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-30 01:31:34 +03:00
laurimaaninka 853bda3a4b Merge remote-tracking branch 'origin/lounas-päivällinen' into lounas-päivällinen 2026-05-30 00:53:06 +03:00
laurimaaninka b4eecb3d67 Kuljetus ymmärtämään tyyppiä
Signed-off-by: laurimaaninka <lauri.maaninka@gmail.com>
2026-05-30 00:52:59 +03:00
12 changed files with 109 additions and 80 deletions
+1 -1
View File
@@ -3,7 +3,7 @@
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<groupId>fi.lpam.ruokamanageri</groupId> <groupId>fi.lpam.ruokamanageri</groupId>
<artifactId>Ruokamanageri</artifactId> <artifactId>Ruokamanageri</artifactId>
<version>3.2.1</version> <version>4.0.0</version>
<properties> <properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>25</maven.compiler.source> <maven.compiler.source>25</maven.compiler.source>
@@ -1,7 +1,6 @@
package fi.lpam.dataluokat; package fi.lpam.dataluokat;
import fi.lpam.gui.virheDialogit.SiirtoVirhe; import fi.lpam.gui.virheDialogit.SiirtoVirhe;
import org.apache.commons.lang3.NotImplementedException;
import java.sql.*; import java.sql.*;
import java.time.DayOfWeek; import java.time.DayOfWeek;
@@ -353,22 +352,22 @@ public class Asiakas implements TietokantaOlio {
public int getKuljetuksenSalaatit(LocalDate päivä, Kuljetus.Tyyppi tyyppi) { public int getKuljetuksenSalaatit(LocalDate päivä, Kuljetus.Tyyppi tyyppi) {
return switch (tyyppi) { return switch (tyyppi) {
case Kuljetus.Tyyppi.LOUNAS -> getLounasKuljetusKerroin(päivä) * getSalaatit(); case Kuljetus.Tyyppi.Lounas -> getLounasKuljetusKerroin(päivä) * getSalaatit();
case Kuljetus.Tyyppi.PÄIVÄLLINEN -> getPäivällisKuljetusKerroin(päivä) * getDinnerSalaatit(); case Kuljetus.Tyyppi.Päivällinen -> getPäivällisKuljetusKerroin(päivä) * getDinnerSalaatit();
}; };
} }
public int getKuljetuksenPääruoat(LocalDate päivä, Kuljetus.Tyyppi tyyppi) { public int getKuljetuksenPääruoat(LocalDate päivä, Kuljetus.Tyyppi tyyppi) {
return switch (tyyppi) { return switch (tyyppi) {
case Kuljetus.Tyyppi.LOUNAS -> getLounasKuljetusKerroin(päivä) * getPääruoat(); case Kuljetus.Tyyppi.Lounas -> getLounasKuljetusKerroin(päivä) * getPääruoat();
case Kuljetus.Tyyppi.PÄIVÄLLINEN -> getPäivällisKuljetusKerroin(päivä) * getDinnerPääruoat(); case Kuljetus.Tyyppi.Päivällinen -> getPäivällisKuljetusKerroin(päivä) * getDinnerPääruoat();
}; };
} }
public int getKuljetuksenJälkiruoat(LocalDate päivä, Kuljetus.Tyyppi tyyppi) { public int getKuljetuksenJälkiruoat(LocalDate päivä, Kuljetus.Tyyppi tyyppi) {
return switch (tyyppi) { return switch (tyyppi) {
case Kuljetus.Tyyppi.LOUNAS -> getLounasKuljetusKerroin(päivä) * getJälkiruoat(); case Kuljetus.Tyyppi.Lounas -> getLounasKuljetusKerroin(päivä) * getJälkiruoat();
case Kuljetus.Tyyppi.PÄIVÄLLINEN -> getPäivällisKuljetusKerroin(päivä) * getDinnerJälkiruoat(); case Kuljetus.Tyyppi.Päivällinen -> getPäivällisKuljetusKerroin(päivä) * getDinnerJälkiruoat();
}; };
} }
+30 -13
View File
@@ -9,8 +9,8 @@ import java.util.ArrayList;
@SuppressWarnings("DuplicatedCode") @SuppressWarnings("DuplicatedCode")
public class Kuljetus implements TietokantaOlio { public class Kuljetus implements TietokantaOlio {
public enum Tyyppi { public enum Tyyppi {
LOUNAS(), Lounas,
PÄIVÄLLINEN(); Päivällinen;
} }
private int id = -1; private int id = -1;
@@ -71,6 +71,7 @@ public class Kuljetus implements TietokantaOlio {
this.nimi = nimi; this.nimi = nimi;
this.kuljetusPäivämäärä = kuljetusPäivämäärä; this.kuljetusPäivämäärä = kuljetusPäivämäärä;
this.kuljetusKierros = kuljetusKierros; this.kuljetusKierros = kuljetusKierros;
this.tyyppi = tyyppi;
this.salaatit = salaatit; this.salaatit = salaatit;
this.pääruoat = pääruoat; this.pääruoat = pääruoat;
this.jälkiruoat = jälkiruoat; this.jälkiruoat = jälkiruoat;
@@ -84,13 +85,15 @@ public class Kuljetus implements TietokantaOlio {
* Hakee tietyn kierroksen kuljetukset * Hakee tietyn kierroksen kuljetukset
* @param päivä kierroksen päivä * @param päivä kierroksen päivä
* @param kuljetusKierros kierroksen numero * @param kuljetusKierros kierroksen numero
* @param tyyppi kuljetuksen tyyppi
* @return valitun päivän valitun kierroksen kuljetukset * @return valitun päivän valitun kierroksen kuljetukset
*/ */
public static ArrayList<Kuljetus> haePäivänKuljetuksetKierroksella(LocalDate päivä, int kuljetusKierros) { public static ArrayList<Kuljetus> haeKierroksenKuljetukset(LocalDate päivä, int kuljetusKierros, Tyyppi tyyppi) {
try (Connection tietokanta = Tietokanta.haeYhteys()) { try (Connection tietokanta = Tietokanta.haeYhteys()) {
PreparedStatement stmt = tietokanta.prepareStatement("SELECT * FROM kuljetukset WHERE kuljetusKierros = ? and kuljetusPäivämäärä = ?"); PreparedStatement stmt = tietokanta.prepareStatement("SELECT * FROM kuljetukset WHERE kuljetusKierros = ? and kuljetusPäivämäärä = ? and tyyppi = ?");
stmt.setInt(1, kuljetusKierros); stmt.setInt(1, kuljetusKierros);
stmt.setDate(2, Date.valueOf(päivä)); stmt.setDate(2, Date.valueOf(päivä));
stmt.setString(3, tyyppi.toString());
ResultSet rs = stmt.executeQuery(); ResultSet rs = stmt.executeQuery();
return parsiResultSet(rs); return parsiResultSet(rs);
} catch (SQLException e) { } catch (SQLException e) {
@@ -103,18 +106,19 @@ public class Kuljetus implements TietokantaOlio {
@Override @Override
public boolean tallennaUusi() { public boolean tallennaUusi() {
try (Connection tietokanta = Tietokanta.haeYhteys()) { try (Connection tietokanta = Tietokanta.haeYhteys()) {
PreparedStatement stmt = tietokanta.prepareStatement("INSERT INTO kuljetukset (asiakasID, nimi, kuljetusPäivämäärä, kuljetusKierros, salaatit, pääruoat, jälkiruoat, ruokarajoite, osoite, avainTieto, lisätieto) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)", Statement.RETURN_GENERATED_KEYS); PreparedStatement stmt = tietokanta.prepareStatement("INSERT INTO kuljetukset (asiakasID, nimi, kuljetusPäivämäärä, kuljetusKierros, tyyppi, salaatit, pääruoat, jälkiruoat, ruokarajoite, osoite, avainTieto, lisätieto) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)", Statement.RETURN_GENERATED_KEYS);
stmt.setInt(1, asiakasID); stmt.setInt(1, asiakasID);
stmt.setString(2, nimi); stmt.setString(2, nimi);
stmt.setDate(3, Date.valueOf(kuljetusPäivämäärä)); stmt.setDate(3, Date.valueOf(kuljetusPäivämäärä));
stmt.setInt(4, kuljetusKierros); stmt.setInt(4, kuljetusKierros);
stmt.setInt(5, salaatit); stmt.setString(5, tyyppi.toString());
stmt.setInt(6, pääruoat); stmt.setInt(6, salaatit);
stmt.setInt(7, jälkiruoat); stmt.setInt(7, pääruoat);
stmt.setString(8, ruokarajoite); stmt.setInt(8, jälkiruoat);
stmt.setString(9, osoite); stmt.setString(9, ruokarajoite);
stmt.setString(10, avainTieto); stmt.setString(10, osoite);
stmt.setString(11, lisätieto); stmt.setString(11, avainTieto);
stmt.setString(12, lisätieto);
int muokatutRivit = stmt.executeUpdate(); int muokatutRivit = stmt.executeUpdate();
if (muokatutRivit == 0) { if (muokatutRivit == 0) {
@@ -203,8 +207,12 @@ public class Kuljetus implements TietokantaOlio {
rs.getString("lisätieto"), rs.getString("lisätieto"),
rs.getString("avainTieto"), rs.getString("avainTieto"),
rs.getString("ruokarajoite"), rs.getString("ruokarajoite"),
Tyyppi.valueOf(rs.getString("tyyppi")) Tyyppi.valueOf(rs.getString("tyyppi").strip())
); );
System.out.println(rs.getString("tyyppi").equals(Tyyppi.Lounas.toString()));
System.out.println(Tyyppi.Lounas);
System.out.println(uusi.getTyyppi());
System.out.println(Tyyppi.valueOf(rs.getString("tyyppi")));
kuljetukset.add(uusi); kuljetukset.add(uusi);
} }
} catch (SQLException e) { } catch (SQLException e) {
@@ -222,6 +230,7 @@ public class Kuljetus implements TietokantaOlio {
", nimi='" + nimi + '\'' + ", nimi='" + nimi + '\'' +
", kuljetusPäivämäärä=" + kuljetusPäivämäärä + ", kuljetusPäivämäärä=" + kuljetusPäivämäärä +
", kuljetusKierros=" + kuljetusKierros + ", kuljetusKierros=" + kuljetusKierros +
", tyyppi =" + tyyppi +
", salaatit=" + salaatit + ", salaatit=" + salaatit +
", pääruoat=" + pääruoat + ", pääruoat=" + pääruoat +
", jälkiruoat=" + jälkiruoat + ", jälkiruoat=" + jälkiruoat +
@@ -345,4 +354,12 @@ public class Kuljetus implements TietokantaOlio {
public void setRuokarajoite(String ruokarajoite) { public void setRuokarajoite(String ruokarajoite) {
this.ruokarajoite = ruokarajoite; this.ruokarajoite = ruokarajoite;
} }
public Tyyppi getTyyppi() {
return tyyppi;
}
public void setTyyppi(Tyyppi tyyppi) {
this.tyyppi = tyyppi;
}
} }
@@ -10,12 +10,13 @@ import java.util.ArrayList;
public class RaporttiRivi { public class RaporttiRivi {
private final String nimi; private final String nimi;
private final LocalDate pvm; private final LocalDate pvm;
private final Kuljetus.Tyyppi tyyppi;
private final int salaatit, pääruoat, jälkiruoat; private final int salaatit, pääruoat, jälkiruoat;
private final String erva; private final String erva;
private final String lisätiedot; private final String lisätiedot;
private final String yhteyshenkilönNimi, laskutusOsoite, yhteyshenkilönPuhelinnumero, yhteyshenkilönSähköposti; private final String yhteyshenkilönNimi, laskutusOsoite, yhteyshenkilönPuhelinnumero, yhteyshenkilönSähköposti;
public RaporttiRivi(String nimi, private RaporttiRivi(String nimi,
LocalDate pvm, LocalDate pvm,
int salaatit, int salaatit,
int pääruoat, int pääruoat,
@@ -25,9 +26,11 @@ public class RaporttiRivi {
String laskutusOsoite, String laskutusOsoite,
String yhteyshenkilönPuhelinnumero, String yhteyshenkilönPuhelinnumero,
String yhteyshenkilönSähköposti, String yhteyshenkilönSähköposti,
String erva) { String erva,
Kuljetus.Tyyppi tyyppi) {
this.nimi = nimi; this.nimi = nimi;
this.pvm = pvm; this.pvm = pvm;
this.tyyppi = tyyppi;
this.salaatit = salaatit; this.salaatit = salaatit;
this.pääruoat = pääruoat; this.pääruoat = pääruoat;
this.jälkiruoat = jälkiruoat; this.jälkiruoat = jälkiruoat;
@@ -57,11 +60,12 @@ public class RaporttiRivi {
asiakkaat.laskutusosoite, asiakkaat.laskutusosoite,
asiakkaat.yhteyshenkilönPuhelinnumero, asiakkaat.yhteyshenkilönPuhelinnumero,
asiakkaat.yhteyshenkilönSähköposti, asiakkaat.yhteyshenkilönSähköposti,
asiakkaat.erityisruokavalio asiakkaat.erityisruokavalio,
kuljetukset.tyyppi
from kuljetukset from kuljetukset
left join asiakkaat on kuljetukset.asiakasID=asiakkaat.id left join asiakkaat on kuljetukset.asiakasID=asiakkaat.id
where kuljetusPäivämäärä between ? and ? where (kuljetusPäivämäärä between ? and ?) and (kuljetukset.salaatit > 0 or kuljetukset.pääruoat > 0 or kuljetukset.jälkiruoat > 0 or LENGTH(kuljetukset.lisätieto) > 3)
order by kuljetukset.nimi order by asiakkaat.yhteyshenkilönNimi DESC, kuljetukset.nimi, kuljetukset.kuljetusPäivämäärä, kuljetukset.tyyppi
"""); """);
stmt.setDate(1, Date.valueOf(alkuPvm)); stmt.setDate(1, Date.valueOf(alkuPvm));
stmt.setDate(2, Date.valueOf(loppuPvm)); stmt.setDate(2, Date.valueOf(loppuPvm));
@@ -80,7 +84,8 @@ public class RaporttiRivi {
rs.getString(i++), rs.getString(i++),
rs.getString(i++), rs.getString(i++),
rs.getString(i++), rs.getString(i++),
rs.getString(i++) rs.getString(i++),
Kuljetus.Tyyppi.valueOf(rs.getString(i++))
); );
raportti.add(uusi); raportti.add(uusi);
} }
@@ -99,12 +104,13 @@ public class RaporttiRivi {
asiakkaat.laskutusosoite, asiakkaat.laskutusosoite,
asiakkaat.yhteyshenkilönPuhelinnumero, asiakkaat.yhteyshenkilönPuhelinnumero,
asiakkaat.yhteyshenkilönSähköposti, asiakkaat.yhteyshenkilönSähköposti,
asiakkaat.erityisruokavalio asiakkaat.erityisruokavalio,
kuljetukset.tyyppi
from kuljetukset from kuljetukset
left join asiakkaat on kuljetukset.asiakasID=asiakkaat.id left join asiakkaat on kuljetukset.asiakasID=asiakkaat.id
where kuljetusPäivämäärä between ? and ? where (kuljetusPäivämäärä between ? and ?) and (kuljetukset.salaatit > 0 or kuljetukset.pääruoat > 0 or kuljetukset.jälkiruoat > 0 or LENGTH(kuljetukset.lisätieto) > 3)
group by kuljetukset.nimi group by kuljetukset.asiakasID, kuljetukset.tyyppi
order by kuljetukset.nimi order by asiakkaat.yhteyshenkilönNimi DESC, kuljetukset.nimi, kuljetukset.kuljetusPäivämäärä, kuljetukset.tyyppi
"""); """);
stmt.setString(1, "\n"); stmt.setString(1, "\n");
stmt.setDate(2, Date.valueOf(alkuPvm)); stmt.setDate(2, Date.valueOf(alkuPvm));
@@ -124,7 +130,8 @@ public class RaporttiRivi {
rs.getString(i++), rs.getString(i++),
rs.getString(i++), rs.getString(i++),
rs.getString(i++), rs.getString(i++),
rs.getString(i++) rs.getString(i++),
Kuljetus.Tyyppi.valueOf(rs.getString(i++))
); );
raportti.add(uusi); raportti.add(uusi);
} }
@@ -145,7 +152,7 @@ public class RaporttiRivi {
"\n" + yhteyshenkilönSähköposti; "\n" + yhteyshenkilönSähköposti;
return nimi + " " + erva + return nimi + " " + erva +
"\nSal: " + salaatit + ", Pr: " + pääruoat + ", Jr: " + jälkiruoat + "\n" + tyyppi + " Sal: " + salaatit + ", Pr: " + pääruoat + ", Jr: " + jälkiruoat +
"\nLisätiedot:\n" + "\nLisätiedot:\n" +
getLisätiedot() + getLisätiedot() +
laskutustiedot.replace("\nnull", "").strip(); laskutustiedot.replace("\nnull", "").strip();
@@ -195,4 +202,8 @@ public class RaporttiRivi {
public String getErva() { public String getErva() {
return erva; return erva;
} }
public Kuljetus.Tyyppi getTyyppi() {
return tyyppi;
}
} }
+2 -2
View File
@@ -330,8 +330,8 @@ public class AsiakasIkkuna extends Stage {
alert.setTitle("Onnistuimme!"); alert.setTitle("Onnistuimme!");
alert.setHeaderText("Asiakkaan tallentaminen onnistui!"); alert.setHeaderText("Asiakkaan tallentaminen onnistui!");
//TODO tähän myös dinneri määrät... //TODO tähän myös dinneri määrät...
// alert.setContentText(String.format("%s saa jatkossa yhteensä \n%s salaattia, %s pääruokaa ja %s jälkiruokaa viikossa", alert.setContentText(String.format("%s saa lounaalla yhteensä \n%s salaattia, %s pääruokaa ja %s jälkiruokaa viikossa",
// käsiteltäväAsiakas.getNimi(), käsiteltäväAsiakas.getSalaatit()*viikonKuljetukset, käsiteltäväAsiakas.getPääruoat()*viikonKuljetukset, käsiteltäväAsiakas.getPääruoat()*viikonKuljetukset)); käsiteltäväAsiakas.getNimi(), käsiteltäväAsiakas.getSalaatit()*viikonKuljetukset, käsiteltäväAsiakas.getPääruoat()*viikonKuljetukset, käsiteltäväAsiakas.getPääruoat()*viikonKuljetukset));
alert.showAndWait(); alert.showAndWait();
this.close(); this.close();
} }
+27 -33
View File
@@ -1,9 +1,7 @@
package fi.lpam.gui; package fi.lpam.gui;
import fi.lpam.Main;
import fi.lpam.dataluokat.Asiakas; import fi.lpam.dataluokat.Asiakas;
import fi.lpam.gui.elementit.FontLabel; import fi.lpam.gui.elementit.FontLabel;
import fi.lpam.gui.elementit.MaaraTableColumn;
import fi.lpam.gui.elementit.TabPohja; import fi.lpam.gui.elementit.TabPohja;
import javafx.collections.FXCollections; import javafx.collections.FXCollections;
import javafx.scene.control.*; import javafx.scene.control.*;
@@ -56,31 +54,31 @@ public class Asiakashallinta extends TabPohja {
tcOsoite.setCellValueFactory(new PropertyValueFactory<>("osoite")); tcOsoite.setCellValueFactory(new PropertyValueFactory<>("osoite"));
int minWidth = 40; int minWidth = 40;
TableColumn<Asiakas, MaaraTableColumn<Asiakas, Integer>> tcKuljetuspäivät = new TableColumn<>("Kuljetukset per päivä"); // TableColumn<Asiakas, MaaraTableColumn<Asiakas, Integer>> tcKuljetuspäivät = new TableColumn<>("Kuljetukset per päivä");
MaaraTableColumn<Asiakas, Integer> tcMaanantaiKpl = new MaaraTableColumn<>("MA", minWidth); // MaaraTableColumn<Asiakas, Integer> tcMaanantaiKpl = new MaaraTableColumn<>("MA", minWidth);
tcMaanantaiKpl.setCellValueFactory(new PropertyValueFactory<>("maanantaiKpl")); // tcMaanantaiKpl.setCellValueFactory(new PropertyValueFactory<>("maanantaiKpl"));
MaaraTableColumn<Asiakas, Integer> tcTiistaiKpl = new MaaraTableColumn<>("TI", minWidth); // MaaraTableColumn<Asiakas, Integer> tcTiistaiKpl = new MaaraTableColumn<>("TI", minWidth);
tcTiistaiKpl.setCellValueFactory(new PropertyValueFactory<>("tiistaiKpl")); // tcTiistaiKpl.setCellValueFactory(new PropertyValueFactory<>("tiistaiKpl"));
MaaraTableColumn<Asiakas, Integer> tcKeskiviikkoKpl = new MaaraTableColumn<>("KE", minWidth); // MaaraTableColumn<Asiakas, Integer> tcKeskiviikkoKpl = new MaaraTableColumn<>("KE", minWidth);
tcKeskiviikkoKpl.setCellValueFactory(new PropertyValueFactory<>("keskiviikkoKpl")); // tcKeskiviikkoKpl.setCellValueFactory(new PropertyValueFactory<>("keskiviikkoKpl"));
MaaraTableColumn<Asiakas, Integer> tcTorstaiKpl = new MaaraTableColumn<>("TO", minWidth); // MaaraTableColumn<Asiakas, Integer> tcTorstaiKpl = new MaaraTableColumn<>("TO", minWidth);
tcTorstaiKpl.setCellValueFactory(new PropertyValueFactory<>("torstaiKpl")); // tcTorstaiKpl.setCellValueFactory(new PropertyValueFactory<>("torstaiKpl"));
MaaraTableColumn<Asiakas, Integer> tcPerjantaiKpl = new MaaraTableColumn<>("PE", minWidth); // MaaraTableColumn<Asiakas, Integer> tcPerjantaiKpl = new MaaraTableColumn<>("PE", minWidth);
tcPerjantaiKpl.setCellValueFactory(new PropertyValueFactory<>("perjantaiKpl")); // tcPerjantaiKpl.setCellValueFactory(new PropertyValueFactory<>("perjantaiKpl"));
MaaraTableColumn<Asiakas, Integer> tcLauantaiKpl = new MaaraTableColumn<>("LA", minWidth); // MaaraTableColumn<Asiakas, Integer> tcLauantaiKpl = new MaaraTableColumn<>("LA", minWidth);
tcLauantaiKpl.setCellValueFactory(new PropertyValueFactory<>("lauantaiKpl")); // tcLauantaiKpl.setCellValueFactory(new PropertyValueFactory<>("lauantaiKpl"));
MaaraTableColumn<Asiakas, Integer> tcSunnuntaiKpl = new MaaraTableColumn<>("SU", minWidth); // MaaraTableColumn<Asiakas, Integer> tcSunnuntaiKpl = new MaaraTableColumn<>("SU", minWidth);
tcSunnuntaiKpl.setCellValueFactory(new PropertyValueFactory<>("sunnuntaiKpl")); // tcSunnuntaiKpl.setCellValueFactory(new PropertyValueFactory<>("sunnuntaiKpl"));
tcKuljetuspäivät.getColumns().addAll(tcMaanantaiKpl, tcTiistaiKpl, tcKeskiviikkoKpl, tcTorstaiKpl, tcPerjantaiKpl, tcLauantaiKpl, tcSunnuntaiKpl); // tcKuljetuspäivät.getColumns().addAll(tcMaanantaiKpl, tcTiistaiKpl, tcKeskiviikkoKpl, tcTorstaiKpl, tcPerjantaiKpl, tcLauantaiKpl, tcSunnuntaiKpl);
//
TableColumn<Asiakas, MaaraTableColumn<Asiakas, Integer>> tcKuljetusmäärät = new TableColumn<>("Määrät per kuljetus"); // TableColumn<Asiakas, MaaraTableColumn<Asiakas, Integer>> tcKuljetusmäärät = new TableColumn<>("Määrät per kuljetus");
MaaraTableColumn<Asiakas, Integer> tcSalaatit = new MaaraTableColumn<>("Salaatit", minWidth, 150); // MaaraTableColumn<Asiakas, Integer> tcSalaatit = new MaaraTableColumn<>("Salaatit", minWidth, 150);
tcSalaatit.setCellValueFactory(new PropertyValueFactory<>("salaatit")); // tcSalaatit.setCellValueFactory(new PropertyValueFactory<>("salaatit"));
MaaraTableColumn<Asiakas, Integer> tcPääruoat = new MaaraTableColumn<>("Pääruoat", minWidth, 150); // MaaraTableColumn<Asiakas, Integer> tcPääruoat = new MaaraTableColumn<>("Pääruoat", minWidth, 150);
tcPääruoat.setCellValueFactory(new PropertyValueFactory<>("pääruoat")); // tcPääruoat.setCellValueFactory(new PropertyValueFactory<>("pääruoat"));
MaaraTableColumn<Asiakas, Integer> tcJälkiruoat = new MaaraTableColumn<>("Jälkiruoat", minWidth, 150); // MaaraTableColumn<Asiakas, Integer> tcJälkiruoat = new MaaraTableColumn<>("Jälkiruoat", minWidth, 150);
tcJälkiruoat.setCellValueFactory(new PropertyValueFactory<>("jälkiruoat")); // tcJälkiruoat.setCellValueFactory(new PropertyValueFactory<>("jälkiruoat"));
tcKuljetusmäärät.getColumns().addAll(tcSalaatit, tcPääruoat, tcJälkiruoat); // tcKuljetusmäärät.getColumns().addAll(tcSalaatit, tcPääruoat, tcJälkiruoat);
TableColumn<Asiakas, String> tcErityisruokavalio = new TableColumn<>("Ruokarajoitteet"); TableColumn<Asiakas, String> tcErityisruokavalio = new TableColumn<>("Ruokarajoitteet");
tcErityisruokavalio.setCellValueFactory(new PropertyValueFactory<>("erityisruokavalio")); tcErityisruokavalio.setCellValueFactory(new PropertyValueFactory<>("erityisruokavalio"));
@@ -97,7 +95,7 @@ public class Asiakashallinta extends TabPohja {
TableColumn<Asiakas, String> tcYhteyshenkilönSähköposti = new TableColumn<>("Yhteyshenkilön sähköposti"); TableColumn<Asiakas, String> tcYhteyshenkilönSähköposti = new TableColumn<>("Yhteyshenkilön sähköposti");
tcYhteyshenkilönSähköposti.setCellValueFactory(new PropertyValueFactory<>("yhteyshenkilönSähköposti")); tcYhteyshenkilönSähköposti.setCellValueFactory(new PropertyValueFactory<>("yhteyshenkilönSähköposti"));
tvAsiakkaat.getColumns().addAll(tcId, tcNimi, tcOsoite, tcKuljetuspäivät, tcKuljetusmäärät, tcErityisruokavalio, tcAvainTieto, tcLisätiedot, tcYhteyshenkilönNimi, tcLaskutusOsoite, tcYhteyshenkilönPuhelinnumero, tcYhteyshenkilönSähköposti); tvAsiakkaat.getColumns().addAll(tcId, tcNimi, tcOsoite, tcErityisruokavalio, tcAvainTieto, tcLisätiedot, tcYhteyshenkilönNimi, tcLaskutusOsoite, tcYhteyshenkilönPuhelinnumero, tcYhteyshenkilönSähköposti);
for (TableColumn<Asiakas, ?> column : tvAsiakkaat.getColumns()) { for (TableColumn<Asiakas, ?> column : tvAsiakkaat.getColumns()) {
column.getColumns().forEach(this::määritäColumn); column.getColumns().forEach(this::määritäColumn);
@@ -191,10 +189,6 @@ public class Asiakashallinta extends TabPohja {
column.setEditable(false); column.setEditable(false);
column.setReorderable(false); column.setReorderable(false);
column.setResizable(true); column.setResizable(true);
column.setStyle( column.setStyle(TV_COLUMN_STYLE);
"-fx-alignment: CENTER;" +
"-fx-font-size: " + Main.properties.getProperty("tekstiFonttiKoko") + "px;" +
"-fx-font-family: " + Main.properties.getProperty("tekstiFontti")
);
} }
} }
@@ -143,10 +143,7 @@ public class KuljetusListat extends TabPohja {
sarake.setSortable(false); sarake.setSortable(false);
sarake.setEditable(true); sarake.setEditable(true);
sarake.setResizable(true); sarake.setResizable(true);
sarake.setStyle( sarake.setStyle(TV_COLUMN_STYLE);
"-fx-alignment: CENTER;" +
"-fx-font-size: " + Main.properties.getProperty("tekstiFonttiKoko") + "px;" +
"-fx-font-family: " + Main.properties.getProperty("tekstiFontti"));
} }
tcNimi.setEditable(false); tcNimi.setEditable(false);
} }
@@ -1,6 +1,7 @@
package fi.lpam.gui; package fi.lpam.gui;
import fi.lpam.Main; import fi.lpam.Main;
import fi.lpam.dataluokat.Kuljetus;
import fi.lpam.dataluokat.RaporttiRivi; import fi.lpam.dataluokat.RaporttiRivi;
import fi.lpam.gui.elementit.FontLabel; import fi.lpam.gui.elementit.FontLabel;
import fi.lpam.tulostajat.KuljetusRaporttiTulostaja; import fi.lpam.tulostajat.KuljetusRaporttiTulostaja;
@@ -75,6 +76,10 @@ public class KuljetusRaportit extends TabPohja {
tcPvm.setCellFactory(_ ->new PaivamaaraTableCell()); tcPvm.setCellFactory(_ ->new PaivamaaraTableCell());
tcPvm.setCellValueFactory(new PropertyValueFactory<>("pvm")); tcPvm.setCellValueFactory(new PropertyValueFactory<>("pvm"));
TableColumn<RaporttiRivi, Kuljetus.Tyyppi> tcTyyppi = new TableColumn<>("Tyyppi");
tcTyyppi.setMinWidth(150);
tcTyyppi.setCellValueFactory(new PropertyValueFactory<>("tyyppi"));
TableColumn<RaporttiRivi, Integer> tcSalaatit = new TableColumn<>("Salaatit"); TableColumn<RaporttiRivi, Integer> tcSalaatit = new TableColumn<>("Salaatit");
tcSalaatit.setMinWidth(100); tcSalaatit.setMinWidth(100);
tcSalaatit.setCellValueFactory(new PropertyValueFactory<>("salaatit")); tcSalaatit.setCellValueFactory(new PropertyValueFactory<>("salaatit"));
@@ -111,17 +116,14 @@ public class KuljetusRaportit extends TabPohja {
tcYhteyshenkilönSähköposti.setMinWidth(200); tcYhteyshenkilönSähköposti.setMinWidth(200);
tcYhteyshenkilönSähköposti.setCellValueFactory(new PropertyValueFactory<>("yhteyshenkilönSähköposti")); tcYhteyshenkilönSähköposti.setCellValueFactory(new PropertyValueFactory<>("yhteyshenkilönSähköposti"));
tableView.getColumns().addAll(tcNimi, tcPvm, tcSalaatit, tcPääruoat, tcJälkiruoat, tcErva, tcLisätiedot, tableView.getColumns().addAll(tcNimi, tcPvm, tcTyyppi, tcSalaatit, tcPääruoat, tcJälkiruoat, tcErva, tcLisätiedot,
tcYhteyshenkilönNimi, tcLaskutusOsoite, tcYhteyshenkilönPuhelinnumero, tcYhteyshenkilönSähköposti); tcYhteyshenkilönNimi, tcLaskutusOsoite, tcYhteyshenkilönPuhelinnumero, tcYhteyshenkilönSähköposti);
tableView.setPlaceholder(new FontLabel(BUTTON_FONT, "Hae raportti")); tableView.setPlaceholder(new FontLabel(BUTTON_FONT, "Hae raportti"));
for (TableColumn<RaporttiRivi, ?> sarake : tableView.getColumns()) { for (TableColumn<RaporttiRivi, ?> sarake : tableView.getColumns()) {
sarake.setSortable(false);
sarake.setEditable(false); sarake.setEditable(false);
sarake.setResizable(true); sarake.setResizable(true);
sarake.setStyle( sarake.setStyle(TV_COLUMN_STYLE);
"-fx-alignment: CENTER;" +
"-fx-font-size: " + Main.properties.getProperty("tekstiFonttiKoko") + "px;" +
"-fx-font-family: " + Main.properties.getProperty("tekstiFontti"));
} }
} }
} }
@@ -17,6 +17,7 @@ public class TabPohja extends Tab {
public static Insets INSETS; public static Insets INSETS;
public static Border BORDER = new Border(new BorderStroke(Color.BLACK, BorderStrokeStyle.SOLID, new CornerRadii(5), BorderWidths.DEFAULT)); public static Border BORDER = new Border(new BorderStroke(Color.BLACK, BorderStrokeStyle.SOLID, new CornerRadii(5), BorderWidths.DEFAULT));
public static String STYLE; public static String STYLE;
public static String TV_COLUMN_STYLE;
public static Font BUTTON_FONT; public static Font BUTTON_FONT;
public static Font TEKSTI_FONT; public static Font TEKSTI_FONT;
public static double SPACING; public static double SPACING;
@@ -29,6 +30,10 @@ public class TabPohja extends Tab {
INSETS = new Insets(Double.parseDouble(prop.getProperty("insets"))); INSETS = new Insets(Double.parseDouble(prop.getProperty("insets")));
SPACING = Double.parseDouble(prop.getProperty("insets")); SPACING = Double.parseDouble(prop.getProperty("insets"));
STYLE = "-fx-background-color: " + prop.getProperty("taustaVari"); STYLE = "-fx-background-color: " + prop.getProperty("taustaVari");
TV_COLUMN_STYLE =
"-fx-alignment: CENTER;" +
"-fx-font-size: " + Main.properties.getProperty("tekstiFonttiKoko") + "px;" +
"-fx-font-family: " + Main.properties.getProperty("tekstiFontti");
BUTTON_FONT = Font.font(prop.getProperty("buttonFontti"), FontWeight.BOLD, Double.parseDouble(prop.getProperty("buttonFonttiKoko"))); BUTTON_FONT = Font.font(prop.getProperty("buttonFontti"), FontWeight.BOLD, Double.parseDouble(prop.getProperty("buttonFonttiKoko")));
TEKSTI_FONT = Font.font(prop.getProperty("tekstiFontti"), FontWeight.NORMAL, Double.parseDouble(prop.getProperty("tekstiFonttiKoko"))); TEKSTI_FONT = Font.font(prop.getProperty("tekstiFontti"), FontWeight.NORMAL, Double.parseDouble(prop.getProperty("tekstiFonttiKoko")));
@@ -12,7 +12,7 @@ public class KuljetusListaTulostaja extends Tulostaja{
public void luoKuljetusLista(ObservableList<Kuljetus> kuljetukset, int kierrosnumero) { public void luoKuljetusLista(ObservableList<Kuljetus> kuljetukset, int kierrosnumero) {
try { try {
sisältö.showText(kuljetukset.getFirst().getKuljetusPäivämäärä().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")) + ", kierros: " + kierrosnumero); sisältö.showText(kuljetukset.getFirst().getKuljetusPäivämäärä().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")) + ", kierros " + kierrosnumero + " " + kuljetukset.getFirst().getTyyppi());
uusiRivi(); uusiRivi();
for (Kuljetus kuljetus : kuljetukset) { for (Kuljetus kuljetus : kuljetukset) {
+4
View File
@@ -1,3 +1,7 @@
# 4.0.0
- Kuljetuslistoista luodaan lounas- ja päivällislistat erikseen
- Kuljetuslistalla asiakkaan nimeä ei voi enään muokata
# 3.2.1 # 3.2.1
- Asiakkaan erityisruokavalio osaksi raporttia - Asiakkaan erityisruokavalio osaksi raporttia
+1 -1
View File
@@ -47,7 +47,7 @@ alter table asiakkaat add lauantaiKpl int not null default 0;
alter table asiakkaat add sunnuntaiKpl int not null default 0; alter table asiakkaat add sunnuntaiKpl int not null default 0;
--3.x.x->4.0.0 --3.x.x->4.0.0
alter table kuljetukset add tyyppi varchar(50); alter table kuljetukset add tyyppi varchar(50) not null default 'Lounas';
alter table asiakkaat add dinner_maanantaiKpl int not null default 0; alter table asiakkaat add dinner_maanantaiKpl int not null default 0;
alter table asiakkaat add dinner_tiistaiKpl int not null default 0; alter table asiakkaat add dinner_tiistaiKpl int not null default 0;
alter table asiakkaat add dinner_keskiviikkoKpl int not null default 0; alter table asiakkaat add dinner_keskiviikkoKpl int not null default 0;