Editing
Inline Edits With PHP/AJAX
Jump to navigation
Jump to search
Warning:
You are not logged in. Your IP address will be publicly visible if you make any edits. If you
log in
or
create an account
, your edits will be attributed to your username, along with other benefits.
Anti-spam check. Do
not
fill this in!
== Markup == === Editable container === Add a `<td>` or `<div>` container as a container for the inline edits. * The container's content is changed to accommodate the edits, but not the container itself. * Assign the container a class that will serve as a selector for inline edits. Something like `status-cell`, `in-stock-cell`, `access-cell`, etc. * Assign the container the `inline-edit` class to use to target it for content updates. * The container has a `data-id` attribute with the parent record's id as its value. * Variable name ** The PHP variable used to access the value displayed in the cell is typically `$row` on listings pages and `$input` on details pages. ** The content template will have to accommodate whatever variable is used on its parent page. ** Create an object variable for the purposes of the template that won't collide with the parent page's variables, and that has whatever properties are required by the cell template:<br /><syntaxhighlight lang="php"> $name = (object)array("id"=>$clip->id, "table"=>'album', "value"=>$clip->title); </syntaxhighlight> === Editable content === Create an include file for the flattened content that can be shared between listings and details pages. * path: `[SECTION_BASE_DIR]_templates/content/[content_type]-cell.php` * The actual content of this file doesn't affect the process; it can be anything. === Editing form === Create an include file to be inserted into the DOM by the editing handler. * path: `[SECTION_BASE_DIR]_templates/forms/[content_type]-edit-form.php` * Include a hidden error message container with class `alert alert-error`. * Hidden form inputs: ** `id`: parent record id ** `[class_id_param]`: parent record id parameter as defined in the parent PHP class ** Any filter values needed to present options during the process. * A form input for the property being edited. * Submit buttons are optional. Ideally an `onchange` or {{kbd|Enter}} key keystroke handler will cause the inline form to be submitted. == JavaScript == === Shared library === `$.inlineEdit()` * Bundled into `littled.js` * Source: `[COMMON_BASE_DIR]scripts/littled/inlineEdit.js` * Settings ** `input_key` The name of the parameter used to pass the new value to the AJAX page. ** `edit_uri` URL of the AJAX script that serves the form markup and commits the changes to the database. ** `events.to_commit` Type of event that will cause the new value to be saved to the database, e.g. 'keydown', 'change'. *** Currently, 'change' is the only value that is implemented. *** <span style="color:red">'''implement a keydown handler for textbox form inputs'''</span> === Initialization on page === <syntaxhighlight lang="javascript"> $(document).ready(function() { $('.mycontent-edit-cell').inlineEdit('init', { input_key: 'mycontentID', edit_uri: '/path/to/ajax_script.php' }); }); </syntaxhighlight> == AJAX == === Custom content edits === * Create a page class derived from the shared `AjaxPage` class. * Collect parent id, read parent properties, return markup used to display the editing form. * Test if form was submitted, and save changes accordingly. * Return JSON containing markup used to update page content, error messages, and status messages. === Standardized edits === Names, titles, status (enabled vs disabled), dates, keywords, page numbers. == Examples == * [http://littled.dbarchowsky.com/storage Littledamien storage CMS] > package status container * [http://damienjay.dbarchowsky.com/hostmgr/books Damien Jay Comics books CMS] > in-stock container [[Category:CMS Documentation]] [[Category:JavaScript]] [[Category:jQuery/AJAX]] [[Category:PHP]] [[Category:Littled Libraries]] [[Category:Web Development]]
Summary:
Please note that all contributions to Littledamien Wiki may be edited, altered, or removed by other contributors. If you do not want your writing to be edited mercilessly, then do not submit it here.
You are also promising us that you wrote this yourself, or copied it from a public domain or similar free resource (see
Littledamien Wiki:Copyrights
for details).
Do not submit copyrighted work without permission!
Cancel
Editing help
(opens in new window)
Template used on this page:
Template:Kbd
(
edit
)
Navigation menu
Personal tools
Not logged in
Talk
Contributions
Create account
Log in
Namespaces
Page
Discussion
English
Views
Read
Edit
View history
More
Search
Navigation
Main page
Recent changes
Random page
Help about MediaWiki
Tools
What links here
Related changes
Special pages
Page information