| Age | Commit message (Collapse) | Author | 
|---|
|  | container. Brought back borders. Use a neutral bg color for albums. Link item titles, not just thumbnails. | 
|  |  | 
|  |  | 
|  |  | 
|  | communicate.  Almost all controllers now use JSON to speak to the
theme when we're dealing with form processing.  This means tht we only
send the form back and forth, but we use a JSON protocol to tell the
browser success/error status as well as the location of any newly
created resources, or where the browser should redirect the user.
Lots of small changes:
1) Admin -> Edit Profile is gone.  Instead I fixed the "Modify Profile" link
   in the top right corner to be a modal dialog
2) We use json_encode everywhere.  No more Atom/XML for now.  We can bring those
   back later, though.  For now there's a lot of code duplication but that'll be
   easy to clean up.
3) REST_Controller is no longer abstract.   All methods its subclasses should create
   throw exceptions, which means that subclasses don't have to implement stubs for
   those methods.
4) New pattern: helper method get_add_form calls take an Item_Model,
   not an id since we have to load the Item_Model in the controller
   anyway to check permissions.
5) User/Groups REST resources are separate from User/Group in the site
   admin.  They do different things, we should avoid confusing overlap. | 
|  | 1) Deleted in-place-editing.  We'll be replacing this with a real edit
   system that groups settings together and is more coherent.
2) Tweaked the way that dialog boxes work to get the ajax stuff working
   again.  It's imperfect and does not work properly for uploading images.
   This is going to get redone also, but this is a good resting point.
3) Created edit forms for albums and photos.  Moved _update and _create out
   of Items_Controller and into the individual subclasses.
4) Created access::required which is a shorthand for:
    if (!access::can(...)) {
      access::forbidden();
    }
5) Added validation rules to Items_Model
6) Converted login to use the regular modal dialog approach in the theme. | 
|  | 1) If the create request is Ajax, then return a 201 Created response code
2) If we receive back a 201 response, then switch to the new page.
3) Display a status message when we do an upload. | 
|  |  | 
|  |  | 
|  | context of dialog display (don't show legends, fieldset border, or submit button).
Let's make sure that all forms generated are complete and well formed and then use JS and CSS to control their display and behavior in different contexts. | 
|  | Applied to modal dialogs. | 
|  | labels' value. Labels should always be used with visible inputs. Use this to style and control short form input display and behavior. | 
|  |  | 
|  |  | 
|  | submission so the form doesn't close.  There might be a better way, but i couldn't think of it. | 
|  |  | 
|  |  | 
|  |  | 
|  | errors don't display on first failed attempt, will fix later. Moved jquery js, images, css out to respective folders. | 
|  |  | 
|  |  | 
|  | and we can reuse it for a different popup | 
|  | 1) separate the classes that are generated by the Menu class from what is used for the rendering. The classes that are generated are gMenu, gMenuElement, and gMenuDialog for the Menu, Menu_Element and MenuDialog classes respectively.
2) Changed the ui.init.js to add the appropriate rendering classes to the above classes. All gMenu elements have the sf-menu class added.  All elements of class gMenuDialog have the gDialogLink class added.
3) Use Superfish for the menus so they now float properly. | 
|  | Updated album/item view icons. | 
|  |  | 
|  | screen.css, moved default theme JS to js folder. Named jQuery UI files to match the file names as they distribute them. Removed accordion, it's not used yet. | 
|  |  | 
|  |  | 
|  |  | 
|  | li to comment thread ul. Added fadeIn for user login. | 
|  |  | 
|  | here. In place commenting works again. | 
|  | user login form. Added gHide, gShowBlock, gShowInline, gClose classes to handle show and hide functions. Half-baked idea which will need refinement. | 
|  | implementation yet | 
|  | refer to collections should now have plural names and there should be only one controller per resource. Updated existing classes that implement REST_Controller. The routing now works like this:
GET    /controller    -> controller::_index()
POST   /controller    -> controller::_create()
GET    /controller/id -> controller::_show()
PUT    /controller/id -> controller::_update()
DELETE /controller/id -> controller::_delete()
GET    /form/edit/controller/resource_id -> controller::_form()
GET    /form/add/controller/data         -> controller::_form() | 
|  | ajaxify_comment_form() as needed.  Otherwise the 2nd post attempt won't be ajax | 
|  | 1) Changed the way that we get forms.  Now, if you want to get a form
   for a REST resource you prefix /form to the resource id.  So:
    /form/photo/1    : returns a form for editing photo id 1
    /form/comments/1 : returns a form for adding a comment to photo id 1
    /form/comment/1  : returns a form for editing comment id 1
2) Changed the comment module to have two controllers:
    comment:  deals with a single comment resource
    comments: deal with collections of comments attached to an item
Related stuff:
- Moved the comments js into the theme
- Reworked Comment_Helper for clarity
- Moved form generation code down into Comment_Helper
- Cleaned up routes (eliminating new comment ones added in recent rev)
- Added form() function to all REST controllers
- Changed comment module to use a block instead of an arbitrary helper call from the theme
- Comment controller only returns HTML currently, but returns a 201 Created status
  code when a new comment is added, which the Ajax code can catch and act upon.
- Got rid of a lot of extra views in comment module | 
|  | This disambiguates forms from blocks (for example in the comment
module we were calling both the form and block gComments). | 
|  |  | 
|  | * Remove user registration link and popup from the theme; this
  shouldn't be done in a popup. Use ajaxform to simplify the way
  that we load the login popup.
* Create form.html.php, this is a template for Forge based forms.
* Move user validation rules into User_Model and let forms
  populate the rules into their forms as useful.
* Undo r18688's changes regarding the REST code.  We should never
  accept a null resource, this breaks the REST abstraction.
* Change login and user controllers to use Forge which lets us delete
  login.html.php and user.html.php since those now are generated by
  the theme-owned form template | 
|  |  | 
|  | generate the post data | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | html for the login form is retrieve via an ajax call when the user clicks on login.  Can't login with a valid id yet, but you certainly get error messages when things are wrong :-) | 
|  |  | 
|  | login link in the header wil open up a login box like the mockup |