diff --git a/uw_cfg_common.install b/uw_cfg_common.install index 004de253ac4b26cf82413977a7bc1bf58c28c582..9ed2ed61a1033cab1d5f554676525f25956313a3 100644 --- a/uw_cfg_common.install +++ b/uw_cfg_common.install @@ -6,6 +6,7 @@ */ use Drupal\taxonomy\Entity\Term; +use Drupal\node\Entity\Node; use Drupal\uw_cfg_common\UwPermissions\UwPermissions; /** @@ -239,3 +240,117 @@ function _uw_cfg_common_create_term($taxonomy_name, $vocab_machine_name, $weight // Return the taxonomy term id. return $new_term->id(); } + +/** + * Update listing blocks items per page when needed. + * + * For listing blocks items per page, when default settings were used, + * change to the original default number of items. + */ +function uw_cfg_common_update_8101() { + + // Block ids that need to be changed, and what the original default was. + // For some reason, we didn't originally use the same number for everything. + $block_ids = [ + 'views_block:uw_view_blogs-blogs_listing_block' => 5, + 'views_block:uw_view_events-events_listing_block' => 10, + 'views_block:uw_view_news_items-news_items_listing_block' => 10, + ]; + + // Load all the nodes. + $nodes = Node::loadMultiple(); + + // Step through each node and set any that were using the default setting + // to the number that was the default before this change. + foreach ($nodes as $node) { + + // Flag to save the node, have this to save processing + // time if we don't need to save the node after the checks. + $save_node_flag = FALSE; + + // Load the layout and sections. + $layout = $node->get('layout_builder__layout'); + $sections = $layout->getSections(); + + // Step through each of the sections. + foreach ($sections as $section) { + + // Load the components for the section. + $components = $section->getComponents(); + + // Step through each of the components. + foreach ($components as $component) { + + // If this component is one that needs to be changed, + // then check for setting and change if required. + if (in_array($component->getPluginId(), array_keys($block_ids))) { + + // Load the config for the block. + $configurations = $component->get('configuration'); + + // If the config is set to "none", it needs to be changed to + // be set to the number that was the old default value. + if ($configurations['items_per_page'] == 'none') { + // Change the config and save the component. + $configurations['items_per_page'] = $block_ids[$component->getPluginId()]; + $component->setConfiguration($configurations); + + // Set the save node flag so that we know to + // save this node as the last step in the loop. + $save_node_flag = TRUE; + } + } + } + + // If we need to save the node, then save it. + if ($save_node_flag) { + $node->save(); + } + } + + // Load all the revisions for the node. + $vids = \Drupal::service('entity_type.manager')->getStorage('node')->revisionIds($node); + + // Step through each revision, and check if we have to + // change the settings for the listing blocks. + foreach ($vids as $vid) { + + // Flag to see if we have to save the revision. + $save_revision_flag = FALSE; + + // Load the revision node. + $revision_node = \Drupal::service('entity_type.manager')->getStorage('node')->loadRevision($vid); + + // Comments from here down are the same as above. + $layout = $revision_node->get('layout_builder__layout'); + $sections = $layout->getSections(); + + foreach ($sections as $section) { + + $components = $section->getComponents(); + + foreach ($components as $component) { + + if (in_array($component->getPluginId(), $block_ids)) { + + $configurations = $component->get('configuration'); + + if ( + $configurations['items_per_page'] == 'none' || + $configurations['items_per_page'] == '5' + ) { + + $configurations['items_per_page'] = '3'; + $component->setConfiguration($configurations); + $save_revision_flag = TRUE; + } + } + } + } + + if ($save_revision_flag) { + $revision_node->save(); + } + } + } +}