[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Phpgroupware-developers] Templating system for phpGW
From: |
Dan Kuykendall |
Subject: |
[Phpgroupware-developers] Templating system for phpGW |
Date: |
Tue, 10 Sep 2002 11:43:08 -0700 |
User-agent: |
Mozilla/5.0 (Windows; U; Windows NT 5.0; en-US; rv:1.1) Gecko/20020826 |
As you know I have been working on an xslt solution for our templates
system. I am not all that concerned with what we use, so long as we stop
having apps do so much of the UI layer and move to a more robust
templating solution.
A little history on this:
I orignally looked at using XUL since that could have provided a way to
create a UI that can be converted to various platforms. But so far XUL
is only useful to mozilla and java developers, and there is no XUL to
HTML code out there... So XUL was out as a base template structure.
I then started learning XSLT for a project at work, and found that it
could do what we needed very well. I then wrote a templates class that
uses XSL for the templating. It works very well, but I then needed some
easy to use xml handling code. So I had to side track and write really
simple, yet powerful ones. That is where the xmltools.php I have sent
out came from.
I also have some challenges with XSL and phpGW in that it still doesnt
provide a common wiget set that should be used. I was starting to work
on this by creating a set of html wigets in a wiget.xsl that was basicly
a collection of named templates that took params. This could work well,
but ralfbecker came back into the picture because ceb talks to him and
she asked me about using his etemplates.
I had looked at ralf's etemplates awhile ago but I wasnt sure how well
it could work. I was concerned with the performance and the issue with
having to use his UI for creating all the forms.
I have attached the irc log from our conversation today and I am very
interested in using etemplates. Its a bummer for me because I have
potentially wasted alot of time writing my xsl template class, but my
interest is in getting phpGW to be as fantastic as possible.
Using etemplates over my xsltemplates has many advantages.
* It doesnt require XSLT support to be included in the PHP installs for
our users
* It will give all apps a consistant user interface.
* It will give us a single point at which we can control translations
since app developers wont have to manually use lang() themselves.
* It also makes use of CSS more controlled, since the etemplates will
handle adding the class="whatever" into the various html elements.
* It gives developers an interface for creating their app interfaces
using the etemplates editor.
etemplates also accomplish my original goal of seperation the UI
generation for the apps. Apps will just generate an array (or xml) of
their data and let the templates system handle the rest.
Im interested in everyones feedback about this issue. Whatever we decide
to use, will show up in the HEAD code pretty quickly and ceb, ralfbecker
(if etemplates is the soltuion) and I will start converting the API and
core apps to use it. Hopefully we will get other help, but those are the
ones I know of that are commited to jumping into this particular problem
and solving it.
We will still leave the old templates class in place for other apps to
cling to for awhile.
Seek3r
Sep 10 08:18:50 <ralfbecker> ceb: Hi, how is the work on the templates
proceding?
Sep 10 08:28:09 <Seek3r_> hey
Sep 10 08:28:33 <ceb> oh heya Seek3r_
Sep 10 08:28:36 --- You are now known as Seek3r
Sep 10 08:30:51 <neotexan> hello Seek3r
Sep 10 08:31:51 <Seek3r> hey neotexan
Sep 10 08:32:12 <neotexan> I've changed jobs...no more defense:)
Sep 10 08:32:47 <ralfbecker> Seek3r: hi
Sep 10 08:32:54 <ceb> Seek3r: i told ralfbecker about the current state of
the xml tpl class tests
Sep 10 08:33:45 <ceb> right now he described how his class works...
ralfbecker: could you repeat this please?
Sep 10 08:33:57 <ralfbecker> Seek3r: i would like to explain abit the
benefits of a widget-bases approach in comparison to plain XSL-transformation
Sep 10 08:34:01 <ceb> i mean the function calls
Sep 10 08:34:06 <ceb> :)
Sep 10 08:34:45 <ralfbecker> u mean how it works from an apps-programmers
side?
Sep 10 08:35:21 <ralfbecker> u create the classe and optional pass a
template name
Sep 10 08:36:10 <ralfbecker> the u call a function call exec and pass a
content-array (the data) plus a methode name, to be called with the returned
data of the form
Sep 10 08:36:57 <ralfbecker> with that approach the template class itself
can resend the form (eg. the change the tabs of a tab-widget) without
interaction of the app
Sep 10 08:37:20 <ralfbecker> from the app-side it gets called when the data
is ready to prceed
Sep 10 08:38:27 <ralfbecker> with that approach u can have widgets with own
programm-logic (like a tab-widget) which can work transparently for an app
Sep 10 08:39:08 <ralfbecker> eg. a template-designer could create a template
with tabs and it does not need any change of the app-code
Sep 10 08:39:59 <ralfbecker> a tab-widget is only one example what is
possible (and one which i already realized with the eTeamplates)
Sep 10 08:40:25 <ralfbecker> Seek3r: do u understand my point?
Sep 10 08:40:51 * fixe would like to announce the new AxisGroupware.Org
portal. Please take a moment to check it out. Thank You.
Sep 10 08:41:02 --> ____iggy_ (address@hidden) has joined #phpgroupware
Sep 10 08:44:59 ra3vat ralfbecker Sep 10 08:45:08 --> UltraSparc
(address@hidden) has joined #phpgroupware
Sep 10 08:45:09 <Seek3r> ralfbecker: sorry, had to walk away for a sec
to do something
Sep 10 08:45:11 <Seek3r> reading now
Sep 10 08:45:41 <-- UltraSparc has quit (Client Quit)
Sep 10 08:46:48 <Seek3r> ralf, yes I think I understand
Sep 10 08:47:16 <ralfbecker> i think for the transformation or both ideas
are very close
Sep 10 08:47:45 <ralfbecker> with transformation i mean getting html from xml
Sep 10 08:47:50 <Seek3r> right
Sep 10 08:48:23 <ralfbecker> the advantage of the etemplates is the
widget-concept and most of all the control-flow
Sep 10 08:48:24 <Seek3r> so with your stuff the app packages up its data
as xml or an array and passes it to etemplate
Sep 10 08:48:35 <ralfbecker> yep
Sep 10 08:48:49 <ralfbecker> the etemplate load the template (from the db,
for now)
Sep 10 08:48:59 <Seek3r> why from db?
Sep 10 08:49:10 <ralfbecker> and creates a first html-form out of the
template and the data
Sep 10 08:50:00 <ralfbecker> as it showed up templates contains other
templates, its quite fast to load it from the db
Sep 10 08:50:24 <ralfbecker> the distribution is done via files and works
with CVS too
Sep 10 08:50:37 <ralfbecker> but i think this is a minor detail
Sep 10 08:51:28 <ralfbecker> from the control-flow an app passed its data
and a call-back methode to the template-class (and of course a template-name)
Sep 10 08:52:15 <ralfbecker> the template-class generates an html-form (if
we are just talking html) and puts itself (the template-class) as the
receipient of the form
Sep 10 08:52:40 <ralfbecker> when the users send the form, control gets
passed back to the template-class and NOT to the app
Sep 10 08:52:46 <Seek3r> sure
Sep 10 08:53:00 <ralfbecker> the template-class or its extensions can do
some post processing
Sep 10 08:53:23 <ralfbecker> eg. build a time-stamp from 3-date-fields
Sep 10 08:54:01 <Seek3r> hmm. thats cool
Sep 10 08:54:11 <ralfbecker> after that post-processing, if none of the
widgets require further user-interaction the result-data (as array) gets passed
to to method of the app
Sep 10 08:54:35 <-- MAS (address@hidden) has left #phpgroupware ("Client
Exiting")
Sep 10 08:54:37 <ralfbecker> my first try of the template class was missing
that feature
Sep 10 08:54:51 <ralfbecker> but it turned out it makes things so much easier
Sep 10 08:55:19 <Seek3r> this actually works well in the n-tier
structure because its actually possible to have etemplates hit the app objects
the same way an xml-rpc/soap client would
Sep 10 08:55:28 <ralfbecker> specialy the widgets which are independent
classes and extend the eTemplates
Sep 10 08:55:54 <ralfbecker> yes
Sep 10 08:56:24 <ralfbecker> i can then replace the UI-layer with other
implementations of the etemplate-class
Sep 10 08:56:32 <Seek3r> is that an easy task?
Sep 10 08:56:43 <ralfbecker> i already have a working phpgtk-layer
Sep 10 08:56:55 <Seek3r> wait, before the gtk...
Sep 10 08:57:14 <ralfbecker> to replace the UI-layer?
Sep 10 08:57:17 <Seek3r> yes
Sep 10 08:57:37 <ralfbecker> it was done in 1-2 days
Sep 10 08:57:45 <ralfbecker> for gtk
Sep 10 08:58:14 <Seek3r> why does it have to be done by writing a new
class?
Sep 10 08:58:29 <Seek3r> why cant they just take the widgets templates
and edit them?
Sep 10 08:58:41 <ralfbecker> who?
Sep 10 08:59:07 <ralfbecker> u mean to extend the etemplate with an other
widget?
Sep 10 08:59:33 <ralfbecker> u can just edit an etemplate to create an other
look, of course
Sep 10 09:00:00 <ralfbecker> the widget sometimes contain own program-logic,
let me give you an example
Sep 10 09:00:04 <Seek3r> I mean to create a new set of what the wigets
look like
Sep 10 09:00:12 <Seek3r> the html behind the widget object
Sep 10 09:00:18 <ralfbecker> that is just editiong of the templates
Sep 10 09:00:43 <ralfbecker> no difference to your or the actual
template-concept
Sep 10 09:01:15 <ralfbecker> the difference start if you want a new widget
Sep 10 09:01:24 <Seek3r> ok, I see that
Sep 10 09:01:32 <ralfbecker> the etemplates-class know several widget-types
Sep 10 09:01:43 <ralfbecker> basicly all of html and some more
Sep 10 09:02:06 <Seek3r> hmm... kinda works well with the new 5 part
interface I put into the HEAD code... each of those can be the initial wigets
Sep 10 09:02:15 <ralfbecker> to enable an app-programer to extend the
etemplates without touching the class
Sep 10 09:02:41 <ralfbecker> i created an extension-interface
Sep 10 09:03:08 <Seek3r> hows that work?
Sep 10 09:03:15 <ralfbecker> that keeps the class itself small and everone
can extend it via a documented interface
Sep 10 09:03:35 <Seek3r> they have an eTemplates extends class in their
app area?
Sep 10 09:04:05 <ralfbecker> the can have own eTemplates-extensions /
widgets in theire app-dir
Sep 10 09:04:20 <Seek3r> ok
Sep 10 09:04:32 <Seek3r> sounds all very nice
Sep 10 09:04:40 <Seek3r> now about the gtk interface
Sep 10 09:04:49 <ralfbecker> if you decide a widget is worth putting in the
api (or for now the etemplates-dir) you can put it there for all apps too
Sep 10 09:04:50 <Seek3r> I heard you used XUL for that
Sep 10 09:04:56 <ralfbecker> no
Sep 10 09:05:13 <ralfbecker> XUL is an other idea for a UI-layer
Sep 10 09:05:23 <ralfbecker> gtk used php-gtk
Sep 10 09:05:30 <Seek3r> oh ok. Then lets ignore XUL for now
Sep 10 09:06:01 <ralfbecker> instead of creating html from the template it
creates a dialog with the necessary widgets
Sep 10 09:06:29 <Seek3r> ok, next question
Sep 10 09:06:35 <ralfbecker> if the extensions are programmed as eTemplate
plus code it can be used by each UI-layer
Sep 10 09:06:38 <Seek3r> what format are your templates in?
Sep 10 09:06:39 <ralfbecker> k
Sep 10 09:06:55 <ralfbecker> at the moment the templates are arrays
Sep 10 09:07:22 <Seek3r> you store it seralized into the db?
Sep 10 09:07:44 <ralfbecker> for now yes, i was thinking about xml ...
Sep 10 09:07:54 <ralfbecker> there was just no need
Sep 10 09:08:17 <Seek3r> hmmm... but this means the actual html tags are
in the eTemplates class?
Sep 10 09:08:21 <ralfbecker> i can programm an xml-interface which would
allow programmers to write the templates with an editor
Sep 10 09:08:30 <ralfbecker> no
Sep 10 09:08:47 <ralfbecker> the etemplate-class uses the html-class to
generate html-tags
Sep 10 09:09:13 <Seek3r> the html class?
Sep 10 09:09:30 <ralfbecker> the extemplates can have css-class-name and use
css to customice it
Sep 10 09:09:56 <ralfbecker> the html-class helps u to get arround the pain
of putting html in php
Sep 10 09:09:59 <Seek3r> the html class is a class with functions for
all the various html elements?
Sep 10 09:10:06 <ralfbecker> yes
Sep 10 09:10:23 <ralfbecker> i use it in all my apps an other programmers us
it too
Sep 10 09:10:36 <Seek3r> so the eTemplates class doesnt actually
generate any html itself?
Sep 10 09:10:41 <ralfbecker> there are 3-4 versions in phpgw at the moment
as it is not in the api
Sep 10 09:10:46 <ralfbecker> no
Sep 10 09:11:08 <Seek3r> yeah, I was starting to work on an html class
for the api
Sep 10 09:11:18 <ralfbecker> the html-class generates a table to organice
the widgets
Sep 10 09:11:20 <Seek3r> one that used out templates system for the
actual html
Sep 10 09:11:30 <Seek3r> out = our
Sep 10 09:12:19 <ralfbecker> eg. an text-input-field widget calls the
html->input function to generate the actual html
Sep 10 09:12:51 <ralfbecker> but again we are very much into detail, details
which the template class hides from the apps
Sep 10 09:13:10 <Seek3r> I understand hiding it from the app
developers... but I want to know the details :-)
Sep 10 09:13:22 <ralfbecker> of course
Sep 10 09:13:54 <ralfbecker> i just mean, i dont care about changing
implementation details in the template-class
Sep 10 09:13:56 <Seek3r> so the html class allows the etemplate class to
set all the various atributes of each html element?
Sep 10 09:14:17 <ralfbecker> to a certain extend yes
Sep 10 09:15:01 <ralfbecker> the etemplates control only basic aspects of
the html-options, the rest is doen at the moment via css
Sep 10 09:15:20 <Seek3r> ahh. ok, thats fine
Sep 10 09:15:22 <ralfbecker> lets say you can set the width of a text-field
in an etemplate
Sep 10 09:15:40 <ralfbecker> but you cant sets its color, this has to be
done via css
Sep 10 09:15:50 <Seek3r> thats fine
Sep 10 09:16:16 <ralfbecker> one reason for the etemplates was to help
geting a similar look-and-feel for all apps using it
Sep 10 09:16:35 <ralfbecker> that is best to archive via a shared css
Sep 10 09:17:30 <Seek3r> yeah, the api would have a collection of
choices in css files... and then apps can add their own ones as well
Sep 10 09:17:58 <ralfbecker> i think the strengs of the eTemplates concept
is the program logic, the extensebility and for a novice programmer or designer
the eTemplate-editor
Sep 10 09:18:45 <ralfbecker> there is more work needed in actualy creating a
shared set of widget and rendering it
Sep 10 09:19:05 <Seek3r> I think its pretty clever. I remember when I
looked at it many moons ago, the problem I had with it was that it wasnt really
possible to create an interface without using your eTemplate-Editor
Sep 10 09:19:14 <Seek3r> have you changed that at all?
Sep 10 09:19:45 <ralfbecker> not yet, i will do it very quick if someone
else considers using it
Sep 10 09:19:58 <Seek3r> how would you make it possible?
Sep 10 09:20:32 <Seek3r> oh, and by someone else, would the phpgwAPI and
core apps count as "someone else"?
Sep 10 09:20:32 <ralfbecker> i would read the etemplate from an xml-file
instead of an array
Sep 10 09:20:42 <ralfbecker> for shure
Sep 10 09:20:44 <ralfbecker> ;-)
Sep 10 09:21:02 <Seek3r> ceb: what do you think about this... youve been
pretty quiet
Sep 10 09:21:30 ra3vat ralfbecker Sep 10 09:21:40 <ceb> yes because i was
talking with ralfbecker already
Sep 10 09:22:31 <ceb> i like it , but i also would like to use an own editor
and not the current etemplate interface
Sep 10 09:22:54 <Seek3r> ralfbecker: I would also think we should setup
the ability to use files instead of the db for the etemplates widget
definitions... I would want to use the files for what we store in cvs, and then
like the translation system, we can have a way to import this into the db
Sep 10 09:23:37 <ralfbecker> i can do the import from xml within days
Sep 10 09:23:42 ra3vat ralfbecker Sep 10 09:23:51 <ralfbecker> did i talked
about the translation?
Sep 10 09:23:56 <Seek3r> ralfbecker: ok. I should also send you my
xmltools.php file
Sep 10 09:24:05 <Seek3r> ralfbecker: no you didnt
Sep 10 09:24:47 <ralfbecker> the etemplates can contain text, this texts
gets automatically run throug the lang-function
Sep 10 09:25:05 <Seek3r> ceb: yes, thats the only limitation that
bothers me. The other is performance. I think performnce should be ok if the
code is written well... but it is another layer that has the potential to slow
things down
Sep 10 09:25:14 ra3vat ralfbecker Sep 10 09:25:16 <ralfbecker> if you use the
editor to create the etemplate, it adds the new phrases to the lang-files
Sep 10 09:25:22 <Seek3r> ralfbecker: ok, cool... a central control to
that
Sep 10 09:26:02 ra3vat ralfbecker Sep 10 09:26:04 <ceb> and btw a small issue
about the css: i dont think the apps should have their own css files also
Sep 10 09:26:07 <ralfbecker> u can set an option if you dont want to use a
lang-call
Sep 10 09:26:29 <Seek3r> ceb: why not?
Sep 10 09:26:37 <ceb> and the performance gets worse if it works like the
current way to have the apps creating all their own tpl objects...
Sep 10 09:27:02 <Seek3r> ceb: the css files shouldnt be like that
Sep 10 09:27:10 <ceb> the css files would help to have a uniform look and
feel for all apps
Sep 10 09:27:22 <ralfbecker> thats my opionion too
Sep 10 09:27:30 <ceb> kind of the themes right now
Sep 10 09:28:11 <ceb> if we again would have the apps decide about how they
look all would stay like it is
Sep 10 09:28:30 <Seek3r> ceb/ralf: wouldnt the apps need css classes for
their custom wigets (via the extends thing)
Sep 10 09:28:35 <ceb> the look of the ui should be uniform
Sep 10 09:28:43 <ceb> nop
Sep 10 09:29:18 <ceb> we should code it that way the choosen 'theme' decides
about the look
Sep 10 09:29:20 <ralfbecker> for the extensions / new widgets they would, i
would suggest to create a bigger pool of phpgw-standard widgets
Sep 10 09:30:12 <ralfbecker> i would say noone should create its own
date-entry-widgets as this is against a common look and feel
Sep 10 09:30:13 <Seek3r> ralfbecker: yes, they will for the
extentions... but if the standard widget set is complete enough, then that will
be used very little
Sep 10 09:30:26 <ralfbecker> yes
Sep 10 09:30:36 <ceb> ok i have to run, sorry
Sep 10 09:30:41 <ceb> bb in two hours
Sep 10 09:30:41 <Seek3r> ceb: ok.
Sep 10 09:30:46 <ceb> shower time...
Sep 10 09:30:48 <Seek3r> this is some serious re-designing of things
Sep 10 09:30:59 <ralfbecker> i think so
Sep 10 09:31:08 <Seek3r> not as simple as switching to xsl instead of
tpl for the templates system
Sep 10 09:31:24 <ralfbecker> thats why i asked ceb about rethinking it
Sep 10 09:31:43 <ralfbecker> no its alot about the programm-logic too
Sep 10 09:31:55 <ralfbecker> how can we proceed now
Sep 10 09:32:13 <ralfbecker> i can look into writing the etemplates via
xml-files
Sep 10 09:32:35 <Seek3r> give my xmltools.php file a look at
Sep 10 09:32:37 <ralfbecker> if your xml-tools can help to translate xml to
an array it would be helpful
Sep 10 09:32:45 <ralfbecker> is it in the api
Sep 10 09:33:09 <Seek3r> its can be used to convert any var (including
arrays and class objects) into xml and then back
Sep 10 09:33:34 <Seek3r> I will email it to you. I havent put it into
the api yet, since I need to find a good point to where it will be loaded up.
Sep 10 09:33:45 <ralfbecker> ok
Sep 10 09:33:53 <Seek3r> it breaks convention with the normal api format
of having a single class in a file
Sep 10 09:34:25 <Seek3r> I do that because it uses multiple classes to
generate a single xml document
Sep 10 09:34:32 <ralfbecker> if you want to see the extensions working, you
can have a look at my tab-widget-demo
Sep 10 09:35:10 <Seek3r> where is all your code? do you have any app
using it yet?
Sep 10 09:35:32 <ralfbecker> the code is in the etemplates app
Sep 10 09:35:51 <ralfbecker> the etemplates app is using the etemplates-class
Sep 10 09:36:05 <ralfbecker> with etemplates-app i mean the editor and the
db-tools
Sep 10 09:36:38 <ralfbecker> at the moment im porting infolog to etemplates
and i have a other app running with the etemplates
Sep 10 09:36:50 <ralfbecker> that other app is not in the cvs
Sep 10 09:37:31 <ralfbecker> the etemplate-editor is a complex application
using the etemplate-system itself
Sep 10 09:37:56 <ralfbecker> if you want i can show u around, i only need to
power-up my development-system
Sep 10 09:38:15 <ralfbecker> at the moment i'm in the office at a windows box
Sep 10 09:39:47 <ralfbecker> Seek3r: could you mail me the xmltools-class so
i can have a look if i can use it to read the etemplates from xml
Sep 10 09:43:38 <Seek3r> whats your email address?
Sep 10 09:44:25 <ralfbecker> address@hidden
Sep 10 09:44:57 <ralfbecker> Seek3r: want me to show u the extensions, like
the tab-widget
Sep 10 09:49:36 <Seek3r> sure
Sep 10 09:49:51 * Seek3r is fixing up the example of how to use his
xmltools
Sep 10 09:50:38 <ralfbecker> lets say in half an hour, could you
checkout/update the etemplates-app on your box
Sep 10 09:51:29 <Seek3r> Im ready now... just cleaning up the example a
bit
Sep 10 09:52:02 <ralfbecker> i need to get to my development-system
Sep 10 09:52:26 <ralfbecker> i'm not developing under windows
Sep 10 09:52:46 <ralfbecker> i be back in a fiew minutes, ok?
Sep 10 09:53:11 --> Zone (address@hidden) has joined #phpgroupware
Sep 10 09:56:45 <Seek3r> o
Sep 10 09:56:46 <Seek3r> ok
Sep 10 10:01:08 <-- ralfbecker has quit ("ChatZilla 0.8.7 [Mozilla
rv:1.0.0/20020530]")
Sep 10 10:03:48 <-- ____iggy_ has quit ("BitchX-1.0c19 -- just do it.")
Sep 10 10:18:19 --> ralfbecker (address@hidden) has joined #phpgroupware
Sep 10 10:20:35 <ralfbecker> Seek3r: should we start?
Sep 10 10:34:11 <Seek3r> was just playing with my xmltools. I merged
xmldoc and xmlnode into a single xmldoc class
Sep 10 10:34:55 <ralfbecker> k, i'm adding a button to the editor to export
a loaded eTemplate as xml-file
Sep 10 10:35:31 <ralfbecker> Seek3r: if you want i can show u the
tab-widget-extension
Sep 10 10:37:44 <Seek3r> ok
Sep 10 10:37:56 <Seek3r> did you find my xmltools easy to use?
Sep 10 10:38:09 <ralfbecker> looks like
Sep 10 10:38:20 <ralfbecker> it is exactly what i need
Sep 10 10:38:41 <Seek3r> cool
Sep 10 10:38:54 <ralfbecker> i'm just thinking about where to store the
etemplates (for performance reasons)
Sep 10 10:39:48 <ralfbecker> as complex etemplates, like the editor,
sometimes consist out of 10 nested templates, i'm not shure how good it works
from a file
Sep 10 10:40:07 <ralfbecker> but one step after the other
Sep 10 10:40:17 <ralfbecker> load the etemplate-app
Sep 10 10:40:35 <ralfbecker> and type '%test' in the Name-field and hit Read
Sep 10 10:40:46 <Seek3r> wait... where should I load this?
Sep 10 10:40:58 <Seek3r> do a cvs checkout?
Sep 10 10:41:05 <ralfbecker> do you have the etemplates app installed?
Sep 10 10:41:19 <ralfbecker> if not checkout etemplates from HEAD
Sep 10 10:41:19 <Seek3r> nope
Sep 10 10:41:43 <Seek3r> whats the module name?
Sep 10 10:41:49 <ralfbecker> it should work in HEAD or 0.9.14
Sep 10 10:41:51 <ralfbecker> etemplate
Sep 10 10:42:06 <Seek3r> grabbing it now
Sep 10 10:42:10 <ralfbecker> k
Sep 10 10:42:30 <Seek3r> I also just sent my new xmltools to the dev
list. The new version has the single xmldoc class
Sep 10 10:43:02 <ralfbecker> so i can load it via CreateObject
Sep 10 10:43:11 <Seek3r> not yet.... but that will be possible soon
Sep 10 10:43:29 <Seek3r> right now that class is in the xmltools file
with the other functions
Sep 10 10:43:44 <Seek3r> I will switch that to its own file so it can be
used with CreateObject()
Sep 10 10:43:53 <ralfbecker> btw. i would like to add a function LoadObject
that just loads a class (or does nothing if the class is already loaded)
Sep 10 10:44:27 <Seek3r> CreateObject() already does that
Sep 10 10:44:32 <ralfbecker> i use the code of the function to ensure a
class is loaded to extend it
Sep 10 10:44:34 <Seek3r> hmm... maybe not
Sep 10 10:44:52 <ralfbecker> but that gives me an object i dont need
Sep 10 10:45:09 <Seek3r> also, since we are dropping PHP3 support I will
probably change it to use include_once() instead of our custom solution
Sep 10 10:45:14 <ralfbecker> LoadObject is identicat to CreateObject without
creating it
Sep 10 10:45:34 <ralfbecker> without php3-support thats no longer a problem
Sep 10 10:45:47 <ralfbecker> i just dont want to use include_once
Sep 10 10:46:31 <Seek3r> right, app developers wont use include_once(),
only the api will use it
Sep 10 10:46:35 <ralfbecker> i like the CreateObject or ExecMethod
Sep 10 10:47:12 <ralfbecker> with the etemplates i only use methode-name no
links as the cant work in gtk
Sep 10 10:47:15 <Seek3r> oh, I also found a way to seriously improve the
performance of ExecMethod()
Sep 10 10:47:26 <ralfbecker> how?
Sep 10 10:48:38 <Seek3r> http://www.php.net/manual/en/ref.funchand.php
Sep 10 10:48:54 <Seek3r> by using call_user_func() instead of using
exec()
Sep 10 10:49:10 <Seek3r> exec() is very slow, but this call_user_func()
is fine with performance
Sep 10 10:50:20 <Seek3r> so by using many of the stuff in this page, I
am re-writing CreateObject() and Execmethod() so that they can perform better
and be more flexible.
Sep 10 10:51:00 <ralfbecker> i thought u just use something like
list($app,$class,$method) = explode('.',$string); $$method()
Sep 10 10:51:37 <ralfbecker> did you installed the etemplates app?
Sep 10 10:52:58 <Seek3r> yep
Sep 10 10:53:33 <ralfbecker> call it to show the editor
Sep 10 10:53:43 <Seek3r> but, Im running out of time... so we gotta
hurry :-)
Sep 10 10:53:48 <ralfbecker> then type '%test' in the name field
Sep 10 10:53:48 <Seek3r> I see the editor
Sep 10 10:53:58 <Seek3r> ok
Sep 10 10:54:15 <ralfbecker> click on edit behind etemplate.tab_widget.test
Sep 10 10:54:50 <ralfbecker> you can see the tab-widget in the 2. row
Sep 10 10:54:55 <ralfbecker> if u click on show
Sep 10 10:55:07 <ralfbecker> u can see it in action
Sep 10 10:55:11 <Seek3r> I dont see what your talking about
Sep 10 10:55:38 <ralfbecker> if you type '%test' in Name and hit Read
Sep 10 10:55:54 <ralfbecker> it shows a list of templates matching that
wildcard
Sep 10 10:56:31 <Seek3r> Warning: stat failed for
/home/phpgroupware/http/devteam/%test/setup/etemplates.inc.php (errno=2 - No
such file or directory) in
/home/phpgroupware/http/devteam/etemplate/inc/class.soetemplate.inc.php on line
639
Sep 10 10:56:32 <ralfbecker> click on edit in the line:
etemplate.tab_widget.test
Sep 10 10:56:35 <Seek3r> but it shows the list
Sep 10 10:57:04 <Seek3r> ok I see the details of the widget
Sep 10 10:57:20 <ralfbecker> i tries to load the distribution file for the
app '%test' ;-)
Sep 10 10:57:43 <ralfbecker> the widget itself has labels separates by |
Sep 10 10:58:03 <ralfbecker> and several etemplate-names separated by | too
Sep 10 10:58:09 <Seek3r> I see
Sep 10 10:58:15 <ralfbecker> click on show to see the template loaded
Sep 10 10:58:18 <Seek3r> and I see what happens when I click show
Sep 10 10:58:21 <Seek3r> neat
Sep 10 10:58:24 <ralfbecker> k
Sep 10 10:58:29 <Seek3r> this will take some getting use to
Sep 10 10:58:36 <ralfbecker> from an apps point of view
Sep 10 10:58:48 <ralfbecker> the chaning between the tabs is invisible
Sep 10 10:58:59 <ralfbecker> the reload is done within the etemplate-class
Sep 10 10:59:02 <Seek3r> yeah
Sep 10 10:59:29 <Seek3r> how do I see whats in each of the tabs?
Sep 10 10:59:31 <ralfbecker> so if this is the addressbook, a different
template-set could use different tabs with an unchanged app
Sep 10 10:59:50 <ralfbecker> u need to load the etemplate of each tab
Sep 10 10:59:51 <Seek3r> nevermind, I found it
Sep 10 10:59:58 <ralfbecker> go back to the editor
Sep 10 11:00:31 <ralfbecker> an to to etemplate.tab_widget.test.work for
example
Sep 10 11:00:43 <Seek3r> yeah
Sep 10 11:01:09 <ralfbecker> the tab-widget is not part of the
etemplate-class its a self-contained extension
Sep 10 11:01:28 <ralfbecker> but the editor autoloads each extension and
show it
Sep 10 11:01:55 <Seek3r> might as well add it to the etemplate class
Sep 10 11:02:00 <Seek3r> but I see your point
Sep 10 11:02:09 <ralfbecker> i could
Sep 10 11:02:41 <ralfbecker> if you want to see the implementation of a
simple extension look at date_field
Sep 10 11:03:03 <ralfbecker> this widget-example allows to enter a date in
3-text-fields
Sep 10 11:03:39 <ralfbecker> it takes the content in a variable format
(specified eg as Y-m-d) and puts it in 3 fields
Sep 10 11:04:02 <ralfbecker> its in the class.datefield_widget.inc.php
Sep 10 11:04:13 <ralfbecker> its a short and basic example
Sep 10 11:05:23 <Seek3r> this is gonna take more than a couple mins
Sep 10 11:05:30 <Seek3r> but now that I have it installed I can fiddle
with it
Sep 10 11:05:42 <Seek3r> do you think you could convert the notes app to
use it?
Sep 10 11:05:47 <ralfbecker> k, i'm going to add the xml-stuff
Sep 10 11:05:49 <Seek3r> that would be a great example
Sep 10 11:06:07 <ralfbecker> i think so
Sep 10 11:06:22 <ralfbecker> i personal would use infolog ;-)
Sep 10 11:06:38 <Seek3r> notes is super simple and easier to grasp
Sep 10 11:06:56 <Seek3r> it would be a good example for everyone to
start with in looking at it
Sep 10 11:07:09 <ralfbecker> the first step to convert notes or infolog, is
to create a nextmatch widget, i'm working on that
Sep 10 11:07:11 <Seek3r> I then need to make the API use it for the
overall interface
Sep 10 11:07:27 <ralfbecker> there is a tutorial with an example-app
Sep 10 11:07:43 <ralfbecker> its in the doc-dir of etemplate
Sep 10 11:07:59 <ralfbecker> its at the same level like notes
Sep 10 11:08:18 <ralfbecker>
http://www.phpgroupware.org/devdemo/etemplate/doc/etemplate.html
Sep 10 11:08:24 <Seek3r> ok
Sep 10 11:08:42 <Seek3r> I will go thru that tonight or tomorrow night
Sep 10 11:08:59 <ralfbecker> k, i will be here on irc
Sep 10 11:09:30 --> kheb (address@hidden) has joined #phpgroupware
Sep 10 11:09:45 <Seek3r> this looks like something we could use... it
would certainly give us a more common look and feel thru all the apps, as well
as a more controllable translation environment
Sep 10 11:10:51 <Seek3r> we will need to get feedback from skeeter
before we start making any final moves tho
Sep 10 11:11:47 <ralfbecker> k
- [Phpgroupware-developers] Templating system for phpGW,
Dan Kuykendall <=