Keywords: Difference between revisions

From Littledamien Wiki
Jump to navigation Jump to search
Line 64: Line 64:


===Displaying keyword lists within 'details' pages===
===Displaying keyword lists within 'details' pages===
* LITTLED/JQuery config within <code>$(document).ready()</code>
====JQuery handlers====
LITTLED/JQuery config within <code>$(document).ready()</code>
<syntaxhighlight lang="javascript">
<syntaxhighlight lang="javascript">
$fn.keywords('bindListingsHandlers');
$fn.keywords('bindListingsHandlers');
</syntaxhighlight>
</syntaxhighlight>


* On the details page, assuming that the content object is derived from <code>db_keyword_content_class</code>  
====Inserting the keyword markup with PHP====
On the details page, assuming that the content object is derived from <code>db_keyword_content_class</code>  
<syntaxhighlight lang="php">
<syntaxhighlight lang="php">
<div class="metadata">
<div class="metadata">
Line 78: Line 80:
</div>
</div>
</syntaxhighlight>
</syntaxhighlight>
====AJAX handler====
* Default handler: <code>_ajax/utils/edit_keywords.php</code>
** Assumes that a case for the content type has been created in the PHP routine <code>cache_class::update_keywords()</code>
** If the content type caches the keywords for fulltext search, then the PHP class for the content type must define a routine named <code>update_fulltext_keywords()</code>.
* Keyword records are saved in PHP routine <code>db_keyword_content_class::save_keywords()</code>


==Album keyword filter autocomplete==
==Album keyword filter autocomplete==

Revision as of 23:36, 17 May 2012

Overview

Details about implementing keywords with PHP classes.

PHP libraries

  • [COMMON_LIB]_classes/db/db_keyword_content_class.php
  • [COMMON_LIB]_classes/keywords/keyword_class.php

Displaying keywords

Displaying keyword lists within listings pages

  • LITTLED/JQuery config within $(document).ready()
$fn.keywords('bindListingsHandlers');
  • This is not rolled into $fn.listings('bindListingsHandlers')
  • Typically, it would be added to a JQuery plugin targeted to a specific CMS content section:
/*
 * file: content_type.js
 * JQuery added functionality
 */
(function($) {
	var methods = {
		bindListingsHandlers: function() {
			
			return this.each(function() {

				/* listings handlers */
				$(this)
				.listings('bindListingsHandlers')
				.keywords('bindListingsHandlers');

				LITTLED.init({setSortables: function() {
					$('#listings-container')
					.listings('bindListingsButtons')
					.keywords('bindListingsButtons');
				}});
			});
		},
/* etc... */
  • Outside the listings loop,
  • Define an object to use to retrieve and display keyword lists.
  • Set the keyword object's content id to the appropriate value for the listings content.
  • Within the listings loop,
  • Set the id of the keyword object to the current record id.
  • Include shared content include to display keyword list.
  • Clear keyword values.
$keywords = new db_keyword_content_class($filters->site_section->id->value);
while ($row = mysql_fetch_object($rs)) {
?>
	<tr class="rec-row <?=$rowClass?>" id="rr-<?$filters->site_section->id->value?>-<?=$row->id?>" data-rid="<?=$row->id?>">
		<td>
<?
	$keywords->id->value = $row->id;
	include (COMMON_TEMPLATE_DIR."content/keywords/keywords_cell.php");
	$keywords->clear_keyword_data();
?>
		</td>
	</tr>
}

Displaying keyword lists within 'details' pages

JQuery handlers

LITTLED/JQuery config within $(document).ready()

$fn.keywords('bindListingsHandlers');

Inserting the keyword markup with PHP

On the details page, assuming that the content object is derived from db_keyword_content_class

<div class="metadata">
<? 	
	$keywords = &$input;
	include (COMMON_TEMPLATE_DIR."content/keywords/keywords_cell.php"); 
?>
</div>

AJAX handler

  • Default handler: _ajax/utils/edit_keywords.php
    • Assumes that a case for the content type has been created in the PHP routine cache_class::update_keywords()
    • If the content type caches the keywords for fulltext search, then the PHP class for the content type must define a routine named update_fulltext_keywords().
  • Keyword records are saved in PHP routine db_keyword_content_class::save_keywords()

Album keyword filter autocomplete

  • AJAX handler: /_ajax/images/album_title_search.php
  • Define derived version of search_titles(). The base routine album_filters_class->search_titles() routine won’t work with the table structure.