diff --git a/islandora_basic_collection/css/islandora_basic_collection.theme.css b/islandora_basic_collection/css/islandora_basic_collection.theme.css index 80dc3c4d..e814f526 100644 --- a/islandora_basic_collection/css/islandora_basic_collection.theme.css +++ b/islandora_basic_collection/css/islandora_basic_collection.theme.css @@ -6,12 +6,16 @@ */ .islandora-basic-collection { - margin: 1.5em auto; overflow: hidden; - width: 96%; + width: 100%; + margin: 0 auto; } -dl.islandora-basic-collection-object +.islandora-basic-collection-object { + margin: 1.5em auto 3em; +} + +.islandora-basic-collection-grid dl.islandora-basic-collection-object { width: 20%; min-width: 100px; @@ -25,7 +29,7 @@ dl.islandora-basic-collection-object _height: 180px; } -.islandora-basic-collection-object dt img { +.islandora-basic-collection-grid .islandora-basic-collection-object dt img { max-width: 100%; *width: 100%; -webkit-border-radius: 5px; @@ -33,7 +37,7 @@ dl.islandora-basic-collection-object border-radius: 5px; } -.islandora-basic-collection-object dd +.islandora-basic-collection-grid .islandora-basic-collection-object dd { margin: 0; padding: 0; @@ -44,3 +48,39 @@ dl.islandora-basic-collection-object #islandora-collection-migrate-form table th.select-all { width: 20px; } + +/* the base css for lists is set in islandora, just adding details */ + +dl.islandora-basic-collection-thumb +{ + float: left; + width: 15%; + margin: 0; +} + +.islandora-basic-collection-thumb dt, +.islandora-basic-collection-thumb dd +{ + margin: 0; +} + +dl.islandora-basic-collection-fields +{ + float: right; + width: 83%; + border-top: 0px solid #ddd; + padding-left: 10px; +} + +.islandora-basic-collection-fields dt, +.islandora-basic-collection-fields dd +{ + border-top: 1px solid #ddd; +} + +.islandora-basic-collection-fields dt.first, +.islandora-basic-collection-fields dd.first +{ + border-top: 1px solid #ddd; +} + diff --git a/islandora_basic_collection/islandora-basic-collection.tpl.php b/islandora_basic_collection/islandora-basic-collection.tpl.php deleted file mode 100644 index d4cbf264..00000000 --- a/islandora_basic_collection/islandora-basic-collection.tpl.php +++ /dev/null @@ -1,35 +0,0 @@ -. - */ -?> -label); ?> - -
-
- $value): ?> -
-
-
-
- -
-
\ No newline at end of file diff --git a/islandora_basic_collection/islandora_basic_collection.module b/islandora_basic_collection/islandora_basic_collection.module index 5dc7ea2e..8d14a042 100644 --- a/islandora_basic_collection/islandora_basic_collection.module +++ b/islandora_basic_collection/islandora_basic_collection.module @@ -65,11 +65,10 @@ function islandora_basic_collection_menu() { * Implements hook_menu_local_tasks_alter(). */ function islandora_basic_collection_menu_local_tasks_alter(&$data, $router_item, $root_path) { - if (module_exists('islandora_content_model_forms')) { // Add action link if ($root_path == 'islandora/object/%/manage/collection') { $object_id = $router_item['page_arguments'][0]; - $item = menu_get_item("islandora/ingest_form/$object_id"); + $item = menu_get_item("islandora/ingest/$object_id"); $item['title'] = 'Add a repository item'; if ($item['access']) { $data['actions']['output'][] = array( @@ -78,7 +77,6 @@ function islandora_basic_collection_menu_local_tasks_alter(&$data, $router_item, ); } } - } } /** @@ -146,7 +144,7 @@ function islandora_basic_collection_manage_object($object_id) { ); $form['collection_manager']['delete_members']['form'] = drupal_get_form('islandora_collection_deletion_form', $object_id); - + // Pass the form around any modules that are interested so that they can add their own collection management functions. module_invoke_all('islandora_collection_manager', $form); @@ -191,22 +189,26 @@ function islandora_basic_collection_access($object_id) { function islandora_basic_collection_theme($existing, $type, $theme, $path) { return array( 'islandora_basic_collection' => array( - 'template' => 'islandora-basic-collection', + 'file' => 'theme/islandora_basic_collection.theme.inc', + 'template' => 'theme/islandora-basic-collection', 'pattern' => 'islandora_basic_collection__', //we can add pids to the end of this pattern in our preprocess function // and templates will be able to have have a pid appended to the template name to overide a template on a per object basis //an example template would be named islandora-basic-image--islandora-27.tpl.phps 'variables' => array('islandora_object' => NULL), ), 'islandora_basic_collection_grid' => array( - 'template' => 'islandora-basic-collection-grid', + 'file' => 'theme/islandora_basic_collection.theme.inc', + 'template' => 'theme/islandora-basic-collection-grid', 'pattern' => 'islandora_basic_collection_grid__', 'variables' => array('islandora_object' => NULL, 'collection_results' => NULL), ), 'islandora_basic_collection_wrapper' => array( - 'template' => 'islandora-basic-collection-wrapper', + 'file' => 'theme/islandora_basic_collection.theme.inc', + 'template' => 'theme/islandora-basic-collection-wrapper', 'variables' => array('islandora_object' => NULL), ), 'islandora_basic_collection_management_form_table' => array( + 'file' => 'theme/islandora_basic_collection.theme.inc', 'arguments' => array('element' => NULL), 'file' => 'includes/CollectionManagerTable.inc', ), @@ -254,110 +256,11 @@ function islandora_basic_collection_islandora_view_object($object, $user) { } /** - * list view preprocess - * currently just calls normal view preprocess as variables are the same - * @param type $variables - */ -function islandora_basic_collection_preprocess_islandora_basic_collection_grid(&$variables) { - islandora_basic_collection_preprocess_islandora_basic_collection($variables); -} - -function islandora_basic_collection_preprocess_islandora_basic_collection_wrapper(&$variables) { - $page_number = (empty($_GET['page'])) ? 0 : $_GET['page']; - $page_size = (empty($_GET['pagesize'])) ? variable_get('islandora_basic_collection_page_size', '10') : $_GET['pagesize']; - $islandora_object = $variables['islandora_object']; - $results = islandora_basic_collection_get_objects($islandora_object, $page_number, $page_size); - $total_count = count($results); - pager_default_initialize($total_count, $page_size); - $variables['collection_pager'] = theme('pager', array('quantity' => 10)); - $display = (empty($_GET['display'])) ? 'list' : $_GET['display']; - if ($display == 'grid') { - $collection_content = theme('islandora_basic_collection_grid', array('islandora_object' => $islandora_object, 'collection_results' => $results)); - } - else { - $collection_content = theme('islandora_basic_collection', array('islandora_object' => $islandora_object, 'collection_results' => $results)); - } - $variables['collection_content'] = $collection_content; -} - -/** - * - * @global type $base_url - * @param array $variables - * an array of variables that will be passed to the theme function + * a wrappert to retrieve an object from Fedora + * @global object $user + * @param string $object_id + * @return null|\FedoraObject */ -function islandora_basic_collection_preprocess_islandora_basic_collection(&$variables) { -// base url - global $base_url; -// base path - global $base_path; - $islandora_object = $variables['islandora_object']; - module_load_include('inc', 'islandora', 'includes/islandora_dublin_core'); - try { - $dc = $islandora_object['DC']->content; - $dc_object = Dublin_Core::import_from_xml_string($dc); - } catch (Exception $e) { - drupal_set_message(t('Error retrieving object %s %t', array('%s' => $islandora_object->id, '%t' => $e->getMessage())), 'error'); - } - $page_number = (empty($_GET['page'])) ? 0 : $_GET['page']; - $page_size = (empty($_GET['pagesize'])) ? variable_get('islandora_basic_collection_page_size', '10') : $_GET['pagesize']; - $results = $variables['collection_results'];//islandora_basic_collection_get_objects($islandora_object, $page_number, $page_size); - $total_count = count($results); - $variables['islandora_dublin_core'] = $dc_object; - $variables['islandora_object_label'] = $islandora_object->label; - $variables['theme_hook_suggestions'][] = 'islandora_basic_collection__' . str_replace(':', '_', $islandora_object->id); - if (isset($islandora_object['OBJ'])) { - $full_size_url = $base_url . '/islandora/object/' . $islandora_object->id . '/datastream/OBJ/view'; - $variables['islandora_full_img'] = ''; - } - if (isset($islandora_object['TN'])) { - $thumbnail_size_url = $base_url . '/islandora/object/' . $islandora_object->id . '/datastream/TN/view'; - $variables['islandora_thumbnail_img'] = ''; - } - if (isset($islandora_object['MEDIUM_SIZE'])) { - $medium_size_url = $base_url . '/islandora/object/' . $islandora_object->id . '/datastream/MEDIUM_SIZE/view'; - $variables['islandora_medium_img'] = ''; - } - - $associated_objects_array = array(); - $start = $page_size * ($page_number); - $end = min($start + $page_size, $total_count); - - for ($i = $start; $i < $end; $i++) { - $pid = $results[$i]['object']['value']; - $fc_object = islandora_basic_collection_get_object($pid); - if (!isset($fc_object)) { - continue; //null object so don't show in collection view; - } - $associated_objects_array[$pid]['object'] = $fc_object; - try { - $dc = $fc_object['DC']->content; - $dc_object = Dublin_Core::import_from_xml_string($dc); - $associated_objects_array[$pid]['dc_array'] = $dc_object->as_formatted_array(); - } catch (Exception $e) { - drupal_set_message(t('Error retrieving object %s %t', array('%s' => $islandora_object->id, '%t' => $e->getMessage())), 'error'); - } - $object_url = 'islandora/object/' . $pid; - $thumbnail_img = ''; - $title = $results[$i]['title']['value']; - $associated_objects_array[$pid]['pid'] = $pid; - $associated_objects_array[$pid]['path'] = $object_url; - $associated_objects_array[$pid]['title'] = $title; - $associated_objects_array[$pid]['class'] = strtolower(preg_replace('/[^A-Za-z0-9]/', '-', $pid)); - if (isset($fc_object['TN'])) { - $thumbnail_img = ''; - } - else { - //TODO: change this default image url - $thumbnail_img = ''; - } - $associated_objects_array[$pid]['thumbnail'] = $thumbnail_img; - $associated_objects_array[$pid]['title_link'] = l($title, $object_url, array('html' => TRUE, 'attributes' => array('title' => $title))); - $associated_objects_array[$pid]['thumb_link'] = l($thumbnail_img, $object_url, array('html' => TRUE, 'attributes' => array('title' => $title))); - } - $variables['associated_objects_array'] = $associated_objects_array; -} - function islandora_basic_collection_get_object($object_id) { module_load_include('inc', 'islandora', 'RestConnection'); global $user; @@ -371,6 +274,15 @@ function islandora_basic_collection_get_object($object_id) { return $fedora_object; } +/** + * gets objects associated with this object with teh isMemberOf or isMemberOfCollection + * + * @global object $user + * @param object $object + * @param string $page_number + * @param string $page_size + * @return array + */ function islandora_basic_collection_get_objects($object, $page_number = 1, $page_size = 5) { $query = 'select $object $title $content from <#ri> where ($object $title diff --git a/islandora_basic_collection/islandora-basic-collection-grid.tpl.php b/islandora_basic_collection/theme/islandora-basic-collection-grid.tpl.php similarity index 94% rename from islandora_basic_collection/islandora-basic-collection-grid.tpl.php rename to islandora_basic_collection/theme/islandora-basic-collection-grid.tpl.php index f56a80b4..5635ebc9 100644 --- a/islandora_basic_collection/islandora-basic-collection-grid.tpl.php +++ b/islandora_basic_collection/theme/islandora-basic-collection-grid.tpl.php @@ -24,7 +24,7 @@
-
+
$value): ?>
diff --git a/islandora_basic_collection/islandora-basic-collection-wrapper.tpl.php b/islandora_basic_collection/theme/islandora-basic-collection-wrapper.tpl.php similarity index 100% rename from islandora_basic_collection/islandora-basic-collection-wrapper.tpl.php rename to islandora_basic_collection/theme/islandora-basic-collection-wrapper.tpl.php diff --git a/islandora_basic_collection/theme/islandora-basic-collection.tpl.php b/islandora_basic_collection/theme/islandora-basic-collection.tpl.php new file mode 100644 index 00000000..3fb1a4c2 --- /dev/null +++ b/islandora_basic_collection/theme/islandora-basic-collection.tpl.php @@ -0,0 +1,53 @@ +. + */ +?> +label); ?> + +
+ + +
+
+
+
+
+ +
+ +
\ No newline at end of file diff --git a/islandora_basic_collection/theme/islandora_basic_collection.theme.inc b/islandora_basic_collection/theme/islandora_basic_collection.theme.inc new file mode 100644 index 00000000..3e79e1f9 --- /dev/null +++ b/islandora_basic_collection/theme/islandora_basic_collection.theme.inc @@ -0,0 +1,114 @@ + 10)); + $display = (empty($_GET['display'])) ? 'list' : $_GET['display']; + if ($display == 'grid') { + $collection_content = theme('islandora_basic_collection_grid', array('islandora_object' => $islandora_object, 'collection_results' => $results)); + } + else { + $collection_content = theme('islandora_basic_collection', array('islandora_object' => $islandora_object, 'collection_results' => $results)); + } + $variables['collection_content'] = $collection_content; +} + +/** + * + * @global type $base_url + * @param array $variables + * an array of variables that will be passed to the theme function + */ +function islandora_basic_collection_preprocess_islandora_basic_collection(&$variables) { +// base url + global $base_url; +// base path + global $base_path; + $islandora_object = $variables['islandora_object']; + module_load_include('inc', 'islandora', 'includes/islandora_dublin_core'); + try { + $dc = $islandora_object['DC']->content; + $dc_object = Dublin_Core::import_from_xml_string($dc); + } catch (Exception $e) { + drupal_set_message(t('Error retrieving object %s %t', array('%s' => $islandora_object->id, '%t' => $e->getMessage())), 'error'); + } + $page_number = (empty($_GET['page'])) ? 0 : $_GET['page']; + $page_size = (empty($_GET['pagesize'])) ? variable_get('islandora_basic_collection_page_size', '10') : $_GET['pagesize']; + $results = $variables['collection_results']; //islandora_basic_collection_get_objects($islandora_object, $page_number, $page_size); + $total_count = count($results); + $variables['islandora_dublin_core'] = $dc_object; + $variables['islandora_object_label'] = $islandora_object->label; + $display = (empty($_GET['display'])) ? 'list' : $_GET['display']; + if ($display == 'grid') { + $variables['theme_hook_suggestions'][] = 'islandora_basic_collection_grid__' . str_replace(':', '_', $islandora_object->id); + } + else { + $variables['theme_hook_suggestions'][] = 'islandora_basic_collection__' . str_replace(':', '_', $islandora_object->id); + } + if (isset($islandora_object['OBJ'])) { + $full_size_url = $base_url . '/islandora/object/' . $islandora_object->id . '/datastream/OBJ/view'; + $variables['islandora_full_img'] = ''; + } + if (isset($islandora_object['TN'])) { + $thumbnail_size_url = $base_url . '/islandora/object/' . $islandora_object->id . '/datastream/TN/view'; + $variables['islandora_thumbnail_img'] = ''; + } + if (isset($islandora_object['MEDIUM_SIZE'])) { + $medium_size_url = $base_url . '/islandora/object/' . $islandora_object->id . '/datastream/MEDIUM_SIZE/view'; + $variables['islandora_medium_img'] = ''; + } + + $associated_objects_array = array(); + $start = $page_size * ($page_number); + $end = min($start + $page_size, $total_count); + + for ($i = $start; $i < $end; $i++) { + $pid = $results[$i]['object']['value']; + $fc_object = islandora_basic_collection_get_object($pid); + if (!isset($fc_object)) { + continue; //null object so don't show in collection view; + } + $associated_objects_array[$pid]['object'] = $fc_object; + try { + $dc = $fc_object['DC']->content; + $dc_object = Dublin_Core::import_from_xml_string($dc); + $associated_objects_array[$pid]['dc_array'] = $dc_object->as_formatted_array(); + } catch (Exception $e) { + drupal_set_message(t('Error retrieving object %s %t', array('%s' => $islandora_object->id, '%t' => $e->getMessage())), 'error'); + } + $object_url = 'islandora/object/' . $pid; + $thumbnail_img = ''; + $title = $results[$i]['title']['value']; + $associated_objects_array[$pid]['pid'] = $pid; + $associated_objects_array[$pid]['path'] = $object_url; + $associated_objects_array[$pid]['title'] = $title; + $associated_objects_array[$pid]['class'] = strtolower(preg_replace('/[^A-Za-z0-9]/', '-', $pid)); + if (isset($fc_object['TN'])) { + $thumbnail_img = ''; + } + else { + //TODO: change this default image url + $thumbnail_img = ''; + } + $associated_objects_array[$pid]['thumbnail'] = $thumbnail_img; + $associated_objects_array[$pid]['title_link'] = l($title, $object_url, array('html' => TRUE, 'attributes' => array('title' => $title))); + $associated_objects_array[$pid]['thumb_link'] = l($thumbnail_img, $object_url, array('html' => TRUE, 'attributes' => array('title' => $title))); + } + $variables['associated_objects_array'] = $associated_objects_array; +} + +?> diff --git a/islandora_basic_image/islandora-basic-image.tpl.php b/islandora_basic_image/islandora-basic-image.tpl.php index 73c79ae2..74d183b0 100644 --- a/islandora_basic_image/islandora-basic-image.tpl.php +++ b/islandora_basic_image/islandora-basic-image.tpl.php @@ -25,7 +25,11 @@
- TRUE)); ?> + + TRUE)); ?> + + +