Sven Schöling [Fri, 25 Jul 2014 14:38:00 +0000 (16:38 +0200)]
PriceSource: Erste Version
- Preisgruppen und Stammdaten sind implementiert
- Persistenz in allen Belegen funktioniert
- Rudimentäre Visualisierung funktioniert
- Klassen sind alle da
- Doku fehlt
- Verkauf/Einkaufweiche fehlt
- best_price ungetestet
- Preisgruppen hängen noch nicht von Verkäufer ab
- dependancy system fehlt
- verhalten bei fehlerhaften sources
- pricegroup -> active_source migration
Moritz Bunkus [Thu, 18 Dec 2014 15:11:42 +0000 (16:11 +0100)]
PriceTaxCalculator: Doku-Fix
G. Richardson [Thu, 18 Dec 2014 14:52:56 +0000 (15:52 +0100)]
Typos in Filtered Doku
G. Richardson [Mon, 15 Dec 2014 06:51:14 +0000 (07:51 +0100)]
Typos in LinkedRecords Dokumentation
Sven Schöling [Wed, 29 Oct 2014 10:14:42 +0000 (11:14 +0100)]
CSS: Klassen für interaktive text <a> mit javascript.
Sven Schöling [Fri, 5 Sep 2014 11:53:31 +0000 (13:53 +0200)]
DBUtils: selectall_ids
Sven Schöling [Mon, 8 Sep 2014 14:10:28 +0000 (16:10 +0200)]
displayable_name für business, partsgroup, pricegroup
Jan Büren [Thu, 18 Dec 2014 13:41:55 +0000 (14:41 +0100)]
PTC-Doku um API-Beispielsaufruf ergänzt
Jan Büren [Thu, 18 Dec 2014 13:39:55 +0000 (14:39 +0100)]
Verwaiste Einträge aus all entfernt
Aktuell werden diese zwei Übersetzungszeichenketten nicht mehr im
Programm verwendet.
Moritz Bunkus [Thu, 18 Dec 2014 12:04:05 +0000 (13:04 +0100)]
PriceTaxCalculator: für Items berechnete flüchtige Werte zurückgeben Teil 3
Die items können nicht als Hash-Referenz gespeichert werden, weil das
kaputt geht, wenn die Items noch nicht gespeichert wurden und damit noch
keine ID besitzen. Daher Umstellung auf Array-Speicherung.
Außerdem Anpassung des Testcases.
Moritz Bunkus [Tue, 16 Dec 2014 12:02:27 +0000 (13:02 +0100)]
PriceTaxCalculator: für Items berechnete flüchtige Werte zurückgeben Teil 2
Moritz Bunkus [Tue, 16 Dec 2014 11:03:46 +0000 (12:03 +0100)]
PriceTaxCalculator: für Items berechnete flüchtige Werte in %data zurückgeben
Sven Schöling [Mon, 15 Dec 2014 14:26:39 +0000 (15:26 +0100)]
Webdav: Typo
Jan Büren [Mon, 15 Dec 2014 08:17:10 +0000 (09:17 +0100)]
orderitems persistent teil III
IMMER die orderitems_id in sub poso löschen, nicht nur in
der if-bedingung
Angebot -> Auftrag i.O.
Auftrag - > Angebot i.O.
Kundenauftrag -> Lieferantenauftrag i.O.
Sven Schöling [Fri, 12 Dec 2014 16:20:32 +0000 (17:20 +0100)]
CsvImport: Makemodels auch auf instabilen Datenbanken in der richtigen Reihenfolge speichern
G. Richardson [Fri, 12 Dec 2014 11:12:42 +0000 (12:12 +0100)]
Löschen von Angeboten/Aufträgen protokollieren
Berücksichtigt jetzt auch Angebote in history_erp.
Sven Schöling [Thu, 11 Dec 2014 16:32:59 +0000 (17:32 +0100)]
Webdav: Framework um Dokumente im Webdav zu behandeln
Soll auf lange Sicht die Funktionen in Common ablösen.
G. Richardson [Thu, 11 Dec 2014 09:29:20 +0000 (10:29 +0100)]
SL/DB/Invoice->abbreviation prüft jetzt invoice_type
G. Richardson [Mon, 3 Nov 2014 22:57:55 +0000 (23:57 +0100)]
USTVA - Position 67 richtig berechnen
G. Richardson [Fri, 5 Dec 2014 07:42:25 +0000 (08:42 +0100)]
console - shortcut for purchase_invoice
Jan Büren [Tue, 9 Dec 2014 15:17:24 +0000 (16:17 +0100)]
redundante actions / orderitems delete in oe.pl gelöscht
nur einmal in sub poso alle orderitems_id löschen. ferner doppelte
dispatch actions entfernt
Jan Büren [Tue, 9 Dec 2014 15:09:36 +0000 (16:09 +0100)]
orderitems persistent machen.
bei vorlage als und position löschen entsprechend die ids löschen, sodass
diese beim speichern des neuen beleges, bzw. beim neu erstellen der positionen
erzeugt werden.
Folgende Szenarien geprüft:
Von Angebot:
-> erneuern i.O.
-> mittlere Position löschen i.O.
-> als neu speichern i.O.
-> Speichern, Löschen, neue Pos i.O.
-> Angebot -> Auftrag i.O.
Rücksprünge von:
-> Auftrag -> Angebot (quotation in io.pl!) i.O.
-> Lieferantenauftrag -> Verkaufsauftrag i.O.
-> Lieferantenauftrag -> Lieferantenanfrage i.O.
-> Verkaufs-Rechnung -> Auftrag (keine orderitems vorhanden) i.O.
Moritz Bunkus [Tue, 9 Dec 2014 09:46:44 +0000 (10:46 +0100)]
CustomerVendorPicker: ref($value) nur prüfen, wenn es tatsächlich ein Objekt ist
…und nicht schlicht die ID eines Objektes.
Moritz Bunkus [Mon, 8 Dec 2014 12:50:18 +0000 (13:50 +0100)]
SL::DB::{Invoice,DeliveryOrder}: Items mit neg. qty beim Wandeln optional weglassen
Sven Schöling [Fri, 5 Dec 2014 11:46:45 +0000 (12:46 +0100)]
Auth: nicht auskommentieren, sondern richtig dokumentieren
Sven Schöling [Fri, 5 Dec 2014 10:43:59 +0000 (11:43 +0100)]
RecordLinks: credit_notes verlinken, und Typ von Rechnungen anzeigen
Sven Schöling [Fri, 5 Dec 2014 10:42:42 +0000 (11:42 +0100)]
Layout: entfernte locales
Sven Schöling [Fri, 5 Dec 2014 10:16:46 +0000 (11:16 +0100)]
Auth - experimentell: $::auth dbh wieder cachen.
Sven Schöling [Thu, 4 Dec 2014 18:04:58 +0000 (19:04 +0100)]
Layout: Tests schlagen fehl, weil Top auf $::dispatcher zugreift
Sven Schöling [Thu, 4 Dec 2014 17:47:02 +0000 (18:47 +0100)]
Layout Aufräumaktion:
- Admin und V3 Menü entflochten. Benutzen jetzt beide das neue CssMenu
als sub_layout
- Top-Klone aus V3 und Javascript herausoperiert und als sub_layout
eingebunden
- Neues Layout AdminLogin für die Loginmaske im Adminbereich (d'oh)
- Inputfelder im frame_header kleiner gemacht, Frickelfox ignoriert mal
wieder css Vorgaben und inheritet font-size nicht.
- Beschreibung in Placeholder verschoben. Ja das ist html5. Benutz halt
nicht IE6.
- javascript für Ansprechpartnersuche gefixt und ausgelagert.
- Login, Classic und V3 sind top level Layouts und brauchen nicht
sub_layoutbar sein. Macht den Code einfacher.
G. Richardson [Thu, 4 Dec 2014 15:58:37 +0000 (16:58 +0100)]
LxERP.t8 ist kein filter.
analog zu Commit
445c84a3593
Jan Büren [Thu, 4 Dec 2014 15:48:32 +0000 (16:48 +0100)]
no lexical postif in DeliveryPlan.pm
test ausführen, nicht vergessen!!! @myself
G. Richardson [Thu, 4 Dec 2014 15:43:23 +0000 (16:43 +0100)]
HTML Templates für Buchungstab vergessen
Sven Schöling [Thu, 4 Dec 2014 15:36:30 +0000 (16:36 +0100)]
LxERP.t8 ist kein filter.
Moritz Bunkus [Thu, 4 Dec 2014 15:12:55 +0000 (16:12 +0100)]
Auth.pm: Rechte nur dann laden, wenn User & Client gesetzt sind
Seit
f6ed86e wird im Menü-Template-Code auf Rechte
getestet (AUTH.assert(…)). Im User-Bereich ist das kein Problem, weil
die Menü-Templates nur dann benutzt werden, wenn tatsächlich ein User
angemeldet ist.
Im Admin-Bereich allerdings wird ebenfalls Menü-Code verwendet,
allerdings gibt es in dem Moment weder einen Client noch einen User. Der
Auth-Code muss damit klarkommen und in dem Fall schlicht »nicht
berechtigt« zurückliefern.
Moritz Bunkus [Thu, 4 Dec 2014 15:12:20 +0000 (16:12 +0100)]
Auth.pm cosmetics: Entfernen von $::lxdebug->enter_sub/leave_sub
G. Richardson [Thu, 4 Dec 2014 14:11:24 +0000 (15:11 +0100)]
Tabreiter-Titel für Buchungsliste angepasst
damit der Übersetzungsparser damit zurechtkommt.
G. Richardson [Thu, 4 Dec 2014 13:51:23 +0000 (14:51 +0100)]
WebDAV Reiter - title als class statt h1
G. Richardson [Mon, 13 Oct 2014 14:29:12 +0000 (16:29 +0200)]
Buchungen in ar/ap/is/ir in eigenem Tabreiter anzeigen
Neuer Reiter "Buchungen", wo zu einer Rechnung/Buchung die Buchungen
laut acc_trans angezeigt werden.
In einer Tabelle "Buchungen" werden alle Buchungen laut acc_trans
angezeigt.
In einer Tabelle "Salden" werden die aktuellen Salden der bebuchten
Konten angezeigt, ausgeglichene Konten werden herausgefiltert.
Nicht für Dialogbuchungen umgesetzt.
Es wird auf das FiBu-Recht (general_ledger) geprüft, ansonsten wird der
Reiter nicht angezeigt
G. Richardson [Thu, 4 Dec 2014 12:47:47 +0000 (13:47 +0100)]
Typos in Doku/perlpod
G. Richardson [Mon, 3 Nov 2014 22:52:02 +0000 (23:52 +0100)]
Datum Schnelleingabe - changelog Eintrag
G. Richardson [Tue, 21 Oct 2014 00:19:31 +0000 (02:19 +0200)]
setTimeOut für schnelle Datumseinsgabe bei set_duedate
Die jquery-Abfrage des Datumsfeldes in set_duedate (Fälligkeitsdatum)
wird mit setTimeOut erst nach Ersetzen des Datums per schneller
Datumseingabe durchführen
G. Richardson [Tue, 21 Oct 2014 00:07:07 +0000 (02:07 +0200)]
Schnelle Datumseingabe ohne Trenner
Buchhalter sind es gewohnt, das Datum im Nummernblock ohne Punkte
eingeben zu können, z.B. wird aus
01122014 -> 01.12.2014
Mit diesem Patch wird im Datumsfeld noch vor der Prüfung auf ein gültiges
Datumsformat per Javascript geprüft, ob
* die Eingabe nur aus Zahlen besteht
* das Datumsformat dd.mm.yy, dd-mm-yy oder mm-dd-yy ist
Trifft dies zu, werden am Beispiel für den Fall dd.mm.yy folgende
Umwandlungen durchgeführt:
8 Zahlen:
31122014 -> 31.12.2014
6 Zahlen: 311214 -> 31.12.2014
4 Zahlen: 3112 -> 31.12.2014 aktuelles Jahr wird angenommen
1-2 Zahlen: 12 -> 31.10.2014 aktueller Monat wird angenommen
7 -> 07.10.2014 aktueller Monat wird angenommen
Nach der Umwandlung findet wie bisher eine (simple) Plausibilitätsprüfung des
Datums per Javascript statt. Sollte das Datumsfeld andere Datumsfelder
beeinflussen, wie z.B. das Rechnungsdatum das Fälligkeitsdatum im Ein-
und Verkauf durch ein onChange, muß hier eventuell mit einem setTimeOut
gearbeitet werden, da ansonsten der Wert vor der Umwandlung genommen
wird.
G. Richardson [Fri, 4 Apr 2014 11:09:26 +0000 (13:09 +0200)]
FiBu Schellsuche in Headerzeile
neues Ajax Autocompletefeld im Header für Benutzer mit FiBu-Rechten,
welches Rechnungsnummern und Kunden-/Lieferantennamen durchsucht. Durch
die Auswahl im Dropdown gelangt man direkt zu dem Beleg.
Sven Schöling [Thu, 27 Aug 2009 10:54:05 +0000 (12:54 +0200)]
Löschen von orderitems beim speichern von OE korrigiert.
Jan Büren [Wed, 3 Dec 2014 19:15:18 +0000 (20:15 +0100)]
Lieferplan: all_businesses in init-methode ausgelagert
<gorash> kurzes feedback zum lieferplan:
<gorash> in der action alle business laden: der ganze punkt an den init_* sachen ist, dass mand as laden von nötigen daten aus der action rauskriegt
Moritz Bunkus [Wed, 3 Dec 2014 11:25:57 +0000 (12:25 +0100)]
Benutzerdefinierte Variablen via Trigger löschen Bugfix 2
Die Triggerfunktion selber sollte aus Performancegründen nicht »DELETE …
WHERE … IN (SELECT…)« nutzen, da dies bei PostgreSQL sehr langsam ist.
Moritz Bunkus [Fri, 28 Nov 2014 11:53:46 +0000 (12:53 +0100)]
CVars-Lösch-Queries deutlich effizienter gestaltet
PostgreSQL kann Queries à la »DELETE … WHERE … IN (SELECT…)« nicht gut
optimieren und erzeugt dafür exponentielle Laufzeit. Viel schneller ist,
eine Vorselektierung mit normalen JOINs zu nutzen und nachher beim
DELETE ein WHERE EXIST (…) mit Bezug auf die zu löschende Tabelle
einzusetzen.
Moritz Bunkus [Tue, 25 Nov 2014 16:56:40 +0000 (17:56 +0100)]
SL::CTI::sanitize_number: nur Ziffern zurückliefern
Jan Büren [Tue, 25 Nov 2014 18:37:01 +0000 (19:37 +0100)]
Syntax Typo in all
Jan Büren [Tue, 25 Nov 2014 18:22:06 +0000 (19:22 +0100)]
Übersetzungsspalte verbessert und Berechnungsfuntkion für stocked_qty in Lieferberichte
Jan Büren [Tue, 25 Nov 2014 18:04:44 +0000 (19:04 +0100)]
Übersetzungen für Lieferwertbericht
Jan Büren [Tue, 25 Nov 2014 17:10:17 +0000 (18:10 +0100)]
Merge branch 'master' of github.com:kivitendo/kivitendo-erp
Jan Büren [Tue, 25 Nov 2014 17:05:27 +0000 (18:05 +0100)]
Lieferplan / Lieferwertbericht um Filter Bearbeiter erweitert
Moritz Bunkus [Tue, 25 Nov 2014 15:46:11 +0000 (16:46 +0100)]
Merge branch 'master' of github.com:kivitendo/kivitendo-erp
Moritz Bunkus [Tue, 25 Nov 2014 15:45:45 +0000 (16:45 +0100)]
CustomerVendor: CVars bei Wechsel von Ansprechpersonen richtig befüllen
Bernd Bleßmann [Mon, 25 Nov 2013 14:48:26 +0000 (15:48 +0100)]
Lieferplan: Filter für Projektnummer und Kundentyp
Conflicts:
SL/Controller/DeliveryPlan.pm
Moritz Bunkus [Tue, 25 Nov 2014 13:29:02 +0000 (14:29 +0100)]
CustomerVendor-Controller: Daten in Neu-Anzeige bei Fehler beibehalten
RDBO hat das Verhalten, dass bei einem neuen, noch nicht gespeicherten
Objekt die Methoden zum Hinzufügen von Relationship-Objekten (z.B. in
1:n-Beziehnungen wie $customer->add_contacts(…)) beim danach erfolgenden
Auslesen der Beziehung nicht zurückliefert. Das heißt, dass Folgendes
der Fall ist:
my $customer = SL::DB::Customer->new;
$customer->add_contacts(SL::DB::Contacts->new);
print scalar(@{ $customer->contacts || [] }); # Das hier gibt 0 aus
Existiert das Objekt hingegen schon, dann klappt das normal. Das Problem
kann man umgehen, indem man beim Anlegen des neuen Objektes die
Beziehungen explizit auf eine leere Array-Referenz setzt, damit der in
RDBO enthaltene Check an der Stelle greift.
Das betrifft den Workflow, wenn man Daten in den benutzerdefinierten
Variablen eingibt, auf Speichern drückt und kivitendo dann wegen eines
fehlgeschlagenen Checks die Maske erneut anzeigt.
Bernd Bleßmann [Tue, 25 Nov 2014 13:13:25 +0000 (14:13 +0100)]
Kunden/Lieferanten sind nicht verwaist, wenn es Lieferscheine gibt.
Moritz Bunkus [Tue, 25 Nov 2014 12:52:27 +0000 (13:52 +0100)]
CustomerVendor-Presenter: croaken, wenn Parameter fehlen oder falsch sind
Moritz Bunkus [Tue, 25 Nov 2014 12:52:01 +0000 (13:52 +0100)]
common/render_cvar_input.html: richtige Picker-Methoden für customer/vendor/part
Moritz Bunkus [Tue, 25 Nov 2014 12:51:10 +0000 (13:51 +0100)]
SL::DB::CustomVariable->value: undef anstelle von 0 wenn ref.Objekt nicht existiert
Bernd Bleßmann [Tue, 25 Nov 2014 12:30:44 +0000 (13:30 +0100)]
Redundante Trigger zum Aufräumen nach Löschen von Kunden/Lieferanten entfernen.
Diese Trigger sind nicht nur doppelt, sondern auch falsch, da sie "module" in
"shipto" nicht berücksichtigen, was dazu führen kann, das in Belegen individuell
vergebene Lieferadressen gelöscht werden, wenn ein Kunde oder Lieferant gelöscht
wird, der zufällig die selbe id hat, wir der entsprechende Beleg.
Die neueren Trigger werden/wurden mit dem Upgrade-Tag
"cleanup_after_customer_vendor_deletion" installiert.
Bernd Bleßmann [Tue, 25 Nov 2014 12:22:42 +0000 (13:22 +0100)]
Redundante Upgrade-Skripte zum Löschen von CVars via Trigger entfernt.
Nicht gelöscht, sondern "geleert" und ein weiteres Skript zum Löschen
der Trigger und Funktionen.
Jan Büren [Tue, 25 Nov 2014 11:51:57 +0000 (12:51 +0100)]
Neuer Bericht: Lieferwertbericht
Erweiterung DeliveryPlan.pm um Modusweiche Lieferplan oder Lieferwertbericht
Implementierungstand Lieferwertbericht:
- Alle offenen Verkaufsaufträge werden berücksichtigt
- Beim CSV-Export wird die Einheit als Extra-Spalte exportiert und die
Einheiten bei allen anderen Spalten ausgeblendet
Ferner neues Recht Lieferwertbericht umgesetzt
Moritz Bunkus [Tue, 25 Nov 2014 08:07:56 +0000 (09:07 +0100)]
Finanzcontrollingbericht refactoring: map nicht nur für Seiteneffekte nutzen
Moritz Bunkus [Tue, 25 Nov 2014 08:05:14 +0000 (09:05 +0100)]
Finanzcontrollingbericht: Filtern nach Vorgangsbezeichnung
Moritz Bunkus [Tue, 25 Nov 2014 08:03:29 +0000 (09:03 +0100)]
Finanzcontrollingbericht: Filterfelder breiter gemacht
Moritz Bunkus [Tue, 25 Nov 2014 08:01:56 +0000 (09:01 +0100)]
Finanzcontrollingbericht: Spalte »Vorgangsbezeichnung« anzeigen
Sven Schöling [Mon, 24 Nov 2014 13:01:21 +0000 (14:01 +0100)]
Installcheck: Moose::Role ist in libmoose-perl
Bernd Bleßmann [Mon, 24 Nov 2014 11:50:58 +0000 (12:50 +0100)]
Upgrade-Scripte zum Löschen von CVars via Trigger beschleunigt.
In den queries, die vor dem Installieren der Trigger die DB aufräumen,
"NOT IN" durch "NOT EXISTS" ersetzt.
Hintergrund-Info ist hier zu finden:
http://explainextended.com/2009/09/16/not-in-vs-not-exists-vs-left-join-is-null-postgresql/
(Dank an Sven)
Sven Schöling [Mon, 24 Nov 2014 10:26:48 +0000 (11:26 +0100)]
PartPicker: Bessere Beschreibung zum das javascript include
Sven Schöling [Fri, 21 Nov 2014 17:17:16 +0000 (18:17 +0100)]
Layout: title Ausgabe normalisieren
...mit dem Ziel das später ins Layout zu migrieren.
- In allen Templates den Tital auch wirklich als erstes ins DOM
verschoben
- unterschiedliche Verwendung der folgenden Muster vereinheitlicht:
<h1>...</h1>
<div class='listtop'>...</div>
<p><div class='listtop'>...</div></p>a
<tr><th class='listtop' colspan=..>....</th></tr>
- Verwendung der gleichen Klasse im Footer in <h2> geändert
- Puffer <tr height=5> entfert
Das ergibt insgesamt folgende Effekte:
- Einheitliches Rendern der Überschrift
- Einheitlicher Abstand zum Content
- flash/message werden immer unter der Überschrift angezeigt
Sven Schöling [Thu, 20 Nov 2014 11:52:04 +0000 (12:52 +0100)]
CsvImport: Makemodels feiner granulieren.
Sven Schöling [Tue, 18 Nov 2014 15:03:16 +0000 (16:03 +0100)]
RequirementSpec: partpicker js muss vorher schon geladen sein.
Sven Schöling [Tue, 18 Nov 2014 14:52:15 +0000 (15:52 +0100)]
Doku update
Sven Schöling [Tue, 18 Nov 2014 14:49:35 +0000 (15:49 +0100)]
PartPicker: javascript direkt im P.part_picker adden.
Sven Schöling [Tue, 18 Nov 2014 14:48:21 +0000 (15:48 +0100)]
Controller: content for header rendern
Hat zur Folge, dass Presenterwidgets benötigte stylesheets und
javascripts anfordern können.
Sven Schöling [Tue, 18 Nov 2014 14:11:13 +0000 (15:11 +0100)]
Stylesheets: Aufräumaktion
- gemeinsame stylesheets aus den kivitendo/lx-office-erp Verzeichnissen
genommen
- README aktualisiert
- rp/bwa nicht mehr hartcodiert in kivitendo laden
Sven Schöling [Tue, 18 Nov 2014 12:25:31 +0000 (13:25 +0100)]
Nicht mehr gepflegtes Stylesheet Mobile entfernen
kann wieder aufgenommen werden wenn es weitergepflegt wird
Sven Schöling [Mon, 17 Nov 2014 10:51:39 +0000 (11:51 +0100)]
Einkaufsrechnungen: closedto beachten
Sven Schöling [Mon, 17 Nov 2014 09:36:19 +0000 (10:36 +0100)]
Freitagabendcommit Fixes
Sven Schöling [Fri, 14 Nov 2014 17:56:10 +0000 (18:56 +0100)]
DeliveryPlan: Cleanup, vc mitschleifen
Sven Schöling [Fri, 14 Nov 2014 17:55:08 +0000 (18:55 +0100)]
ReportGenerator: visible Information nicht ignorieren
Sven Schöling [Fri, 14 Nov 2014 16:53:49 +0000 (17:53 +0100)]
Gloable BCC Adresse
Sven Schöling [Fri, 14 Nov 2014 15:28:50 +0000 (16:28 +0100)]
Email: Kosmetik
Sven Schöling [Fri, 14 Nov 2014 15:02:59 +0000 (16:02 +0100)]
Belege: Filtern nach Ansprechpartner
Sven Schöling [Fri, 14 Nov 2014 10:40:56 +0000 (11:40 +0100)]
FlattenToForm: Rabatte richtig formatieren
Sven Schöling [Fri, 14 Nov 2014 10:01:03 +0000 (11:01 +0100)]
PeriodicInvoices: employee aus Quellauftrag setzen
Sven Schöling [Thu, 13 Nov 2014 16:50:38 +0000 (17:50 +0100)]
CsvImport: temporäre Profile ausblenden
Moritz Bunkus [Wed, 12 Nov 2014 11:29:25 +0000 (12:29 +0100)]
Ansprechpersonen-CVars auch beim Updaten speichern
Beim Neuanlegen wurden sie schon geschrieben, weil da in den Objekten
noch keine ID vorhanden ist. Bei existierenden Objekten muss aber das
Mutterobjekt mit cascade=>1 gespeichert werden, damit modifizierte
Relationships auch gespeichert werden.
Moritz Bunkus [Wed, 12 Nov 2014 11:12:33 +0000 (12:12 +0100)]
Ansprechpersonen-CVars mit INCLUDE und nicht PROCESS einbinden
PROCESS lokalisiert die Variablen nicht. Das führt dazu, dass bei
multiplen CVars für Ansprechpersonen der Feldname aller CVar-Inputs
immer der der ersten CVar ist.
Moritz Bunkus [Wed, 12 Nov 2014 11:01:09 +0000 (12:01 +0100)]
Benutzerdefinierte Variablen via Trigger löschen Bugfix
Die ID-Spalte heißt in der contacts-Tabelle cp_id und nicht id.
Jan Büren [Tue, 11 Nov 2014 10:43:28 +0000 (11:43 +0100)]
Optimierung Helfer-Funktion _get_delivery_qty
ALLE Aufrufe dann auch von dieser Funktion erledigen.
Jan Büren [Mon, 10 Nov 2014 17:46:46 +0000 (18:46 +0100)]
weitere Verbesserungen für die helper-funktion
Die Funktion sollte unabhängig vom Variablen-Namen sein, damit dies
langfristig einfacher wartbar ist.
Jan Büren [Mon, 10 Nov 2014 15:29:51 +0000 (16:29 +0100)]
HelperFunktion OderItem: _delivered_qty optimiert
Jan Büren [Mon, 10 Nov 2014 14:23:51 +0000 (15:23 +0100)]
OrderItems-> delivered_qty in helper-funktion ausgelagert
Ergänzung zum Commit von gerade: Da man nicht sicher sein kann,
ob dieser Wert als Objekt-Variable zu dem Zeitpunkt (t2) schon berechnet
wurde, entsprechend in eine nach perl-konvention private (_delivered_qty)
funktion ausgelagert.
Jan Büren [Mon, 10 Nov 2014 13:00:01 +0000 (14:00 +0100)]
Lieferplan: Warenwert der ausgelagerten Warenmenge anzeigen
Sven Schöling [Fri, 7 Nov 2014 13:07:45 +0000 (14:07 +0100)]
CVars: typo bei Editieren von Waren
Waldemar Toews [Fri, 7 Nov 2014 10:01:27 +0000 (11:01 +0100)]
Laden von CVars mit falschen Werten in Artikelstammdaten unterbinden.
Beim Laden der CVars in Stammdaten fand die Prüfung nach 'sub_module'
nicht statt.
Dabei werden mehrere Datensätze zurückgeliefert und wenn mann Pech hat
kann der erste Satz, der genommen wird, den Wert aus dem Auftrag oder
woher auch immer haben.
Die Abfrage ist jetzt geändert: Wenn der Parameter nicht übergeben
wurde, dann mit Leerstring vorbelegen und immer nach 'sub_module'
durchsuchen.