/Urchin

Publishing platform for Drupal

Primary LanguagePHP

Urchin

Urchin contains the bulk of the business logic and data parsing functions that make up the core of our Drupal-based publishing platform. Helper classes for parsing nodes, getting lists of nodes and nids, and accessing fields are available, with the overall goal of providing a solid kick-start to any Drupal-based editorial site.

Installation

Urchin should be placed in your template's lib directory. Rather than copy the files manually, though, it's best to add Urchin as a git submodule. This allows for easy command-line updating in the future. From the base of your Drupal project, add Urchin as a git submodule by running the following commands from the project root:

$ git submodule add git@github.com:AsheAvenue/Urchin.git drupal/sites/all/themes/<theme_name>/lib/Urchin

Urchin will then be included in your project. To reference it within your project, add the following line to the top of your template.php file, just after the opening PHP tag:

require_once('lib/Urchin/Urchin.php');

Updating Urchin

To update Urchin, run the following commands from the project root:

$ cd drupal/sites/all/themes/<theme_name>/lib/Urchin
$ git pull origin master

Reference

Urchin contains a robust set of chainable functions used for querying the Drupal database for articles and other content:

Start by opening the chain with one of the following:

  • Article::get($type) - Uses Drupal's EntityFieldQuery system
  • Select::get($type) - Uses Drupal's db_select system

Then set your criteria by chaining any of the following on to the opener:

  • Base::date($order)
  • Base::dateAfter($date)
  • Base::dateBetween($start, $stop)
  • Base::dateBefore($date)
  • Base::exclude($exclude)
  • Base::field($field_name, $field_value, $key)
  • Base::fieldOrderBy($field, $order, $key)
  • Base::limit($limit)
  • Base::pager($limit)
  • Base::sort()
  • Base::vocabularyTerm($vocabulary, $term)

And finish the chain by calling for the count or for the result(s):

  • Base::count()
  • Base::execute()

Examples:

$video_articles = Article::get('video')
                    ->sort('recent')
                    ->limit(1)
                    ->execute();

$galleries = Article::get('gallery')
                    ->sort('alpha')
                    ->limit(3)
                    ->execute();

$recent_articles  = Select::get('text')
                    ->sort('recent')
                    ->execute();

$video_article_count = Article::get('video')
                    ->count();

$articles = Article::get('event')
                    ->dateBetween($firstDayOfMonth, $lastDayOfMonth)
                    ->date()
                    ->execute();

Urchin also contains a series of helper functions useful for rendering page components and getting site-specific parameters:

  • Article::getCollection($nid)
  • Gallery::get($node)
  • Node::getAuthor($node)
  • Node::getCategory($node)
  • Node::getExcerpt($node)
  • Node::getField($node, $field, $key = 'value', $id = 0, $strip_tags = false, $multiple = false)
  • Node::getNids($nodes)
  • Node::getNodeData($node)
  • Node::getNodes($nids)
  • Node::getThumbnail($node)
  • Node::getRelated($node, $limit = 3, $category_only = true, $tags_only = false)
  • Search::get($search_term)
  • Site::getFallbackImgSrc()
  • Site::getLibPath($lib_name)
  • Site::getRequestURI()
  • Site::getSharedPath($view_name)
  • Site::isFirstPage()
  • Site::breadcrumb()
  • Taxonomy::getChildren($tid)
  • Taxonomy::getFieldName($vid)
  • Taxonomy::getSeriesInfo($node)
  • Taxonomy::getTerm($tid)
  • Taxonomy::getTermInfo($term)
  • Taxonomy::getTids($field, $language)
  • Utility::trimText($text, $length = 80, $append = '...')
  • Utility::slugify($string)
  • Video::renderYouTubeEmbed($id = null, $width = 640, $height = 390)
  • Video::renderEmbed($embed)
  • Video::getFeaturedVideo($field_article_video)
  • Video::getYouTubeImageURL($node)

Finally, Urchin contains a file that includes globally-declared variables aimed at preventing the proliferation of specific category names, series names, and node IDs throughout the project. If you need to refer to a specific node ID or category ID in your template or helper, declare a global variable in globals.php and only reference the global variable. Example:

// Article node types
$GLOBALS['article_node_types'] = array('text', 'blog', 'video', 'gallery', 'poll');

// Categories
$GLOBALS['category_news']              = 1;
$GLOBALS['category_entertainment']     = 3;
$GLOBALS['category_oneohone']          = 25;
$GLOBALS['category_grow']              = 21;

// Collections
$GLOBALS['sidebar_featured_gallery']    = 206;
$GLOBALS['sidebar_whats_smokin']        = 205;
$GLOBALS['sponsored_links']             = 19314;

Acknowledgements + Legal

© 2013 Ashe Avenue. Created by Heath Beckett and Tim Boisvert.
Urchin is released under the MIT license.

Totoro designed by Nithin Davis Nanthikkara from The Noun Project