The Administration Interface Project

Author Message

Alex Jones

Friday 16 April 2004 11:36:33 am

Balazs, it's been a while since anyone from eZ systems posted to this thread. Perhaps now might be a good time to summarize and update us on the direction of the Administration Interface Project..?

Thanks,

Alex

Alex
[ bald_technologist on the IRC channel (irc.freenode.net): #eZpublish ]

<i>When in doubt, clear the cache.</i>

Thomas Nunninger

Friday 16 April 2004 9:09:51 pm

If you want to deploy an eZ publish system for your customer, he perhaps wants to have a quick reference or context sensitve help (at least ours wants one :) Perhaps this would be an idea for this project. A quick and dirty hack could be to link to the tutorial in the documentation...

Have a nice day

Thomas

Mark Marsiglio

Saturday 17 April 2004 6:17:23 pm

As the person responsible for setting up content classes in most of my eZ installations, I think it would be great to be able to offer end user conten administrators some clues as to what each datatype (field) is intended to be used for when they are adding content. This could be accomplished with something similar to the <acronym> tag in HTML. When they mouse over the name of the field, it would offer a tip about what text/info should be entered there.

Alternately, a "?" help icon next to the datatype name could lead to some clues about where the content will be used, and how. This would eliminate much of the training that is required for a custom site built on the eZ framework.

http://www.thinkcreative.com
Turning Ideas Into Strategic Solutions

Tony Wood

Sunday 18 April 2004 2:20:21 am

I think one of the issues most people have when using the current interface is one of contect. Everyone is used (whether it be the best way or not) to the MS file manager approach of content. Folders and files in a tree list. This does not have to be the only way. We need to think about how content should be grouped to enable people to find what they need and once found work with the cotnent. For this reason the one of the first steps is to define user interface guidelines for how content should be reprsented. i.e. http://developer.gnome.org/projects/gup/
Now there is no reason to start from scratch there are many project out their we can gain input from. What we already have in the admin project is a resprensatation of many peoples thoughts. I am saying we should accept this and not reinvent the wheel.

In my experience when you ask people to organise content they immediately go to the tree list (file/folder) way of organising content. After all its what they know. But this does not scale. Folder structures do not work for large amounts of information. We can see this by using Google.; does it use tree anf folders? The question then is about content and the finding of that content in my mind is the most important if we are to have a more attractive enterprise solution. The current format works for small sites, but for large, well you can get lost very quickly and finding the page you want to edit can take longewr than the edit itself. I have spent many an hour training people to use eZ and the biggest step is trying to match the front end view (thw web site) with the admin view (tree list). I feel it is much better to have an edit bar that appears in the main site so when you are an editor so you can choose to edit a page when you browse to it. After all most of the changes come from people viewing the site. So when they tell you about it they send you a lin to the page wouldn't it be quicker just to click and edit this? (I remeber a contrib for the beginning of this a while back, but a tool bar would be better)
This does not stop us from having an admin view. This is important too as we need a way for developers to organise content in a logical view. But thats what it is; a logical view. This is not a view that is inituative for the editor. Sure, they will learn how to use the interface, but don;t we want something quick and easy to use without people having to learn the interace in depth? People want to change content, not learn eZ publish.

So the first step I feel should be to take a step back and look at the current usabilty problems with the current admin interface and catalogue them. Then we discuss way that people have already found to workaround these problems. Lets learn together from our experiences. Once we have this information we can feed this into the administration interface project to help it plan to solve these problems. If we do not learn from history, then I feel we will have a nice shiny admin interface with all the same problems. Granted most of the comments in this thread are about experience, I say we should formalise the process not just have a thread. This should be a forum with a thread for each area of the administration.

(in no particular order)
*visual editing
*translations
*related objects
*finding content
*permissions
*client APIs
*performance issues (cache etc)
*branding user interfance
*usability
* etc

For the problmes with the admin interface i'll start this off with a couple of issues I have had:
* editing preview
* knowing if a folder has children or not
* root node (each use should have their own root node for displaying content in the admin
* editing from the front end view
* contect sensitive options (class choice, editing etc)
* basic / advnaced eidting view (remove crud when editor don't need to see it)
* publish/unpublished content (quick remove but "not" delete)

tony

--
http://www.visionwt.com

Tony Wood : twitter.com/tonywood
Vision with Technology
Experts in eZ Publish consulting & development

Power to the Editor!

Free eZ Training : http://www.VisionWT.com/training
eZ Future Podcast : http://www.VisionWT.com/eZ-Future

Paul K Egell-Johnsen

Wednesday 28 April 2004 9:46:22 pm

Help files as you suggest is a good idea for those of us who care to learn more, often though, as can be judged by any support forum on the net, people don't use the documentation, nor even the search engine...

They all crave personal attention by a mentor.

--
http://www.vogol.com/user/spdyvkng/blog/

Paul K Egell-Johnsen

Wednesday 28 April 2004 9:49:37 pm

I suggest using the same method as in some parts of eZ publish 2, where each object gets a drop down of categories to select where to move them; if some kind of profiles are implemented (as pr another suggestion in this thread by Huib Kleinhout, I think) then each profile could probably restrict the areas one role might move content to.

--
http://www.vogol.com/user/spdyvkng/blog/

Huib Kleinhout

Friday 30 April 2004 11:22:41 am

Tony Wood rightfully addresses the need to take a step back and look at the fundamental issues of the administration interface. Ideally, usability engineering is tightly integrated in the development process of a product. Mainly because the the technical design of a product will depend on the user interface design and vice versa. At this time there already is a fully functional system, and now the administration interface is to be redesigned. This redesign is really needed and it think it's a good idea, but remember a proper redesign might also require painful architectural changes in the underlying system.
Because of the lack of responses on the previous discussions about the new admin interface, Balazs Halasy did a good thing to just publish a concrete proposal. At least there is some discussion right now. However, if we take a step back there are several fundamental questions to be answered first, before an actual design should be created. Some of these questions are:
What is the purpose of the interface? - Why does ez-publish need an administration interface?
Who are the users? - What are their characteristics (skills, roles, numbers etc.) and why should they use the interface?
What kind of tasks are the users going to perform? - What steps need to be taken to complete a task?
What kind of scenarios are possible to happen?
Which interface requirements can be formulated?
Which lessons can be learned from experiences with the previous interface? (As Tony Wood also noted)
Only by answering such questions first, you can be sure you know exactly what you're doing when you're actually designing and writing xhtml code. And therefor, I think the discussion should be on this kind of level first. We shouldn't discuss now whether the radio buttons next to the search field are useful or not. Later on in the process however, we should discuss about whether the related 'search' scenario fits the interface goals, targeted user group and requirements.
Just starting to put buttons, texts and boxes on a page is as structured as starting to code a software program without creating a single flowchart or uml-diagram in advance. Maybe Balazs Halasy and his colleagues already went trough a more or less extensive usability design process. If true, it would be useful if they published some of the documents or a summary of the underlying design. It would certainly take this discussion to a higher level and I would be happy to contribute!

Cheers,
Huib Kleinhout

Huib Kleinhout

Friday 30 April 2004 12:09:25 pm

<i> >Folder structures do not work for large amounts of information. We can see this by using Google.; does it use tree anf folders?</i> (Tony Wood)
I'm not sure whether this it is fair to compare the whole Internet to a single website. Ultimately, one or more admins should have some control over the structure of their website. In my opinion you're not very much of a good administrator if you can't create a proper information structure.
<i> >I have spent many an hour training people to use eZ and the biggest step is trying to match the front end view (thw web site) with the admin view (tree list).</i>
This is not a problem of 'unscalability' but a lack of transparency (between the content view and edit)!
<i> >I feel it is much better to have an edit bar that appears in the main site so when you are an editor so you can choose to edit a page when you browse to it.</i>
This is a very interesting suggestion as it would certainly ease the editing process. I know some cms systems already implemented this, it might be interesting to take a look at these. Certainly such an interface would also introduce new transparency problems, because you effectively have two interfaces. Furthermore, in some situations users should be aware of the underlying technical structure or else they might end up having a ms frontpage quality website. Though I think something like Tony's editing bar will probably be very much appreciated by content editors, because the content does not need to be search for in a complex administration interface.

Tony Wood

Saturday 01 May 2004 1:48:16 am

Huib,

<i>I'm not sure whether this it is fair to compare the whole Internet to a single website. Ultimately, one or more admins should have some control over the structure of their website. In my opinion you're not very much of a good administrator if you can't create a proper information structure.</i> (Huib Kleinhout)

I agree, the point was a stretch. I should clarify; the directory structure does work for small/medium amounts of classifiable information. The problem comes when large (1000s) of pieces of information are required. An example of this type of information would be the BBC site http://news.bbc.co.uk/.
I agree again that a good administrator can logically classify information for storage and update purposes. But the real strength of information should be that it can be viewed in the way the "user" chooses not in the easiest storage method. This means that information needs to exist in many locations. So maybe we should classify what folders are; search crtieria based on a category. If we change folders so they can also become searchs. We will then have a more powerful system that enables us to have many pieces of informaiton in many locations without the "location-grind" of adding loads of locations to our articles.

Thoughts?

--tony

Tony Wood : twitter.com/tonywood
Vision with Technology
Experts in eZ Publish consulting & development

Power to the Editor!

Free eZ Training : http://www.VisionWT.com/training
eZ Future Podcast : http://www.VisionWT.com/eZ-Future

Alex Jones

Monday 03 May 2004 7:57:11 am

Tony, your point makes a lot of sense. Ultimately, the sites I work on (retail) require many methods to locate and/or display a product or information. My first eZ publish site makes extensive use of folders for categorization. Over the last year I have learned a lot from the forums, studying large retail sites, and in-depth discussions with other developers (notably you and Paul F.) which have shifted my thinking as to site structure. I have come around to the conclusion that folders do not work for our large product offering. What we really need is a series of filters, or filtered searches, best achieved via a common set of keywords. The developer and the editors will need to work off of a common set of assumptions to create a general information architecture, but ultimately the detailed view of that architecture will be defined by the editors responsible for adding content, and in many instances the customers locating that content. Utilizing a keyword approach provides the user much more flexibility in locating what they seek, while providing the site owners the opportunity to craft pre-defined groupings or categories. This concept works just as well for press releases as it does for products.

Dropping the reliance on Locations will speed development and content creation many-fold (in our case at least) in addition to providing the previously discussed flexibility. Obviously I like this direction a lot, which makes me a bit nervous that I am missing something. ;) I would love to see others on the boards poke holes in the theory as I will be redesigning another sizable retail site in a couple of months and plan to put this concept into practice.

Alex

Alex
[ bald_technologist on the IRC channel (irc.freenode.net): #eZpublish ]

<i>When in doubt, clear the cache.</i>

Paul K Egell-Johnsen

Tuesday 04 May 2004 12:33:10 am

I must admit I'm not entirely certain how the search on eZ publish works, I tried it just now and "eZ publish" didn't return anything, but "pkej" and "eZTrade" did, unfortunately I don't have a very large eZ publish site with a wide variety of content to test it on, but I'll try to explain what is needed.

Searches are the quickest way to find info on a site. How the search assists you in this is alfa and omega. As this thread has been suggesting filters and searches, I thought I'd just point out how a search <i>could</i> work.

The main idea is to give the top ranked content, and exact matches. If I search for an author (of a book for sale, for example at Amazon) it would be efficient if the search engine placed the author result very high up, especially when it is an exact match. Imdb ( http://imdb.com ) is a site where this is excellently implemented. Amazon ( http://www.amazon.com ) seems to have the same functionality, but in a much more cluttered interface.

Folders aren't entirely a waste, it all depends on how the user perceives the site. For example, Amazon uses a hierarchical layout of their books. Drilling down is easy, and for each sub-category there are more info about news in that section, top sellers, popular authors etc. Unfortunately we don't have access to the usage statistics of Amazon, so we can't know if it is datanerds using the folders, or the user levels of those using them.

That they do exist, and continue to exist, is a good pointer towards what Amazon thinks is best. I usually say "emulate Amazon whereevery you can". It isn't neccessarily the best way to do things, but it is the de facto standard.

What is needed though, and others have remarked upon it, is some actual user testing and reports from them. I'd also like to see some verbatim description of what exactly you guys think about when you say search and filters. How will that impact the site design? How will it impact navigation? How will it impact complexity? I guess it isn't an either or proposition, but I'd like to see some sites implementing what you're talking about in order to better understand it.

--
http://www.vogol.com/user/spdyvkng/blog/

Huib Kleinhout

Tuesday 04 May 2004 5:42:52 am

Tony, your point indeed makes a lot of sense. Naturally, this "information overload" problem happens to be a very generic one. For large amounts of information, a hierarchical structure doesn't always fit the user's need or viewpoint.
High quality search engines partially overcome this problem, but the results are highly dependent on the quality of the keywords used for searching. Since it's often hard to know the "right" keywords, the search results vary.
A nice mix between (hierarchical) folders and searches are "vfolders", which can be used in the e-mail package Evolution to create alternative information structures based on filter criteria. (Microsoft copied this and introduced it as "search folders" in outlook 2003)
http://www.ximian.com/support/manuals/evolution_14/x2279.html

Vfolders will not free the administrator from thinking about the information structure, because information classes still need properties which can be used for filtering. Just using some arbitrary keywords describing the content probably won't deliver consistent results. The admin needs to think about the ontology of the content to be able to define the right class attributes and relations.
Taking a amazon as an example. If amazon wants to create a vfolder based on the number of pages in a book, they should add an attribute "number of pages" (which is a non-negative integer) to the class "book". This may sound very simple, but it's hard to create a consistent filter if the criteria of the filter can't be consistently defined.

Personally, I'm using vfolders for quite some time now and it is working quite well. I think such mechanisms would help structuring information in ezp a lot. Any thoughts?

Alex Jones

Tuesday 04 May 2004 8:02:07 am

This may be a bit long, please forgive me for re-hashing earlier posts, but I am using this to think out loud and hope people will point out the weak spots in my thinking. :) Paul F. and Tony, as I am re-stating ideas that you were kind enough to provide me, please point out any mistakes I may be making.

<b>Summary</b>
I think in many ways, we as developers and organizers of information get wrapped up in our previous experiences with the structures used in operating systems and on the Web. A "folder" is merely a grouping of objects or data. Nothing more, nothing less. So, what we are doing with folders is presenting the user (both internal editors and external users) with a grouping of objects whose relationship to each other makes sense. The following list of objects will be used for some examples:

<i>Object One</i>
Color: Red
Size: Large
Keywords: Widget, Sprocket

<i>Object Two</i>
Color: Red
Size: Small
Keywords: Schooner

<i>Object Three</i>
Color: Blue
Size: Small
Keywords: Cog, Gadget

We see that the objects <i>One</i> and <i>Two</i> share a color ('red'), while objects <i>Two</i> and <i>Three</i> share a size ('small'). In the past I have used Locations to show that <i>Object One</i> and <i>Object Two</i> are related, by placing them in the same folder: <i>Red Objects</i>. Extending that further I need to show that <i>Object Three</i> is related to <i>Object Two</i> but is not related to <i>Object One</i>. This second relationship has to be accounted for with the creation of another folder (<i>Small Objects</i>), within which objects <i>Two</i> and <i>Three</i> are located. For smaller sites this is relatively easy to manage. But with a large site the organizing of information and objects becomes much more complicated and time-consuming. This is where I am running into a problem. Adding multiple locations to an item takes a good bit of time. Not only do we have to go through the process of adding a Location in the editor, we have to make sure we see all of the possible relationships between items. In the above example we created two folders, but once we move beyond these three items we might have to create more to account for new relationships: <i>Blue Objects</i>, <i>Large Objects</i>, <i>Green Objects</i>, <i>Large Blue Objects</i> and so on. So many, if not most items will be placed in more than one folder. Now the editor has to go through and add the locations to each object. Not only do they have to go through the process of adding the locations in the editor, they have to understand the reason that the item belongs in that particular location. They have to have a deep understanding of the information architecture and the desired groupings. Again, this is easy with a smaller site which may have a simple structure, but if the site has hundreds of objects this can grow very complicated.

<b>Possible Solution</b>
Much like the concepts of Folders, the term "search" implies that the user is specifying the terms. But there is no reason that has to be the case. We as site creators, can set up pages that display the results of pre-defined searches: display all <i>objects</i> with 'red' as the value of 'color'.

By using searches I hope to get around the need to explicitly state that objects <i>One</i> and <i>Two</i> are related by the use of a Folder or Location. Rather, I would set up a page that presents a search that is filtered to only look for objects of a specific 'color' (in this case 'red'). So, if I add 10 more objects to the site, any items that have 'red' as their color will automatically be included in the search results. As long as I have defined my objects correctly, and filled in all of the information, I will not need to spend any more time categorizing them by adding all of the possible locations to each one. I will simply have a page that fetches and sorts the items that I want to display.

Now let's say that I add the word 'Widget' to the 'Keyword' field for <i>Object Three</i>. I now have a new grouping of <i>Object 1</i> and <i>Object Three</i> without creating a new folder or assigning another location to either object.

This method allows us to harness the strength of search (finding everything that is related, filtering out that which should not be displayed) without losing the strengths of folders (categorization). The displayed results do not have to look like search results, they can look however we want them to. The site design and navigation have just as much flexibility as they would if folders were used. Perhaps more, as we can create new categories very quickly without touching the data. It takes less time to add a fetch that filters on an attribute than it would to add hundreds of objects to a new location. And, if my understanding is correct, the upcoming implementation of view_parameters (http://www.ez.no/community/bug_reports/view_parameters_only_works_with_offset), will allow us to construct new views via URL, so we won't even need to create new fetches. The new category could be created purely by linking to it (http://mysite.com/my/friendly/path/(viewvariable1)/value1/(viewvariable2)/value2/)

All of this doesn't negate the use of a general search, so the user can still use the search engine to find what they want using their own terms.

<b>Additional Benefit</b>
By using this method we may begin to see relationships that may not be obvious from the outset.

I hope this makes sense. It needs to be refined, but it is a start.

Alex

Alex
[ bald_technologist on the IRC channel (irc.freenode.net): #eZpublish ]

<i>When in doubt, clear the cache.</i>

Paul K Egell-Johnsen

Tuesday 04 May 2004 11:59:10 am

Thanks for the clearification, Alex and Huib. As for the keywords, it will as Huib suggests, create problems since the ontology is needed (not to say the poor spelling capabilities of those registering data). I think using restraints in the classes will be a better solution, it will keep the constraints, but 1) limit them to the appropriate for the object being registered and 2) limit the options for the attributes to allowed values.

At this point I would ask the question: Someone is doing data entry into the system, and the allowed options for an attribute is missing one color, how will the one doing the dataentry solve this?

Another thing this can be useful is showing substitute products if a product is out of stock, think AMD XP 2500 if the AMD XP 2600 is out of stock.

And on a higher level, if a product has accessories (ie. a portable computer has a wireless mouse accessory) then one can use the accessories of all objects of the class automatically, to generate super lists. Eh, this should be in another thread.

Ultimately, though, it ties together in making the site easier for those doing dataentry and administration of the site.

--
http://www.vogol.com/user/spdyvkng/blog/

S Ross

Wednesday 05 May 2004 11:58:14 am

Small nitpicky item:

on the Editing class page, can the datatype dropdown list box items be sorted by alpha?

Thanks,
Sharon

S Ross

Wednesday 05 May 2004 1:13:03 pm

Actually, any dropdown list box, have the contents sorted by alpha.

Thanks,
Sharon

Cesar Verdes

Thursday 20 May 2004 9:43:14 am

I hope this links are userful for you:

http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnwui/html/iuiguidelines.asp
http://www.carlsononlinedesign.com/inductive.htm

I suggest to rethink the Administrator Interface from a standard Content Manager Interface to a Task oriented interface.

The end-user, who frequently adds and changes contents to the site, doesn't know about nodes and folders. He knows about thinks from he work universe. For example add a new product to the site database.

C.

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 18 2025 15:08:11
Script start
Timing: Jan 18 2025 15:08:11
Module start 'layout'
Timing: Jan 18 2025 15:08:11
Module start 'content'
Timing: Jan 18 2025 15:08:12
Module end 'content'
Timing: Jan 18 2025 15:08:12
Script end

Main resources:

Total runtime0.6775 sec
Peak memory usage4,096.0000 KB
Database Queries126

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0056 589.9063152.6406
Module start 'layout' 0.00570.0027 742.546939.9063
Module start 'content' 0.00830.6678 782.45311,017.0391
Module end 'content' 0.67610.0013 1,799.492258.2891
Script end 0.6775  1,857.7813 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00310.4599160.0002
Check MTime0.00130.1894160.0001
Mysql Total
Database connection0.00090.130810.0009
Mysqli_queries0.541879.96351260.0043
Looping result0.00120.18421240.0000
Template Total0.647995.620.3240
Template load0.00210.314320.0011
Template processing0.645895.317420.3229
Template load and register function0.00010.013010.0001
states
state_id_array0.00170.252710.0017
state_identifier_array0.00220.329020.0011
Override
Cache load0.00220.32991550.0000
Sytem overhead
Fetch class attribute can translate value0.00060.086580.0001
Fetch class attribute name0.00070.1054230.0000
XML
Image XML parsing0.00470.686980.0006
class_abstraction
Instantiating content class attribute0.00010.0096310.0000
General
dbfile0.00290.4291440.0001
String conversion0.00000.001240.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
14content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
17content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
33content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
20content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 86
 Number of unique templates used: 6

Time used to render debug report: 0.0001 secs