Ein leidiges Thema, wenn man Preise in der DB abspeichern muss. Aus Datenbanksicht gibt es hier meist den Datentyp Decimal. Bei Eingabe in einem Formular möchte ich nun Prüfen ob die eingegebene Zahl dem entspricht was ich mit vorstelle. Hierzu bediehnen wir uns dem „Match“ Validator welcher uns ein RegEx pattern definieren lässt mit dem wir die eingegebene Zahl validieren können.

Das ganze sieht dann so aus: für ein DECIMAL(10,2)

Daily Yii Post

greez Frank

Nunja es ist mal wieder ein Tag mit einem neuen Problem und was soll ich sagen die Lösung war mal wieder einfacher als gedacht und dennoch Frickelei!

Heute: NULL in date Feldern der Datenbank mit Yii und wie man das verarbeitet =)

Ich wollte in bestimmten date Feldern der Datenbank einfach nichts also NULL stehen haben. Nun produziert Yii leider korrekte date Objekte wenn man in die DB schreibt und somit steht dann dort 0000-00-00 00:00:0. Kein Problem dafür gibts ne lösung in Form von bevoreSave() und afterFind() im Yii Modell. sieht dann so aus

und für die Ausgabe kann dann das verwendet werden

Happy Coding!

greez Frank

 

Tjahaaa einfaches Ding aber ich hab lange gesucht bis ich die Lösung hatte. Im nachhineine betrachtet ist das super simpel!

Ich hab in meinem aktuellen Projekt eine Recht perverse HasMany Struktur und musste bei der Ausgabe alle Relationen auflösen und diese teilweise in GridViews anzeigen.

Ich Meine Damit sowas Model1 -> has One Model2 -> Has Many Model 3 -> Has Many Model 4

Die beiden Has Many sind jeweils über Join Tables realisiert.

am ende hatte ich dann ein Kontrukt wie

(vereinfacht)

foreach($model->model2->relationsModel3 as $relation)

-> renderpartial(…. $relation);

 

im renderpartial dann das entsprechende Gridview für die relation zum Model 4

 

Da unsere Relation ein Array ist können wir den CArrayDataProvider von Yii nutzen und ihn damit füttern sodass wir die Relation als dataProvider des GridViews nutzen können

Funzt 1a und ist echt einfach!

 

greez Frank

Nunja man trifft ja immer wieder mal auf besondere Schwierigkeiten beim Programmieren. So auch ich heute. Folgendes Problem:Nested Accordion mit jQueryUI => eigentlich kein Problem, halt, warte … DOCH! Das Problem ist dass die größe der nested Accordions nicht korrekt berechnet wird. Um das Problem zu lösen habe ich mich des Events beforeActivate bediehnt.

Nachfolgend ein Code beispiel um das ganze zu veranschaulichen.

 

Bevor das Panel aktiviert wird, wird ein refresh des Accordions ausgeführt (entspricht .resize() von jQuery vor v1.9). Dadurch wird die benötigte größe neu berechnet und der Inhalt wird correkt dargestellt. Villeicht hilft dass dem ein oder anderen weiter, greez Frank P.S. Comments erwünscht