<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Urbans Blog &#187; OXID eShop</title>
	<atom:link href="http://www.urbans-blog.de/kategorie/oxid-eshop/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.urbans-blog.de</link>
	<description>Der alltägliche Wahnsinn und mein Senf dazu</description>
	<lastBuildDate>Sun, 03 Apr 2011 13:18:47 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Artikel über Core-Klassen Erweiterungen im aktuellen PHPmagazin</title>
		<link>http://www.urbans-blog.de/2010/05/10/artikel-uber-core-klassen-erweiterungen-im-aktuelln-phpmagazin/</link>
		<comments>http://www.urbans-blog.de/2010/05/10/artikel-uber-core-klassen-erweiterungen-im-aktuelln-phpmagazin/#comments</comments>
		<pubDate>Mon, 10 May 2010 07:47:05 +0000</pubDate>
		<dc:creator>urban</dc:creator>
				<category><![CDATA[OXID eShop]]></category>
		<category><![CDATA[artikel]]></category>
		<category><![CDATA[framework]]></category>
		<category><![CDATA[oxid]]></category>
		<category><![CDATA[oxid4all]]></category>
		<category><![CDATA[oxid4project]]></category>
		<category><![CDATA[oxidforge]]></category>
		<category><![CDATA[phpmagazin]]></category>
		<category><![CDATA[projekterfassung]]></category>
		<category><![CDATA[shop]]></category>
		<category><![CDATA[workshop]]></category>

		<guid isPermaLink="false">http://www.urbans-blog.de/?p=264</guid>
		<description><![CDATA[Als Ergänzung zu meinem 3-teiligen Workshop &#8220;OXID4ALL &#8211; Es muss ja nicht immer ein Shop sein &#8230;&#8221; möchte ich heute noch auf die aktuelle Ausgabe (4.10) des PHPmagazins hinweisen. Dort ist unter dem Titel &#8220;Kernig&#8221; nun ein Artikel von mir erschienen, in dem es um Core-Klassen Erweiterungen im OXID eShop geht. Diese Thematik bietet die [...]]]></description>
			<content:encoded><![CDATA[<p>Als Ergänzung zu meinem 3-teiligen Workshop <a title="OXID4All - Es muss ja nicht immer ein Shop sein" href="http://www.urbans-blog.de/2010/05/07/oxid4all-es-muss-ja-nicht-immer-ein-shop-sein-teil-1/" target="_blank">&#8220;OXID4ALL &#8211; Es muss ja nicht immer ein Shop sein &#8230;&#8221;</a> möchte ich heute noch auf die aktuelle Ausgabe (4.10) des <a title="PHPmagazin" href="http://it-republik.de/php/" target="_blank">PHPmagazins</a> hinweisen. Dort ist unter dem Titel &#8220;Kernig&#8221; nun ein Artikel von mir erschienen, in dem es um Core-Klassen Erweiterungen im OXID eShop geht.</p>
<p>Diese Thematik bietet die Basis für die in meinem <a title="Workshop zu Projekterfassungs-Tool auf Basis von OXID eShop CE" href="http://www.urbans-blog.de/2010/05/07/oxid4all-es-muss-ja-nicht-immer-ein-shop-sein-teil-1/" target="_self">Workshop </a>beschriebenen Schritte, um das OXID Framework (OF) auch für eigene Anwendungen &#8211; fern der Ecommerce-Welt &#8211; nutzen zu können.</p>
<p>Der Artikel im <a title="PHPmagazin" href="http://it-republik.de/php/" target="_blank">PHPmagazin</a> nimmt Bezug auf meinen ursprünglich geplanten Vortrag bei den <a title="OXID Commons 2010" href="http://www.oxid-esales.com/de/news/oxid-commons-2010" target="_blank">OXID Commons</a>. Natürlich musste der Artikel schon im April abgegeben werden, als ich noch nicht ahnen konnte, dass ich meine Commons-Teilnahme krankheitsbedingt würde absagen müssen. Der Inhalt des dort ausgefallenen Vortrags ist ja nun hier im Blog verfügbar.</p>
<p>Fragen zum Artikel und/oder zum Workshop beantworte ich gerne hier im Blog. Nutzt die Kommentarfunktion.</p>
<p>Bzgl. des Projekterfassungs-Toos erhielt ich bereits gestern zwei Rückmeldungen von interessierten PHP-Entwicklern, die sich vorstellen können, daran mitzuarbeiten, dieses Projekt weiter auszubauen. Ich werde also versuchen, so schnell wie möglich dafür zu sorgen, dass das Ganze kollaborationsfähig als OXIDforge-Projekt zur Verfügung steht!</p>
]]></content:encoded>
			<wfw:commentRss>http://www.urbans-blog.de/2010/05/10/artikel-uber-core-klassen-erweiterungen-im-aktuelln-phpmagazin/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>OXID4ALL – Es muss ja nicht immer ein Shop sein … – Teil 3</title>
		<link>http://www.urbans-blog.de/2010/05/09/oxid4all-%e2%80%93-es-muss-ja-nicht-immer-ein-shop-sein-%e2%80%a6-%e2%80%93-teil-3/</link>
		<comments>http://www.urbans-blog.de/2010/05/09/oxid4all-%e2%80%93-es-muss-ja-nicht-immer-ein-shop-sein-%e2%80%a6-%e2%80%93-teil-3/#comments</comments>
		<pubDate>Sun, 09 May 2010 17:06:59 +0000</pubDate>
		<dc:creator>urban</dc:creator>
				<category><![CDATA[OXID eShop]]></category>
		<category><![CDATA[framework]]></category>
		<category><![CDATA[oxid]]></category>
		<category><![CDATA[oxid ce]]></category>
		<category><![CDATA[projekt]]></category>
		<category><![CDATA[projekterfassung]]></category>

		<guid isPermaLink="false">http://www.urbans-blog.de/?p=233</guid>
		<description><![CDATA[Nun denn &#8211; auf zum Endspurt &#8211; und damit zum Kern des Projektes &#8220;oxid4project &#8211; Ein Projekterfassungs-Tool auf Basis von OXID CE&#8221;. In diesem dritten und letzten Teil meines kleinen Workshops werde ich die Implementierung eigener Datenbanktabellen und damit verknüpfter core-Objekte demonstrieren. Dies bildet die Grundlage für die weitere Anwendungsentwicklung. Am Ende des Beitrages steht [...]]]></description>
			<content:encoded><![CDATA[<p>Nun denn &#8211; auf zum Endspurt &#8211; und damit zum Kern des Projektes <strong>&#8220;oxid4project &#8211; Ein Projekterfassungs-Tool auf Basis von OXID CE&#8221;</strong>.</p>
<p>In diesem dritten und letzten Teil meines kleinen Workshops werde ich die Implementierung eigener Datenbanktabellen und damit verknüpfter core-Objekte demonstrieren. Dies bildet die Grundlage für die weitere Anwendungsentwicklung.</p>
<p>Am Ende des Beitrages steht dann der komplette Quellcode zum Download zur Verfügung.</p>
<div id="attachment_236" class="wp-caption aligncenter" style="width: 584px"><a href="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid4project_screen_02_main.png"><img class="size-full wp-image-236" title="oxid4project Projektdatenerfassung" src="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid4project_screen_02_main.png" alt="oxid4project Projektdatenerfassung" width="574" height="274" /></a><p class="wp-caption-text">oxid4project Projektdatenerfassung</p></div>
<p>Bisher hatten wir lediglich eine Login-Seite und eine noch ziemlich leere Startseite für das Projekterfassungs-Tool erstellt. Bevor wir das Ganze nun mit nützlicher Funktionalität füllen, wollen wir uns zunächst an die notwendigen core-Objekte machen.</p>
<p>Wie schon in Teil 1 beschrieben, benötigen wir folgende Objekte:</p>
<p>- Mitarbeiter / User: hier nutzen wir OXID Standardfunktionalität<br />
- Projekte: dafür wird eine eigene core-Klasse benötigt<br />
- Zeit- und Texterfassung: auch hierfür mache eine eigene core-Klasse Sinn<br />
- Auswertungen: ebenfalls eine eigene core-Klasse</p>
<p>Um den Bereich &#8220;Mitarbeiter&#8221; kümmern wir uns im Moment überhaupt nicht &#8211; das erledigen wir komplett mit OXID-Standards. Für die Projektstammdaten sieht das anders aus:</p>
<div>&nbsp;</div>
<p><strong>Neues Objekt: Projekt(e) &#8211; Datenfelder</strong></p>
<p>Um die Projektstammdaten zu erfassen, benötigen wir zunächst eine eigene Tabelle:<br />
<pre><code>
CREATE TABLE `azprojects` (
`OXID` varchar(32)&nbsp;&nbsp;NOT NULL,
`AZTITLE` varchar(150) NOT NULL,
`AZPRICEPERHOUR` double NOT NULL,
PRIMARY KEY (`OXID`)
);
</code></pre></p>
<p>Wir beschränken uns hier auf eine eindeutige ID, einen Titel und den Stundensatz. Um nicht mit OXID-eigenen Konventionen in Konflikt zu geraten, sollten eigene Tabellen und Tabellenfelder grundsätzlich ein eigenes Prefix bekommen &#8211; ich nutze stets &#8220;AZ&#8221; dafür. Eine Ausnahme bildet in unserer neu angelegten Tabelle allerdings das Feld <em>OXID</em>.</p>
<p>Im OXID Framework (OF) hat die sog. OX-ID eine besondere Stellung. Diese ID ist in allen Tabellen der primary key und somit immer die eindeutige ID für jeden Datensatz. Anhand dieser ID laden die OF-Basisklassen Inhalte in die Objekte hinein. Damit wir diesen sehr komfortablen Mechanismus nutzen können, müssen wir unserer Tabelle ebenfalls eine <em>OX-ID</em> geben.</p>
<p>Nun brauchen wir noch die zugehörige core-Klasse, die als Minimalversion so aussieht:<br />
<pre><code>
class azproject extends oxI18n
{
&nbsp;&nbsp;&nbsp;&nbsp;protected $_sCoreTbl = &#039;azprojects&#039;;
&nbsp;&nbsp;&nbsp;&nbsp;protected $_sClassName = &#039;azprojcect&#039;;

&nbsp;&nbsp;&nbsp;&nbsp;public function __construct()
&nbsp;&nbsp;&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;parent::__construct();
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;init( &#039;azprojects&#039; );
&nbsp;&nbsp;&nbsp;&nbsp;}
}
</code></pre></p>
<p><span style="text-decoration: underline;"> Erläuterung:<br />
</span>Wir deklarieren die Klasse <em>azproject</em> als Extension von <em>oxI18n</em>. Diese Klasse wiederum ist Extension der Klasse <em>oxBase</em> &#8211; und die wiederum ist Extension von <em>oxSuperCfg</em>. Von dieser Vererbungskette profitieren wir in mehrfacher Hinsicht:</p>
<ul>
<li><em>oxSuperCfg:</em> stellt uns mit Session- und Config-Objektgettern das Fundament des OF zur Verfügung</li>
<li><em>oxBase:</em> enthält alle Kernfunktionen für Datenobjekte, inkl. der notwendigen Methoden, um Daten aus Tabellen in Objekteigenschaften zu überführen und umgekehrt</li>
<li><em>oxI18n:</em> ist die sog. &#8220;Internationalization&#8221; Klasse, in der diverse Mechanismen hinterlegt sind, die es recht einfach machen, die Datenobjekte auch mehrsprachig zu pflegen. (Wir werden das im aktuellen Projekt nicht nutzen, aber um das Projekt möglichst universell nutzen zu können, macht es Sinn, diese Option hier zumindest mit einzubinden.)</li>
</ul>
<p>Dieser OF-Komfort sorgt dafür, dass unsere eigene core-Klasse ziemlich bescheiden bleiben kann. Im Grunde definieren wir dort nur den Namen unseres Objektes <em>($_sClassName)</em> und den Namen der Tabelle, aus der die Daten kommen <em>($_sCoreTbl)</em>. Das reicht bereits, um das grundlegende Handling unserer Projektstammdaten zu erledigen.</p>
<p>Wie das Ganze ins Template eingebunden wird, entnehmt ihr bitte dem Quellcode, der ja zum Download bereitliegt. Ich will hier nur kurz noch zeigen, wie nun das besagte Handling der Daten in die entsprechende View-Klasse <em>azprojectsstart</em> eingebunden wird.</p>
<p>Zuvor brauchen wir aber noch eine weitere core-Klasse &#8211; und zwar für ein Listenobjekt der Projektstammdaten. Warum das? &#8211; Nun, das OF enthält für nahezu alle Daten(core-)objekte jeweils eine Klasse für das Einzelobjekt und eine Klasse für das entsprechende Listenobjekt (z. B.: <em>oxarticle / oxarticlelist, oxcategory / oxcategorylist, oxuser / oxuserlist etc.</em>). Während die Klassen der Einzelobjekte wie oben beschrieben Extensions von <em>oxBase </em>oder <em>oxI18n</em> sind, sind die Listenklassen Extensions von<em>oxList</em>. Die Klasse <em>oxList </em>implementiert einige vordefinierte Interfaces (<em>ArrayAccess, Iterator, Countable</em>) und bietet damit komfortable Möglichkeiten für den Umgang mit Objekten. Viel interessanter sind aber einige Standardmethoden dieser Klasse &#8211; wie z. B. <em>selectString()</em> &#8211; die einem das Leben extrem leicht machen können. Wir werden gleich sehen, was das konkret bedeutet. Zunächst aber legen wir unsere Listenklasse <em>azprojectlist</em> an wie folgt:<br />
<pre><code>
class azProjectList extends oxList
{
&nbsp;&nbsp;&nbsp;&nbsp;public function __construct( $sObjectsInListName = &#039;azproject&#039;)
&nbsp;&nbsp;&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return parent::__construct( &#039;azproject&#039;);
&nbsp;&nbsp;&nbsp;&nbsp;}
}
</code></pre><br />
Ziemlich übersichtlich &#8211; nicht wahr? <img src='http://www.urbans-blog.de/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' />  &#8211; Aber genau dafür nutzen wir ja schließlich Frameworks, um nicht alles ständig komplett neu machen zu müssen. Diese sieben Codezeilen werden uns gleich das Leben extrem vereinfachen.</p>
<div>&nbsp;</div>
<p><strong>Core-Objekt für Projektstammdaten in View-Klasse nutzen</strong></p>
<p>Auf der Startseite für unser Tool soll die komplette Datenerfassung erfolgen. Hier sollen auch neue Projekte mit ihrem aktuellen Stundensatz angelegt werden können. Die vorhandenen Projekte sollen über ein Dropdown-Menü ausgewählt werden können:</p>
<div id="attachment_244" class="wp-caption aligncenter" style="width: 524px"><a href="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid4project_screen_03_projectdata.png"><img class="size-full wp-image-244" title="oxid4project - Projektdatenerfassung" src="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid4project_screen_03_projectdata.png" alt="oxid4project - Projektdatenerfassung" width="514" height="36" /></a><p class="wp-caption-text">oxid4project - Projektdatenerfassung</p></div>
<p>Die Befüllung des Dropdown-Menüs erfolgt, indem wir in der View-Klasse <em>azprojectsstart</em> einen entsprechenden Getter implementieren:<br />
<pre><code>
public function getProjects()
{
&nbsp;&nbsp;$oProjectList = oxNew(&quot;azprojectlist&quot;);
&nbsp;&nbsp;$oProjectList-&gt;selectString(&quot;select oxid, aztitle from azprojects order by aztitle&quot;);

&nbsp;&nbsp;return $oProjectList-&gt;getArray();
}
</code></pre><br />
Im Template sieht das dann folgendermaßen aus:<br />
<pre><code>
&lt;select name=&quot;azdata[azjobs__azprojectid]&quot;&gt;
&nbsp;&nbsp;&lt;option value=&quot;&quot;&gt; -- Projekt auswählen -- &lt;/option&gt;
&nbsp;&nbsp;[{foreach from=$oView-&gt;getProjects() item=oProject}]
&nbsp;&nbsp;&nbsp;&nbsp;&lt;option value=&quot;[{$oProject-&gt;azprojects__oxid-&gt;value}]&quot;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;[{if $actProject == $oProject-&gt;azprojects__oxid-&gt;value}]selected[{/if}]&gt;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;[{$oProject-&gt;azprojects__aztitle-&gt;value}]
&nbsp;&nbsp;&nbsp;&nbsp;&lt;/option&gt;
&nbsp;&nbsp;[{/foreach}]
&lt;/select&gt;
</code></pre></p>
<p>Auch hier eine kurze Erläuterung:<br />
Der Getter <em>azprojectstart::getProjects()</em> instanziiert ein neues Objekt der Listeklasse <em>azprojectlist</em>. Dies erfolgt mittels der (Factory-)Funktion <em>oxNew()</em>. Auch hier steckt wieder viel Komfort und Know How des OF&#8217;s drin: Die Funktion <em>oxNew()</em> sorgt z. B. dafür, dass &#8211; falls vorhanden &#8211; Module für die instanziierten Klassen berücksichtigt werden.</p>
<p>Auf dem Listenklassenobjekt können wir nun die Methode <em>selectString()</em> ausführen, die als Parameter ein simples Datenbankquery bekommt. Diese Methode sorgt nun dafür, dass das Listenobjekt <em>$oProjectList</em> als protected property ein Array enthält, welches die Einzelobjekte sämtlicher Datensätze enthält, die über das Query gefunden wurden. Über die (public) Methode <em>getArray()</em> auf dem Listenobjekt können wir diese Liste nun abrufen und darüber iterieren (siehe Template).</p>
<div>&nbsp;</div>
<p><strong>Neue Stammdaten via Core-Objekt in der Datenbank speichern</strong></p>
<p>Nun fehlt noch das Speichern von neuen Projektstammdaten in der Datenbank. Um auch das ohne viel Aufwand erledigen zu können, kommt es darauf an, die Daten in einer speziellen Struktur zu erfassen, die der OF-eigenen Struktur bei Datenobjekten entspricht:</p>
<p><em>[Objektname]-&gt;[Tabellenname]__[Feldname]-&gt;value</em></p>
<p>Dementsprechend erhält unsere View-Klasse <em>azprojectsstart</em> nun folgende (protected) Methode:<br />
<pre><code>
protected function _createNewProject($title, $dPricePerHour)
{
&nbsp;&nbsp;$id = oxDb::getDb()-&gt;GetOne(&quot;select oxid from azprojects where aztitle = &#039;$title&#039;&quot;);
&nbsp;&nbsp;if(!empty($id)) {
&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;_aErrorMsg[] = &quot;Projekt schon vorhanden!&quot;;
&nbsp;&nbsp;&nbsp;&nbsp;return &quot;error&quot;;
&nbsp;&nbsp;}

&nbsp;&nbsp;$oProject = oxNew(&quot;azproject&quot;);
&nbsp;&nbsp;$oProject-&gt;azprojects__aztitle-&gt;value = $title;
&nbsp;&nbsp;$oProject-&gt;azprojects__azpriceperhour-&gt;value = $dPricePerHour;
&nbsp;&nbsp;$oProject-&gt;save();

&nbsp;&nbsp;return $oProject-&gt;getId();
}
</code></pre><br />
Die Methode wird innerhalb der (public) Methode <em>saveProjectData()</em> aufgerufen und erhält als Parameter die Inhalte der beiden Formularfelder für Projekttitel und Stundensatz. Die genaue Struktur bitte im Quellcode nachvollziehen.</p>
<p>Zunächst überprüfen wir, ob evtl. schon ein Projekt mit demselben Namen existiert und übergeben ggf. eine entsprechende Fehlermeldung. Konnte das neue Projekt erfolgreich angelegt werden, so wird die (OX-)ID des neuen Datensatzes zurückgeliefert.</p>
<div>&nbsp;</div>
<p><strong>Die Erfassung der Projekt- bzw. &#8220;Job&#8221;-Daten</strong></p>
<p>Wenn wir zuvor einige Beispielprojekte mit Stundensätzen angelegt haben, so können wir nun an die eigentliche Erfassung der Daten der einzelnen Jobs gehen. &#8220;Job&#8221; meint hier eine Arbeitseinheit eines Entwicklers an einem bestimmten Projekt.</p>
<p>Vom Grundprinzip her funktioniert das auf dieselbe Weise wie oben bei den Projektstammdaten beschrieben: Wir benötigen zwei core-Klassen <em>azjob </em>und <em>azjoblist</em>, dazu natürlich eine entsprechende Datenbanktabelle und noch die Einbindung in die View-Klasse <em>azprojectsstart</em>. Und da das Ganze hier ja ein <em>Workshop</em> sein soll (bzw. auf der Commons sein sollte &#8230;), kann das nun jeder für sich ausprobieren &#8211; oder aber sich im mitgelieferten Quellcode einfach anschauen, wie ich es gelöst habe. <img src='http://www.urbans-blog.de/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<div>&nbsp;</div>
<p><strong>Ein paar hilfreiche Hinweise zum Schluss</strong></p>
<p>Da der gesamte Beitrag hier nun bereits deutlich länger geworden ist, als gedacht, möchte ich für den Rest der Anwendung auf den überlassenen Quellcode verweisen. Auf ein paar Dinge möchte ich aber noch hinweisen, weil sie ohne tiefergehende OXID-Kenntnis nicht sofort selbsterklärend sind:</p>
<p><em><span style="text-decoration: underline;">functions.php<br />
</span></em>Innerhalb des <em>modules</em>-Verzeichnisses gibt es eine Datei <em>functions.php</em>, die standardmässig leer ist (abgesehen von einigen Kommentaren). Diese Datei ist dafür gedacht, eigene Funktionen anzulegen, die dann in allen übrigen PHP-Klassen genutzt werden können.<br />
Kleiner Praxistipp: Es empfiehlt sich, die eigenen Funktionen in eine extra Datei auszulagern und in der Datei <em>functions.php</em> über includes einzubinden. Grund: Sollten einmal externe Module in die Anwendung eingebunden werden, die ebenfalls eigene Funktionen mitbringen, so müssen diese nicht jedes Mal in der <em>functions.php</em> zusammengeführt werden sondern es reicht dann das Hinzufügen einer weiteren include-Zeile.</p>
<p>Da es sich hier um <em>Funktionen</em> handelt und nicht um in Klassen gekapselte <em>Methoden</em>, sollten diese von vornherein eindeutig benannt werden, indem z. B. ein eindeutiges Prefix vorangestellt wird (in meinem Falle &#8220;az&#8221;).</p>
<p>Ich habe hier 2 Funktionen untergebracht, die für die Dropdowns <em>Datum</em> und <em>Zeitaufwand</em> benutzt werden, um hier sämtliche Daten der letzten 180 Tage sowie Zeitabschnitte in Viertelstundenschritten anzeigen zu lassen.</p>
<p>Für die restliche Funktionalität verzichte ich hier auf weitere Erläuterungen. Jeder kann sich diese anhand des mitglieferten Quellcodes selbst erschließen.</p>
<div>&nbsp;</div>
<p><strong>Abschließende Hinweise zu einer möglichen Weiterentwicklung des Projektes</strong></p>
<p>Wer das Gesamtpaket einmal installiert und testet, wird schnell feststellen, dass hier noch etliche Wünsche offen bleiben. Speziell im Bereich der Auswertung könnte man sich noch viele nützliche Funktionen vorstellen. Gerade deshalb möchte ich das Projekt nun der Community zur Verfügung stellen, damit jeder, der Lust und Zeit hat, am Ausbau und an einer Verbesserung des Tools mitwirken kann. Wie schon gesagt werde ich versuchen, das Ganze schnellstmöglich als Projekt auf OXIDforge anzulegen, damit dann über diese Plattform eine gordnete Weiterentwicklung für Interessierte möglich wird.</p>
<p>Ein interessanter Aspekt der Weiterentwicklung könnte z. B. die Vereinfachung bei der Rechnungsstellung sein. Schließlich werkelt im Hintergrund ja ein <strong>Shop</strong>-Framework &#8211; es läge von daher nahe, aus abgerechneten Jobs Bestellungen zu generieren und hier dann entweder das Rechnungs-PDF des Shops zu nutzen oder aber die Daten über eine Schnittstelle in ein ERP-System zu überführen und dort dann automatisiert Rechnungen zu erstellen. Dafür müssten dann natürlich noch die Projektstammdaten mit Kundenstammdaten verknüpft werden, um einen vollständigen Bestelldatensatz generieren zu können. Das sollte sich aber durchaus machen lassen.</p>
<p>Jeder, der hier weiterführende Ideen beisteuern kann, ist herzlich eingeladen, sich an der Weiterentwicklung zu beteiligen! Sobald vorhanden, werde ich hier die entsprechenden Daten und Links bzgl. OXIDforge veröffentlichen.</p>
<div>&nbsp;</div>
<p><strong>Schlussbetrachtung im Kontext der zurückliegenden OXID Commons</strong></p>
<p>Nachdem ich vorgestern den ersten Teil des Workshops hier veröffentlicht hatte, erhielt ich im Blick auf meine krankheitsbedingte Absage für die Commons kurz darauf einen Tweet von Roland Fesenmayr, den ich hier kurz zitieren möchte:</p>
<blockquote><p>Wenn ich das lese, noch mehr schade, daß Du krank warst &#8230; hätte perfekt gepasst!</p></blockquote>
<p>Tja, das habe ich auch mehrfach gedacht, als ich die Live-Streams der Commons aus dem Krankenbett heraus mitverfolgte. Da war ja mehrfach die Rede von einem &#8220;Ecommerce Betriebssystem&#8221; welches modular aufgebaut sein soll und bei dem sich der Shopbetreiber passend zu seinem individuellen Geschäftsmodell genau <strong>die</strong> Komponenten auswählen kann, die ihm hilfreich erscheinen.</p>
<p>Nun ist ein Projekterfassungs-Tool nicht gerade ein &#8220;Geschäftsmodell&#8221; im Rahmen des Ecommerce. Dennoch zeigt mein Beispiel, wozu das OXID-Framework prinzipiell bereits jetzt fähig ist. Wir haben hier eben kein total starres System, das ausschließlich auf fest definierte Ecommerce-Szenarien abgestellt ist &#8211; sondern wir haben hier bereits heute einen Baukasten vor uns, der &#8211; richtig genutzt &#8211; an so ziemlich jedes Geschäftsmodell angepasst werden kann.</p>
<p>Nicht erst seit der Commons ist klar, dass aktuell ein frischer Wind durch die Ecommerce-Landschaft bläst. Noch ist das eher ein laues Lüftchen, das aber &#8211; nicht zuletzt durch die Verbreitung des iPads &#8211; spürbar an Fahrt aufnimmt. Einkaufen im Internet ist nicht mehr bloß die Besorgung von Dingen, für die man früher in ein Ladengeschäft stiefelte &#8211; Einkaufen im Internet bekommt mehr und mehr eine eigenständige Erlebnisqualität. Während Onlineshops lange Zeit versuchten, das Einkaufen im Ladengeschäft möglichst originalgetreu nachzubilden, gibt es mehr und mehr Features, die dem Onlinekauf einen echten Mehrwert geben. Das sind so Dinge wie z. B. die Möglichkeit von Preisvergleichen, der Austausch in sozialen Netzwerken &#8211; das sind aber auch neue technische Möglichkeiten. Ich freue mich schon darauf, wenn ich zum ersten Mal ein Bild meines Wohnzimmers in mein (hoffentlich bald verfügbares) iPad einlesen kann und die Möbel aus dem Onlineshop mit den Fingern in meinem Wohnzimmer hin und herschieben kann.</p>
<p>Alles, was da auf uns zukommt, wird um so spannender werden, je flexibler die Softwarekomponenten sind, die zur Umsetzung der verschiedensten Ideen zur Verfügung stehen &#8211; und je offener die Schnittstellen dieser Komponenten untereinander sind. Möglicherweise läuft ein Onlineshop dann auf Basis von 10 verschiedenen Komponenten, die auf 10 verschiedenen Webservern (oder in 10 verschiedenen Clouds?) laufen.</p>
<p>Mit meinem Beispiel eines Projekterfassungs-Tools wollte ich demonstrieren, dass das OXID Framework m. E. schon jetzt die Flexibilität und Offenheit bietet, um darauf (fast) alles Mögliche zu bauen. Zumindest ist OXID hier auf einem guten Weg.</p>
<div>&nbsp;</div>
<p><strong>Hinweise zum Download</strong></p>
<p>Der Download, der hier angeboten wird, ist ein Vorabangebot. Die Benutzung erfolgt komplett auf eigene Gefahr. Voraussetzung für die Nutzung der hier zur Verfügung gestellten Dateien ist eine frisch installierte OXID Community Edition 4.3.</p>
<p><a href="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid4project.zip">oxid4project Sourcen</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.urbans-blog.de/2010/05/09/oxid4all-%e2%80%93-es-muss-ja-nicht-immer-ein-shop-sein-%e2%80%a6-%e2%80%93-teil-3/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
		<item>
		<title>OXID4ALL – Es muss ja nicht immer ein Shop sein … – Teil 2</title>
		<link>http://www.urbans-blog.de/2010/05/08/oxid4all-%e2%80%93-es-muss-ja-nicht-immer-ein-shop-sein-%e2%80%a6-%e2%80%93-teil-2/</link>
		<comments>http://www.urbans-blog.de/2010/05/08/oxid4all-%e2%80%93-es-muss-ja-nicht-immer-ein-shop-sein-%e2%80%a6-%e2%80%93-teil-2/#comments</comments>
		<pubDate>Sat, 08 May 2010 19:18:12 +0000</pubDate>
		<dc:creator>urban</dc:creator>
				<category><![CDATA[OXID eShop]]></category>
		<category><![CDATA[commons]]></category>
		<category><![CDATA[framework]]></category>
		<category><![CDATA[oxid]]></category>
		<category><![CDATA[oxid ce]]></category>
		<category><![CDATA[programmierung]]></category>
		<category><![CDATA[projekt]]></category>
		<category><![CDATA[projekterfassung]]></category>
		<category><![CDATA[shop]]></category>
		<category><![CDATA[workshop]]></category>

		<guid isPermaLink="false">http://www.urbans-blog.de/?p=183</guid>
		<description><![CDATA[Die Entscheidung war nun also gefallen: Ich wollte versuchen, auf Basis einer OXID CE ein brauchbares Projekterfassungs-Tool für uns zu programmieren. Die ersten Schritte dorthin hätte ich gerne im Rahmen der OXID Commons 2010 mit euch im Rahmen eines Workshops nachvollzogen. Nun versuche ich, das Ganze hier lesbar aufzubereiten. Der Beitrag insgesamt verfolgt damit folgende [...]]]></description>
			<content:encoded><![CDATA[<p>Die Entscheidung war nun also gefallen: Ich wollte versuchen, auf Basis einer OXID CE ein brauchbares Projekterfassungs-Tool für uns zu programmieren. Die ersten Schritte dorthin hätte ich gerne im Rahmen der OXID Commons 2010 mit euch im Rahmen eines Workshops nachvollzogen. Nun versuche ich, das Ganze hier lesbar aufzubereiten.</p>
<div id="attachment_196" class="wp-caption aligncenter" style="width: 368px"><a href="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid4project_screen_01_login.png"><img class="size-full wp-image-196" title="oxid4project Login Screen" src="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid4project_screen_01_login.png" alt="oxid4project Login Screen" width="358" height="287" /></a><p class="wp-caption-text">oxid4project Login Screen</p></div>
<p>Der Beitrag insgesamt verfolgt damit folgende Ziele:</p>
<ol>
<li>einen generellen Einblick in das OXID Framework (OF) geben</li>
<li>zeigen, dass man damit nicht nur Onlineshops programmieren kann</li>
<li>hilfreiche Tipps geben für den Umgang mit dem OF, die auch im Rahmen von Shops sehr nützlich sind. <img src='http://www.urbans-blog.de/wp-includes/images/smilies/icon_wink.gif' alt=';-)' class='wp-smiley' /> </li>
</ol>
<div>&nbsp;</div>
<p><strong>Am Anfang steht das Konzept: Welche Grundelemente werden benötigt?</strong></p>
<p>Es macht so gut wie nie Sinn, einfach drauf los zu coden &#8211; vor allem dann nicht, wenn man ein vorhandenes Framework nutzen will. Um herauszufinden, welche Teile des Frameworks sich am sinnvollsten für die eigene Applikation nutzen lassen, sollte man zunächst die benötigten Grundelemente definieren. Diese Definition soll dabei so erfolgen, dass jedes der genannten Grundelemente sich nach Möglichkeit bereits als Objekt denken lässt. Oder anders gesagt: Wir suchen nach klar abgrenzbaren Sach- und Funktionsbereichen in unserer geplanten Anwendung, die sinnvoll im Rahmen einzelner Klassen gekapselt werden können.</p>
<p>Für unsere Projekterfassung benötigen wir folgende Bereiche / Elemente:</p>
<ul>
<li>Projekte: Projekt anlegen, löschen, editieren, auflisten &#8230;</li>
<li>Mitarbeiter: anlegen, löschen, editieren, Login &#8230; =&gt; OXID Userverwaltung</li>
<li>Erfassung von Arbeitseinheiten: Zeit- und Texterfassung, Bearbeitung von Einträgen, Löschen &#8230;</li>
<li>Auswertungen: nur für Admin sicht- und nutzbar, über Frontend erreichbar (also nicht im Shop-Admin)</li>
</ul>
<p>Aus dieser Definition ergibt sich ein Konzept für die benötigten Views und Templates sowie für sinnvolle Core-Objekte. Fangen wir pragmatisch mit den Views und Templates an:</p>
<div>&nbsp;</div>
<p><strong>Konzeption der Views und Templates</strong></p>
<p>Die gesamte Anwendung soll im Endeffekt ja auf einem Webserver im Netz laufen, damit jeder Mitarbeiter das Tool nutzen kann, wo immer er sich auch gerade befindet. Also brauchen wir zunächst einmal einen Login-Bereich. Wie oben schon angedeutet, können wir hier komplett die OXID Standardfunktionalität der Benutzerverwaltung nutzen.<br />
Als nächstes brauchen wir eine Zeit- und Texterfassungsmaske, in der die Mitarbeiter ein Projekt auswählen und eintragen können, wie lange sie daran gearbeitet haben und was genau sie in dieser Zeit gemacht haben.<br />
Für die eigentliche Datenerfassung ist das schon alles. Allerdings will ich als Admin ja auch ein paar Auswertungsmöglichkeiten haben. Also fehlen noch folgende Views / Templates:</p>
<ul>
<li>Listenseite(n) für Auswertungen (z. B.: alle noch nicht abgerechneten Projekte im Monat &#8220;X&#8221; etc.)</li>
<li>Detailseite für Auswertungen (z. B.: alle noch nicht abgerechneten Arbeitseinheiten von Projekt &#8220;Y&#8221; im Monat &#8220;X&#8221; etc.)</li>
<li>Detailseite für Bearbeitung von Einzeleinträgen, z. B. wegen Korrekturen, Abzug von nicht abrechenbaren Zeiten etc.</li>
</ul>
<div>&nbsp;</div>
<p><strong>Let&#8217;s code! &#8211; Login-Seite</strong></p>
<p>Die Login-Seite ist im Grunde der einfachste Teil der gesamten Übung, weil wir hier zu nahezu 100% auf OXID Standardfunktionalität zurückgreifen können. Dennoch kann man bereits hier den ein oder anderen hilfreichen Tipp für den generellen Umgang mit dem OXID Framework unterbringen. Daher das Ganze nun etwas ausführlicher:</p>
<p>Wir brauchen eine View-Klasse und ein zugehöriges Template. Die View-Klasse gestaltet sich dabei ausgesprochen simpel:<br />
<pre><code>
class azprojectsLogin extends oxUbase
{
&nbsp;&nbsp;/**
&nbsp;&nbsp; * name of template file
&nbsp;&nbsp; * @var str
&nbsp;&nbsp; */
&nbsp;&nbsp;protected $_sThisTemplate = &quot;azprojectslogin.tpl&quot;;

&nbsp;&nbsp;/**
&nbsp;&nbsp; * calls parent (oxUbase) render and returns name of tpl file
&nbsp;&nbsp; * @return str $this-&gt;_sThisTemplate
&nbsp;&nbsp; *
&nbsp;&nbsp; */
&nbsp;&nbsp;public function render() {
&nbsp;&nbsp;&nbsp;&nbsp;parent::render();

&nbsp;&nbsp;&nbsp;&nbsp;return $this-&gt;_sThisTemplate;
&nbsp;&nbsp;}
}
</code></pre></p>
<p>Jede View-Klasse im OF ist Extension der Klasse oxUbase. Wir verwenden diese Vererbung, um gewisse Grundmechanismen im OF automatisch mitnutzen zu können. Dabei ist zu beachten, dass eine View-Klasse dann auch immer eine public function render() besitzen muss, die a.) die parent::render() aufruft und b.) als return-Wert den Namen der Template-Datei zurückliefert.<br />
Damit sind die Mindestanforderungen für eine eigene View-Klasse bereits erfüllt. Gesagt sei noch, dass der Dateiname der Klasse sinnvollerweise mit dem Klassennamen identisch sein &#8211; allerdings komplett in Kleinbuchstaben gehalten sein sollte. So vermeidet man Probleme beim Switch zwischen verschiedenen Betriebssystemen (z. B. Windows / Mac / BSD / Linux etc.).</p>
<p>Als nächstes machen wir uns nun an das Template heran. Dieses sollte am Ende in etwa so aussehen wie der Screenshot am Anfang dieses Beitrags (<a title="oxid4project Login Screen" href="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid4project_screen_01_login.png" target="_blank">oxid4project Login-Screen</a>).</p>
<p>Hier kommt es natürlich nicht auf das konkrete Layout an &#8211; das möge sich jeder so gestalten, wie es ihm gefällt. Ich möchte  lediglich auf ein paar <strong>Grundzüge bei der Templategestaltung</strong> hinweisen.</p>
<p>Im OXID eShop besteht nahezu jede im Frontend sichtbare Seite aus mind. 6 Einzeltemplates, die in Form von includes eingebunden werden:</p>
<ol>
<li><em>something.tpl</em> &#8211; Die Template-Datei, die von der aktuell aufgerufenen View-Klasse als return-Wert der render() function zurückgeliefert wird. Name ist natürlich für jede Seite anders. Hier erscheint der eigentliche Content der jeweiligen Seite.</li>
<li><em>_header.tpl</em> &#8211; Der Kopfbereich der Seite; wird innerhalb von <em>something.tpl</em> inkludiert.</li>
<li><em>_footer.tpl</em> &#8211; Der Fußbereich der Seite; wird innerhalb von <em>something.tpl</em> inkludiert.</li>
<li><em>_path.tpl</em> &#8211; Anzeige der Breadcrumb-Navigation.</li>
<li><em>_left.tpl</em> &#8211; Navigationsbereich auf der linken Seite; wird innerhalb von <em>_header.tpl</em> inkludiert.</li>
<li><em>_right.tpl</em> &#8211; Bereich für Aktionsboxen auf der rechten Seite; wird innerhalb von <em>_header.tpl</em> inkludiert.</li>
</ol>
<p>Den größten Teil der Inhalte dieser OXID-Standardtemplatedateien benötigen wir für unser Projekt nicht. Also bauen wir uns stark vereinfachte eigene include-Dateien. Die generelle Nutzung des Grundschemas mit includes macht Sinn, da wir für unser kleines Tool ja auch eine ansprechende Optik wünschen und sich im Kopfbereich z. B. gut einige administrative Navigationspunkte unterbringen lassen, die damit dann automatisch auf jeder Seite sichtbar sind.</p>
<p>Einen speziellen Bereich auf der linken oder rechten Seite brauchen wir nicht, weshalb die entsprechenden includes komplett entfallen können. Dasselbe gilt für die Breadcrumb Navigation, die im Shop vor allem den Kategoriepfad nachbildet, den wir in unserer Anwendung überhaupt nicht benutzen.</p>
<p>Wie die Templates im einzelnen aussehen, kann sich jeder anhand der Beispieldateien selbst ansehen. <em>(In Kürze möchte ich das Ganze als Projekt auf  OXIDforge anlegen. Leider kann ich dort zur Zeit keinen Account erstellen &#8230; daher gibt&#8217;s die Dateien zunächst mal als Download hier im Blog. -&gt; siehe Ende des Beitrags)</em></p>
<p>Hier sei nur erwähnt, dass ich mich für die aktuelle Anwendung entschieden habe, zwei eigene include-Dateien <em>azprojectsheader.tpl </em>und <em>azprojectsfooter.tpl</em> zu erstellen. In beiden Dateien ist nur das Nötigste enthalten. Auf ein paar Dinge möchte ich aber hinweisen:</p>
<p><span style="text-decoration: underline;">dynamischer Seitentitel<br />
</span>Im Grunde soll jeder selbst entscheiden ob und welchen Seitentitel er für dieses Tool benutzen möchte. Ich habe mich daher dafür entschieden, den Shopnamen hier als dynamischen Wert einzusetzen, da dieser über den Shop-Adminbereich leicht änderbar ist. Die Einbindung sieht aus wie folgt:<br />
<pre><code>
Projekterfassung - [{$oxcmp_shop-&gt;oxshops__oxname-&gt;value}]
</code></pre><br />
Das Objekt <em>$oxcmp_shop</em> ist dabei ein sog. <em>Komponenten-Objekt</em>. Die <em>Komponenten</em> sind besondere View-Klassen im OF, die in Form des Decorator Patterns bei jeder View-Klassen Instanziierung mitinstanziiert werden. Somit stehen Komponentenobjekte shop- bzw. applikationsübergreifend überall zur Verfügung. Das ist sehr nützlich und ich kann nur empfehlen, sich mit den OF Komponenten ein wenig genauer zu beschäftigen. Die entsprechenden Klassendateien finden sich alle im Verzeichnis <em>views</em> und die Dateinamen beginnen alle mit <em>oxcmp_&#8230;<br />
</em>Es ist sogar relativ einfach möglich, beliebig viele eigene Komponenten in das OF einzubinden. Es würde den Rahmen dieses Beitrages sprengen, dies hier im Detail zu erläutern. Den erfahrenen OXID&#8217;lern sei ein Blick View-Klasse <em>oxUbase</em> empfohlen. Dort findet ihr unter den protected properties u. a. auch das Array namens <em>$_aComponentNames</em>. Direkt darunter findet sich ein leeres Array namens <em>$_aUserComponentNames</em> &#8211; hier können eigene Komponenten eingehängt werden &#8211; eine der vielfältigen Erweiterungsmöglichkeiten, die das OF von Haus aus anbietet.</p>
<p><span style="text-decoration: underline;">Einbindung von Bildern<br />
</span>Bilder, die im Rahmen des Layouts benötigt werden, liegen im OF immer im Verzeichnis <em>/out/basic/img.</em> Dieser Pfad ist innerhalb der Templates abrufbar mittels der Methode <em>$oViewConf->getImageUrl()</em>. Es empfiehlt sich, diese Systematik beizubehalten, weil so auch später das Verlagern der Grafiken in einen anderen Pfad oder auf einen anderen Server sehr einfach zu realisieren ist, ohne gleich alle Templates ändern zu müssen.</p>
<p><span style="text-decoration: underline;">HomeLink<br />
</span>Auf dem Logo oben links liegt &#8211; wie gemeinhin üblich &#8211; der Link zur Startseite unserer Anwendung. Im OF gibt es auch dafür eine eigene Methode, die innerhalb der Templates genutzt werden kann: <em>$oViewConf->getHomeLink()</em>.</p>
<p><span style="text-decoration: underline;">Sonstige Links<br />
</span>In der Templatedatei <em>azprojectsheader.tpl</em> finden sich einige Navigationslinks, die weitere (eigene) View-Klassen aufrufen sollen. Dies erfolgt innerhalb des OF generell via:<br />
<pre><code>
&lt;a href=&quot;[{ $oViewConf-&gt;getSelfLink() }]cl=myclassname&quot;&gt;Linktext&lt;/a&gt;
</code></pre><br />
wobei <em>myclassname</em> der Name der aufzurufenden View-Klasse ist.</p>
<p><span style="text-decoration: underline;">Navigation nur für eingloggte User anzeigen</span></p>
<p>Die Navigation im Kopfbereich (Erfassung, Auswertung, Logout) sollte natürlich nur für eingeloggte User zu sehen sein. Dies erreichen wir sehr einfach über die folgende Abfrage im Template <em>/out/basic/tpl/azprojectsheader.tpl</em>:<br />
<pre><code>
[{ if $oxcmp_user-&gt;oxuser__oxpassword-&gt;value }]
...
[{ /if }]
</code></pre></p>
<div>&nbsp;</div>
<p><strong>Login-Funktionalität</strong></p>
<p>Für die eigentliche Login-Funktionalität nutzen wir zu 100% OXID-Bordmittel. Das Login / Logout-Formular können wir komplett aus dem include-Template <em>/out/basic/tpl/inc/cmp_login.tpl</em> übernehmen. Der Klassenparameter, der in diesem Formular als hidden field &#8220;cl&#8221; übergeben wird, wird hier dynamisch mit der aktuell aufgerufenen View-Klasse gefüllt. Außerdem finden wir in dem Formular noch ein hidden field mit <em>name=&#8221;fnc&#8221;</em> &#8211; dieses dient dazu, eine spezielle Methode auf der View-Klasse auszuführen. Der Name dieser Methode ist &#8211; je nach Zustand &#8211; <em>login_noredirect</em> oder <em>logout</em>.</p>
<p>In unserer View-Klasse <em>azprojectslogin </em>gibt es aber weder die eine noch die andere Methode. Das macht aber nichts &#8211; denn beide Methoden gehören zum Komponentenobjekt <em>oxcmp_user</em> und &#8211; wie oben schon erwähnt &#8211; stehen die Komponentenobjekte überall zur Verfügung. Und deshalb können wir auch die Methoden dieser Objekte an beliebiger Stelle aufrufen.</p>
<div>&nbsp;</div>
<p><strong>Umleitung der Startseite</strong><br />
Eine Kleinigkeit fehlt noch: Bisher bekommen wir noch immer die Startseite des Shops zu sehen, wenn wir unsere Anwendung ohne weitere Parameter aufrufen. Um das zu ändern legen wir ein kleines Modul der View-Klasse <em>start</em> an. Dazu erstellen wir eine Moduldatei mit dem Namen <em>azstart.php </em>mit folgendem Inhalt:<br />
<pre><code>
class azStart extends azStart_parent
{
&nbsp;&nbsp;public function init()
&nbsp;&nbsp;&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;header(&quot;location: index.php?cl=azprojectsstart&quot;);
&nbsp;&nbsp;&nbsp;&nbsp;}

}
</code></pre><br />
Diese Datei speichern wir nun unter: <em>/modules/azstart/azstart.php</em>. Anschließend rufen wir den Shop-Adminbereich auf (http://[Shopadresse]/admin/). Hier muss da Modul nun noch registriert werden: <em>Admin &#8211;&gt; Stammdaten &#8211;&gt; Grundeinstellungen &#8211;&gt; System &#8211;&gt; Module</em>. Dort bitte folgenden Eintrag tätigen:<br />
<em>start =&gt; azstart/azstart</em><br />
und speichern. Nun wird jeder Aufruf der Shopstartseite auf die View-Klasse <em>azprojectsstart</em> umgeleitet. Diese existiert aber noch nicht und wird auch erst im dritten Teil dieses Workshops erläutert werden. Sie liegt aber dem Downloadpaket bereits &#8211; in abgespeckter Form &#8211; bei. Dort könnt ihr sehen, dass es auch in dieser Klasse innerhalb der Methode <em>init()</em> eine header-Weiterleitung auf die Login-Klasse gibt für den Fall, dass der User noch nicht eingeloggt ist.<br />
Die Methode <em>init()</em> wird &#8211; nach einem evtl. vorhandenen constructor &#8211; immer als erste in einer View-Klasse ausgeführt.</p>
<div>&nbsp;</div>
<p><strong>Die Grundlage ist geschaffen</strong></p>
<p>Bis hierher haben wir nun also die Grundlage für das geplante Tool geschaffen. Es fehlt noch die eigentliche Funktionalität &#8211; die ich in Teil 3 dieses Workshops präsentieren möchte. Aber ich denke, man konnte bis hier her bereits eine Ahnung dafür entwickeln, dass das OF viele Möglichkeiten für eigene Entwicklungen bietet. Diesem Beitrag hängt nun auch der erste Teil des Quellcodes des Projektes an, so dass die oben beschriebenen Punkte direkt nachvollzogen werden können.</p>
<p>Mit dem dritten Teil werde ich dann den kompletten Quellcode des Projektes liefern &#8211; vielleicht dann ja schon als OXIDforge-Projekt. Hier schon einmal ein Vorab-Happen: <a href="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid4project_source_part_1.zip">oxid4project_source_part_1</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.urbans-blog.de/2010/05/08/oxid4all-%e2%80%93-es-muss-ja-nicht-immer-ein-shop-sein-%e2%80%a6-%e2%80%93-teil-2/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>OXID4ALL &#8211; Es muss ja nicht immer ein Shop sein &#8230; &#8211; Teil 1</title>
		<link>http://www.urbans-blog.de/2010/05/07/oxid4all-es-muss-ja-nicht-immer-ein-shop-sein-teil-1/</link>
		<comments>http://www.urbans-blog.de/2010/05/07/oxid4all-es-muss-ja-nicht-immer-ein-shop-sein-teil-1/#comments</comments>
		<pubDate>Fri, 07 May 2010 17:25:07 +0000</pubDate>
		<dc:creator>urban</dc:creator>
				<category><![CDATA[OXID eShop]]></category>

		<guid isPermaLink="false">http://www.urbans-blog.de/?p=167</guid>
		<description><![CDATA[Eigentlich hätte ich gestern im Rahmen der OXID Commons einen Workshop halten sollen. Ich hatte mich schon sehr darauf gefreut, aber bereits am Dienstagabend zeichnete sich ab, dass irgendein grippaler Infekt drauf und dran war, die Oberhand über meinen Körper zu gewinnen. Also sah ich mich gezwungen, meine Teilnahme an den Commons schweren Herzens abzusagen. [...]]]></description>
			<content:encoded><![CDATA[<p>Eigentlich hätte ich gestern im Rahmen der <a title="OXID Commons 2010" href="http://www.oxid-esales.com/de/news/oxid-commons-2010" target="_blank">OXID Commons</a> einen Workshop halten sollen. Ich hatte mich schon sehr darauf gefreut, aber bereits am Dienstagabend zeichnete sich ab, dass irgendein grippaler Infekt drauf und dran war, die Oberhand über meinen Körper zu gewinnen. Also sah ich mich gezwungen, meine Teilnahme an den Commons schweren Herzens abzusagen.</p>
<p>Da ich die letzten 3 Tage zeitweise fiebernd überwiegend im Bett verbracht habe, war diese Entscheidung aber rückblickend wohl die richtige. Ich hätte den Donnerstag vermutlich nicht durchgestanden.</p>
<p>Ich bedanke mich auf diesem Wege für die vielen Genesungswünsche, die mich in den letzten Tagen speziell aus den Reihen der Commons erreicht haben. Mehrfach schrieb man mir: &#8220;Schade &#8211; ich hatte mich so auf deinen Workshop gefreut &#8230;&#8221;<br />
Den Workshop an sich kann ich nun nicht wirklich nachliefern &#8211; aber ich möchte hier nun zumindest grob erläutern, worum es in dem Workshop gegangen wäre. Am Ende des letzten Teiles werde ich auch den entsprechenden Quellcode zur Verfügung stellen.</p>
<div id="attachment_168" class="wp-caption alignright" style="width: 310px"><a href="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid-werkzeugkasten.jpg"><img class="size-medium wp-image-168" title="OXID eShop als Werkzeugkasten für eigene Anwendungen" src="http://www.urbans-blog.de/wp-content/anz_uploads/2010/05/oxid-werkzeugkasten-300x207.jpg" alt="OXID eShop als Werkzeugkasten für eigene Anwendungen" width="300" height="207" /></a><p class="wp-caption-text">OXID eShop als Werkzeugkasten für eigene Anwendungen</p></div>
<p><strong>OXID4ALL &#8211; Es muss ja nicht immer ein Shop sein &#8230;</strong></p>
<p><em>Das OXID eShop Framework als Werzkeugkasten für eigene Anwendungen</em></p>
<p>Hauptziel des Workshops sollte sein, einmal an einem praktischen Beispiel zu zeigen, vie vielseitig man das OXID eShop Framework einsetzen kann &#8211; und dass es dabei eben nicht immer nur um Shop-Projekte gehen muss. &#8220;OXID4ALL&#8221; ist daher nicht nur gemeint im Sinne von: &#8220;OXID für alle!&#8221; &#8211; sondern eben auch im Sinne von: &#8220;OXID für alles?&#8221; &#8211; Das Fragezeichen ist hier bewusst gewählt, weil man die Art und Weise wie das OXID-Framework im folgenden Beispiel verwendet wird, sicher auch kritisch betrachten kann. Trotzdem denke ich, kann man auf diese Weise recht gut demonstrieren, wie viel Potential in diesem Framework steckt.</p>
<p><strong>Wie alles begann: Auf der Suche nach einer einfachen Projekterfassungssoftware</strong></p>
<p>Vor etwa 1 1/2 Jahren war ich auf der Suche nach einer Software, mit der unsere Entwickler schnell und einfach erfassen konnten, was sie an welchem Projekt gerade gearbeitet hatten. Die Software sollte preiswert sein, leicht zu handhaben, netzwerkfähig und nach eigenen Bedürfnissen anpassbar. Folgende Anforderungen stellte ich anfangs an die gesuchte Software:</p>
<ul>
<li>Login für Mitarbeiter</li>
<li>Eintragen von Projekten mit jeweiligem Stundensatz</li>
<li>Erfassung der Zeiten: <strong>wann</strong> wurde <strong>von wem wie lange</strong> an <strong>welchem Projekt was </strong>gearbeitet?</li>
<li>Vereinfachung der monatlichen Rechnungsstellung</li>
<li>Platz für interne Anmerkungen</li>
<li>Möglichkeit von diversen Auswertungen</li>
</ul>
<p>Nach einigen Tagen des Suchens und Ausprobierens stellte ich ernüchtert fest, dass alle Lösungen, die ich gefunden hatte</p>
<p>- zu komplex und/oder<br />
- zu teuer und/oder<br />
- zu unflexibel und nur schwierig oder gar nicht anpassbar und/oder<br />
- zu unhandlich</p>
<p>waren. Da ich aber schnell eine Lösung benötigte und nicht länger weitersuchen wollte, bot sich als einzige Alternative: seber machen!</p>
<p><strong>Ein Framework muss her!</strong></p>
<p>Wenn man &#8220;mal eben schnell&#8221; eine kleine Applikation schreiben will, greift der PHP-Entwickler ja gemeinhin zum &#8220;Framework&#8221;. Da ich mich bis zu diesem Zeitpunkt noch nie so richtig intensiv mit dem ZEND-Framework (ZF) beschäftigt hatte, witterte ich die Chance, hier gleich 2 Fliegen mit einer Klappe zu erschlagen und dachte mir: Prima &#8211; nutze ich diesen Anlass, um mich da mal einzuarbeiten.</p>
<p>Nach rund zwei Tagen Kampf mit dem ZF musste ich allerdings feststellen: Wir zwei werden keine Freunde. <img src='http://www.urbans-blog.de/wp-includes/images/smilies/icon_sad.gif' alt=':-(' class='wp-smiley' /><br />
Vielleicht fehlte mir einfach die Zeit und die Ruhe, vielleicht auch die richtige Anleitung &#8230; &#8211; vielleicht bin ich auch einfach irgendwie inkompatibel mit dem ZF &#8211; jedenfalls erschien mir das alles extrem umständlich und langwierig. Und ich wollte ja schnell zum Ziel kommen.<br />
Um ehrlich zu sein: ich habe in diesen 2 Tagen das ZF hassen gelernt. Das spricht nun nicht zwangsläufig gegen das ZF &#8211; vielleicht spricht es eher gegen mich. Jedenfalls scheint mir das ZF nichts für Ungeduldige zu sein, die gerne schnell ein Ergebnis sehen möchten.</p>
<p>Nachdem ich das Thema &#8220;Zend Framework&#8221; für mich zunächst abgehakt hatte, blieb nur noch der Weg, etwas komplett Eigenes zu versuchen. Ich hatte schon früher einmal ein eigenes kleines PHP-Framework erstellt, warum nicht das nutzen, ein bißchen Refactoring betreiben und es weiter ausbauen?<br />
Als ich dann damit begann stellte ich irgendwann plötzlich fest: Das sieht verdammt noch mal sehr nach OXID aus &#8230;</p>
<p>Und genau <strong>da </strong>machte es &#8220;Klick&#8221; und ich fragte mich: Warum also nicht gleich OXID nehmen?!<br />
Der OXID eShop bringt ja schon vieles mit, was ich mir für meine Projekterfassung wünschte:</p>
<ul>
<li>User-Login</li>
<li>Session-Verwaltung</li>
<li>Rechte-System (Admin / normaler User)</li>
<li>und vieles mehr &#8230;</li>
</ul>
<p>Ganz entscheidend war natürlich die Tatsache: Mit OXID kenne ich mich aus &#8211; damit kennen sich unsere Entwickler aus! Ein Ausbau und die Anpassung einer Anwendung auf OXID-Basis sollte für uns also ein Kinderspiel sein.</p>
<p><strong>OXID statt Zend Framework??</strong></p>
<p>Moooment! Kann das denn angehen? Eine Anwendung, die gar nichts mit einem Shop zu tun hat, soll auf Basis einer Shop-Software programmiert werden? Schließlich wird ja seit einiger Zeit werbewirksam (und konkurrenzorientiert) diskutiert, ob man den OXID eShop nicht stärker an das Zend Framework anbinden solle. Und nun kommt der Ziethen daher und will eine Anwendung statt auf dem ZF auf dem OXID Framework aufsetzen? &#8211; Heißt das nicht den Bock zum Gärtner machen?</p>
<p>Wie schon oben angedeutet: Das Ganze hier soll ein Anstoss sein &#8211; zum Nachdenken, zum Ausprobieren und zur eigenen Kreativität. Ich behaupte nicht, dass man nun sinnvollerweise alle möglichen Anwendungen auf OXID aufbauen könnte &#8211; aber ich möchte aufzeigen, was dieses Framework alles kann und von Haus aus mitbringt:</p>
<ul>
<li>MVC Architektur</li>
<li>vollständige Objektorientierung</li>
<li>gute Kapselung und Atomisierung der einzelnen Funktionen</li>
<li>Exception-Handling</li>
<li>Modul-Schnittstelle</li>
<li>Komponenten-Modell</li>
<li>Template-Engine</li>
<li>Datenbankabstratktionslayer</li>
<li>Benutzerverwaltung</li>
<li>Session-Handling</li>
<li>Config-Objekt</li>
<li>Mehrsprachitkeit</li>
<li>zahlreiche Utilities</li>
<li>uvm.</li>
</ul>
<p>Wenn man genau hinschaut, dann kann man im OXID-Framework einen sehr vielfältigen Werkzeugkasten sehen, der einem eine solide Basis für eigene Anwendungen bietet. Und wie das konkret aussehen kann, das werde ich im zweiten Teil dieses Beitrages an dem schon erwähnten Beispiel einer Projekterfassungssoftware demonstrieren.<br />
Ich werde versuchen, den zweiten Teil noch an diesem Wochenende fertigzustellen.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.urbans-blog.de/2010/05/07/oxid4all-es-muss-ja-nicht-immer-ein-shop-sein-teil-1/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>OXID goes Open Source</title>
		<link>http://www.urbans-blog.de/2008/10/30/oxid-goes-open-source/</link>
		<comments>http://www.urbans-blog.de/2008/10/30/oxid-goes-open-source/#comments</comments>
		<pubDate>Thu, 30 Oct 2008 09:44:34 +0000</pubDate>
		<dc:creator>urban</dc:creator>
				<category><![CDATA[OXID eShop]]></category>
		<category><![CDATA[free]]></category>
		<category><![CDATA[open source]]></category>
		<category><![CDATA[oxid]]></category>

		<guid isPermaLink="false">http://www.urbans-blog.de/?p=51</guid>
		<description><![CDATA[Today we got a new open source shop-system: OXID eShop CE. The OXID eSales AG launched their new Releases 4.0 for Professional and Enterprise Edition &#8211; and beside that &#8211; a brandnew &#8220;Community Edition&#8221; which is actually exact the same as the Professional Edition &#8211; but: it&#8217;s completely open source &#8211; and: it&#8217;s for free. [...]]]></description>
			<content:encoded><![CDATA[<p>Today we got a new open source shop-system: OXID eShop CE.<br />
The <a title="OXID eSales AG" href="http://www.oxid-esales.com" target="_blank">OXID eSales AG</a> launched their new Releases 4.0 for Professional and Enterprise Edition &#8211; and beside that &#8211; a brandnew &#8220;Community Edition&#8221; which is actually exact the same as the Professional Edition &#8211; but: it&#8217;s completely open source &#8211; and: it&#8217;s for free.</p>
<p>As I know a new community platform with several docs and a new forum is planed as well.  Unfortunately today there&#8217;s only a sort of prototype of this new platform online &#8230;</p>
<p>This new open source edition now makes it possible for everyone to use, change and extend the software which is released unter GPL V3.</p>
<p>I think this was a brave decision and I am very curious about the consequences during the next months. Probably we should see some rapid development of all sorts of extensions and modifications. Exciting times for OXID &#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://www.urbans-blog.de/2008/10/30/oxid-goes-open-source/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Looking forward to OXID eShop 4.0</title>
		<link>http://www.urbans-blog.de/2008/10/19/looking-forward-to-oxid-eshop-40/</link>
		<comments>http://www.urbans-blog.de/2008/10/19/looking-forward-to-oxid-eshop-40/#comments</comments>
		<pubDate>Sun, 19 Oct 2008 15:58:46 +0000</pubDate>
		<dc:creator>urban</dc:creator>
				<category><![CDATA[OXID eShop]]></category>
		<category><![CDATA[oxid]]></category>
		<category><![CDATA[refactoring]]></category>
		<category><![CDATA[shop]]></category>

		<guid isPermaLink="false">http://www.urbans-blog.de/?p=42</guid>
		<description><![CDATA[This weekend I took some time to have a first closer look to the beta release of OXID eShop 4.0 software which still is available only for registered beta users and some OXID Partners. Although there&#8217;s no official release date yet and I&#8217;m not allowed to say too much, I&#8217;d like to tell a few [...]]]></description>
			<content:encoded><![CDATA[<p>This weekend I took some time to have a first closer look to the beta release of OXID eShop 4.0 software which still is available only for registered beta users and some OXID Partners. Although there&#8217;s no official release date yet and I&#8217;m not allowed to say too much, I&#8217;d like to tell a few impressions I got and which hopefully are not revealing top secrets. <img src='http://www.urbans-blog.de/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>It&#8217;s known quite some time and e. g. told <a title="Lars Jankowfsky: Refactoring legacy Code ?" href="http://www.frontalaufprall.com/2008/10/13/refactoring-legacy-code/" target="_blank">here</a> &#8211; or <a title="OXID eShop 4.0 Betatest" href="http://www.hendrikbahr.de/oxid-eshop4-betatest/" target="_blank">here</a>, that <a title="OXID eSales AG" href="http://www.oxid-esales.com" target="_blank">OXID eSales AG</a> has spent nearly two years of refactoring the code of their software. Together with that some new structures and workflows have been introduced for improved quality management.</p>
<p>The result of all that &#8211; in my opinion &#8211; is a great step forward (and as the bush drums tell, there might come up some even bigger steps soon &#8230;). The whole code has been extremely cleaned up, monster classes and methods have been cut down to small and handy pieces &#8211; obviously a result of the consequent use of unit testing.</p>
<p>There are some new features &#8211; which I did not sort out totally yet. Just to mention some:</p>
<ul>
<li>use of session cookies instead of session ids in urls</li>
<li>very nice SEO URL concept</li>
<li>free mapable SEO URLs (e. g. for content pages and so on)</li>
<li>SEO optimized templates</li>
<li>XHTML-valid templates (finally &#8230;)</li>
<li>div-based layout without needless tables</li>
<li>some web 2.0 stuff (tag clouds, social bookmarking &#8230;)</li>
<li>redesign of admin interface</li>
<li>&#8230;</li>
</ul>
<p>But from a developers point of view the new features are not that important in this new version. The most important thing is the redesigned source code. Already a first look at the class tree shows you which enormous work has been done here.<br />
Much of the functionality has been put into core classes now, there&#8217;s a strict concept of getters and setters now, corresponding to well structured public and protected properties and methods, even some interfaces have been implemented. As far as I could see you finally have consequent namings of classes, functions and variables now. Some very helpful static classes and methods do make live easier and &#8230; and &#8230; and &#8230;</p>
<p>Developers who worked with the OXID versions before will need some time to get used to the new source structure &#8211; but this time will be spent very well and I think at the end of the day they will love to work with the new version. And as you once understand the logic behind all the changes, your work will become much easier.</p>
<p>After the official release (and if I can take some time for that) I will explain some details of the source code here.<br />
For this moment I am very much looking forward to the first release and from what I saw so far this will be much more stable then the last bigger release. In our company we have already started some new projects using the actual beta release cause I did not find any critical bugs so far.</p>
<p>More to come after the official release &#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://www.urbans-blog.de/2008/10/19/looking-forward-to-oxid-eshop-40/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Checkboxes in admin interface &#8211; a quick &amp; dirty trick</title>
		<link>http://www.urbans-blog.de/2008/02/09/checkboxes-in-admin-interface-a-quick-dirty-trick/</link>
		<comments>http://www.urbans-blog.de/2008/02/09/checkboxes-in-admin-interface-a-quick-dirty-trick/#comments</comments>
		<pubDate>Sat, 09 Feb 2008 19:31:29 +0000</pubDate>
		<dc:creator>urban</dc:creator>
				<category><![CDATA[OXID eShop]]></category>
		<category><![CDATA[checkbox]]></category>
		<category><![CDATA[enum]]></category>
		<category><![CDATA[trick]]></category>

		<guid isPermaLink="false">http://www.urbans-blog.de/2008/02/09/checkboxes-in-admin-interface-a-quick-dirty-trick/</guid>
		<description><![CDATA[If you add enum-fields to a table and want to make them editable in an admin menue you are faced to the fact that if the box is not checked &#8211; no parameter is passed to the according PHP-script. Normally you would have to write a small module of the according class containing the save [...]]]></description>
			<content:encoded><![CDATA[<p>If you add enum-fields to a table and want to make them editable in an admin menue you are faced to the fact that if the box is not checked &#8211; no parameter is passed to the according PHP-script. Normally you would have to write a small module of the according class containing the save function with something like this:</p>
<p><pre><pre lang="php">
if(!isset($aParams[&#039;nameOfCheckboxField&#039;]))
&nbsp;&nbsp;&nbsp;&nbsp;$aParams[&#039;nameOfCheckboxField&#039;] = 0;
</pre></pre></p>
<p>Writing a module for such simple stuff is a bit overhead. So what you can do instead in the according template is:<br />
<pre><pre lang="php">
&lt;input type=&quot;hidden&quot; name=&quot;nameOfCheckboxField&quot; value=&quot;0&quot;&gt;
&lt;input type=&quot;checkbox&quot; name=&quot;nameOfCheckboxField&quot; value=&quot;1&quot;&gt;
</pre></pre><br />
So now, if the checkbox is checked, the parameter <em>nameOfCheckboxField</em> with value &#8220;1&#8243; is posted to the PHP script. If the checkbox is not checked then the value of the hidden field is posted &#8211; and you don&#8217;t need any module at all.</p>
<p>Off course this might not be totally valid code. But in the backend I would not care about validation as much as about functionality.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.urbans-blog.de/2008/02/09/checkboxes-in-admin-interface-a-quick-dirty-trick/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Backend Extensions: additional fields</title>
		<link>http://www.urbans-blog.de/2008/02/09/backend-extensions-additional-fields/</link>
		<comments>http://www.urbans-blog.de/2008/02/09/backend-extensions-additional-fields/#comments</comments>
		<pubDate>Sat, 09 Feb 2008 18:48:41 +0000</pubDate>
		<dc:creator>urban</dc:creator>
				<category><![CDATA[OXID eShop]]></category>
		<category><![CDATA[admin]]></category>
		<category><![CDATA[extension]]></category>
		<category><![CDATA[new field]]></category>
		<category><![CDATA[views]]></category>

		<guid isPermaLink="false">http://www.urbans-blog.de/2008/02/09/backend-extensions-additional-fields/</guid>
		<description><![CDATA[From a developers view the reason why I like the Oxid eShop is, that quite a view things are very easy to customize. One of these things is adding your own fields to tables in the database and make them editable through the backend interface. Here is how to do it: Let&#8217;s say you want [...]]]></description>
			<content:encoded><![CDATA[<p>From a developers view the reason why I like the <a href="http://www.oxid-esales.com">Oxid eShop</a>  is, that quite a view things are very easy to customize. One of these things is adding your own fields to tables in the database and make them editable through the backend interface. Here is how to do it:</p>
<p>Let&#8217;s say you want to add a field <em>MY_FIELD </em>to the <em>oxarticles</em> table and want to put a new form field into the main article menue to edit the content of the new table field.</p>
<p>First of course add the field to the database using phpMyAdmin or whatever tool you use for your db-administration. Now look for the template which has to be extended for adding the form field.  If you don&#8217;t know how to find the right template, do the following:</p>
<p>Open the admin interface, open menue <em>Administer Products -&gt; Products</em> and klick on an article of the list at the top of the page. Now, if you move your mouse over the tabs <em>(Main, Extended, Inventory etc.)</em> have a look at the status bar at the bottom of your browser. There you will see something like this: <em>javascript:ChangeEditBar( &#8216;article_main&#8217;, 0);</em> &#8211; which shows you the name of the PHP-class &#8211; and file &#8211; which is called by clicking on that tab. The templates are named the same. So if you see <em>&#8216;article_main&#8217;</em> you cann be sure that a.) the used class is called <em>article_main.php</em> and the according template is called <em>article_main.tpl</em>  (I assume that the locations of admin view classes and templates is known).</p>
<p>Well, so open the template <em>article_main.tpl</em> with an editor. If your new field is a text-field, look for a similar field in the already existend code. For example you could take the searchkeys-field:<br />
<pre><pre lang="php">
&lt;tr&gt;
&lt;td class=&quot;edittext&quot;&gt;
[{ oxmultilang ident=&quot;ARTICLE_MAIN__OXARTICLES__OXSEARCHKEYS_RR&quot; }]&amp;nbsp;
&lt;/td&gt;
&lt;td class=&quot;edittext&quot;&gt;
&lt;input type=&quot;text&quot; class=&quot;editinput&quot; size=&quot;32&quot; 
&nbsp;&nbsp;maxlength=&quot;[{$edit-&gt;oxarticles__oxsearchkeys-&gt;fldmax_length}]&quot; 
&nbsp;&nbsp;name=&quot;editval[oxarticles__oxsearchkeys]&quot; 
&nbsp;&nbsp;value=&quot;[{$edit-&gt;oxarticles__oxsearchkeys-&gt;value}]&quot;&gt;
&lt;/td&gt;
&lt;/tr&gt;
</pre></pre><br />
(This is an example of the OXID EE code &#8211; PE is slightly different but the differences are obvious.)</p>
<p>So now just copy that table-row an paste it to the end of the table before the section with the submit button. Afterwards changed the used variables to the names of your table field:<br />
<pre><pre lang="php">
&lt;tr&gt;
&lt;td class=&quot;edittext&quot;&gt;
Title of my field
&lt;/td&gt;
&lt;td class=&quot;edittext&quot;&gt;
&lt;input type=&quot;text&quot; class=&quot;editinput&quot; size=&quot;32&quot; 
&nbsp;&nbsp;maxlength=&quot;[{$edit-&gt;oxarticles__my_field-&gt;fldmax_length}]&quot; 
&nbsp;&nbsp;name=&quot;editval[oxarticles__my_field]&quot; 
&nbsp;&nbsp;value=&quot;[{$edit-&gt;oxarticles__my_field-&gt;value}]&quot;&gt;
&lt;/td&gt;
&lt;/tr&gt;
</pre></pre><br />
Now you can fill out your new field and save the content to the database.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.urbans-blog.de/2008/02/09/backend-extensions-additional-fields/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
		<item>
		<title>My collection of oxid hints</title>
		<link>http://www.urbans-blog.de/2008/02/09/my-collection-of-oxid-hints/</link>
		<comments>http://www.urbans-blog.de/2008/02/09/my-collection-of-oxid-hints/#comments</comments>
		<pubDate>Sat, 09 Feb 2008 18:44:22 +0000</pubDate>
		<dc:creator>urban</dc:creator>
				<category><![CDATA[OXID eShop]]></category>
		<category><![CDATA[english]]></category>
		<category><![CDATA[hint]]></category>
		<category><![CDATA[tipps]]></category>
		<category><![CDATA[training]]></category>

		<guid isPermaLink="false">http://www.urbans-blog.de/2008/02/09/my-collection-of-oxid-hints/</guid>
		<description><![CDATA[Triggered by I a training I did some days ago I got the idea to build up a collection of hints and informations about customizing the oxid eshop software. Cause one of the participants of my training was australian I had to do it in english &#8211; and that again caused me to write my [...]]]></description>
			<content:encoded><![CDATA[<p>Triggered by I a training I did some days ago I got the idea to build up a collection of hints and informations about customizing the oxid eshop software. Cause one of the participants of my training was australian I had to do it in english &#8211; and that again caused me to write my oxid-stuff here in english, too, as there are not many oxid related ressources yet for developers around in englisch language. And german coders will certainly understand the english stuff too, I think.</p>
<p>I hope that might be helpful for some people.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.urbans-blog.de/2008/02/09/my-collection-of-oxid-hints/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

