123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297 |
- <?php
- /*
- * @files
- * Theme Template Funtions
- */
- use Drupal\Core\Template\Attribute;
- use Drupal\Core\Link;
- use Drupal\Core\Url;
- // function popsu_preprocess_views_view_list(&$variables){
- // kint($variables);die();
- // }
- function popsu_preprocess_html(&$variables) {
- $node = \Drupal::routeMatch()->getParameter('node');
- // $type = $node->getType();
-
- //
- $frontpage = \Drupal::service('path.matcher')->isFrontPage();
- $variables['site_name'] = \Drupal::config('system.site')->get('name');
- $variables['slogan'] = \Drupal::config('system.site')->get('slogan');
- //var_dump($variables['head_title']);
- if( $frontpage == true){
- $variables['head_title'] = [$variables["site_name"], $variables['slogan']];
- }
- // else{
- // $variables['head_title'] = $variables['site_name'];
- // }
- if ($node){
- if($node->hasField('field_programme') && $node->get('field_programme')->getString() != ""){
- $variables['attributes']['class'][] = 'programme-' . $node->get('field_programme')->getString();
- }else{
- if ($node->id()){
- $variables['attributes']['class'][] = 'programme-' . $node->id();
- }
-
- }
- }
- }
- // function popsu_preprocess_page(&$variables) {
- // if(isset($variables['node'])){
- // $node = $variables['node'];
- // if(isset($node) && $node->hasField('field_videos') && $node->get('field_videos')->getString() != ""){
- // $variables['attributes']['class'][] = 'ressources-video';
- // }
- // }
- // }
- function popsu_preprocess_page__node(&$variables) {
- $node = $variables['node'];
- if($node->getType() === "ressource"){
- $type_ref_entity = $node->get('field_type_de_ressource')->referencedEntities();
- if(count($type_ref_entity)){
- // $type = filter_var(strtolower(str_replace(" ", "-", $type_ref_entity[0]->getName())), FILTER_SANITIZE_URL);
- // setlocale(LC_ALL, "en_US.utf8");
- // $type = iconv('UTF-8','ASCII//TRANSLIT//IGNORE',strtolower(str_replace(" ", "-", $type_ref_entity[0]->getName())));
- $trans = \Drupal::transliteration();
- $type = $trans->transliterate(strtolower(str_replace(" ", "-", $type_ref_entity[0]->getName())), 'en');
- $variables['attributes']['class'][] = 'ressources-' . $type;
- }
- }
- }
- function popsu_preprocess_node(&$variables){
-
- $node = &$variables['node'];
- if($node->hasField('field_programme') && $node->get('field_programme')->getString() != ""){
-
- $variables['attributes']['class'][] = 'programme-' . $node->get('field_programme')->getString();
- }
- }
- function popsu_preprocess_field(&$variables){
- $element = &$variables['element'];
- if (isset($element['#field_name'])) {
- $variables['attributes']['class'][] = $element['#field_name'];
- if ($element['#field_name'] == 'field_texte') {
- $variables['attributes']['class'][] = 'crop';
- }
- if($element["#field_name"] == "field_programme"){
-
- foreach ($element["#items"]->getIterator() as $id => $item) {
-
- $nid = $item->getValue()['target_id'];
- //dump($nid);
-
- $variables['items'][$id]['attributes'] = new Attribute();
- $variables['items'][$id]['attributes']->addClass("programme-".$nid);
- }
- }
- }
-
- }
- function popsu_preprocess_views_view_unformatted(&$variables) {
- $view = &$variables['view'];
- $rows = &$variables['rows'];
- if($view->id() == "programmes"){
- foreach ($rows as $id => $row) {
- $variables['rows'][$id]['attributes'] = new Attribute();
- $c = $variables['rows'][$id]['content']["#row"]->nid;
-
- $variables['rows'][$id]['attributes']->addClass("programme-".$c);
- }
- }else{
- foreach ($rows as $id => $row) {
- if(isset($row['content']['#row'])){
- $r = $row['content']['#row'];
- $entity = $r->_entity;
- if ($entity->hasField('field_programme') && $entity->get('field_programme')->getString() != "" ) {
- $variables['rows'][$id]['attributes'] = new Attribute();
- $referenced_entities = $entity->get('field_programme')->referencedEntities();
- foreach ($referenced_entities as $ref_entity) {
- $variables['rows'][$id]['attributes']->addClass("programme-".$ref_entity->id());
- }
- if ($entity->hasField('field_type_de_ressource') && $entity->get('field_type_de_ressource')->getString() == "74" ) {
- $type = $entity->get('field_type_de_ressource')->getString();
- $variables['rows'][$id]['attributes']['class'][] = "type-".$type;
- }
- }
- }else if(isset($row['content']['#node'])){
- $r = $row['content']['#node'];
- if ($r->hasField('field_programme') && $r->get('field_programme')->getString() != "" ) {
-
- $c = $r->get('field_programme')->getString();
- $variables['rows'][$id]['attributes'] = new Attribute();
- $variables['rows'][$id]['attributes']->addClass("programme-".$c);
- }
-
- }
-
- }
- }
- };
- /* implements template_preprocess_region() */
- function popsu_preprocess_region(&$variables) {
- if (isset($variables['region'])) {
- $variables['attributes']['class'][] = $variables['region'].'_container';
- }
- }
- /**
- * Implements hook_preprocess_views_view_unformatted().
- */
- function popsu_preprocess_views_view_grid(&$variables){
- // we pass all variables by reference
- // https://www.php.net/manual/en/language.references.php
- $items =& $variables['items'];
- // loop through grid items (row and cols) not through views\rows
- foreach ($items as $r => &$row) {
- foreach ($row['content'] as $c => &$col) {
- // get the entity
- $entity = $col['content']["#row"]->_entity;
- // build generique classe
- $classes = array(
- $entity->getEntityTypeId(),
- $entity->getEntityTypeId().'-'.$entity->bundle(),
- $entity->getEntityTypeId().'-'.$entity->bundle().'-'.$entity->id(),
- );
- // kint($entity);die();
- // if field_programme exists, add a class
- if ($entity->hasField('field_programme')) {
- $referenced_entities = $entity->get('field_programme')->referencedEntities();
- foreach ($referenced_entities as $ref_entity) {
- $classes[] = "programme-".$ref_entity->id();
- }
- }
- if ($entity->hasField('field_type_de_ressource')) {
- $type = $entity->get('field_type_de_ressource')->getString();
- $classes[] = "type-".$type;
- }
- // add the classes to the column
- // Drupal\Core\Template\Attribute
- // https://api.drupal.org/api/drupal/core%21lib%21Drupal%21Core%21Template%21Attribute.php/class/Attribute/8.2.x
- $col['attributes']->addClass($classes);
- }
- }
- }
- function popsu_preprocess_views_view_field(&$variables){
- // check if link to entity option is true
- $settings = isset($variables['field']->options['settings']) ? $variables['field']->options['settings'] : false;
- if ($settings && isset($settings['link']) && $settings['link']) {
- // get the entity and build the classes
- $entity = $variables['row']->_entity;
- // $entity_type = $entity->getEntityType();
- if ($entity->getEntityType()->id() == "node" && $entity->id() == 5) {
- // temporarely desactivate popsumonde link
- // get the entity link and url
- $link = $entity->toLink();
- // // $url = $entity->toLink()->getUrl();
- // $url = URL::fromUserInput('#');
- // // update the url of the link
- // $link->setUrl($url);
-
- // overwrite the output
- $variables['output'] = [
- '#type' => 'html_tag',
- '#tag' => 'span',
- '#value' => $link->getText(),
- '#attributes' => [
- "class" => array(
- $entity->getEntityTypeId(),
- $entity->getEntityTypeId().'-'.$entity->bundle(),
- $entity->getEntityTypeId().'-'.$entity->bundle().'-'.$entity->id(),
- )
- ]
- ];
-
- }else if ($entity->getType === 'programme') {
- // build new classes
- $new_classes = array(
- $entity->getEntityTypeId(),
- $entity->getEntityTypeId().'-'.$entity->bundle(),
- $entity->getEntityTypeId().'-'.$entity->bundle().'-'.$entity->id(),
- );
- // get the entity link and url
- $link = $entity->toLink();
- $url = $entity->toLink()->getUrl();
- // set the active_class option to the url
- $url->setOption('set_active_class', true);
- // add new classes to the url (without overwriting existing once)
- $options = $url->getOptions();
- if(isset($options['attributes']) && $attributes = $options['attributes']){
- if(isset($attributes['class']) && $classes = $attributes['class']){
- $attributes['class'] += $new_classes;
- }else{
- $attributes['class'] = $new_classes;
- }
- }else{
- $attributes = array(
- "class" => $new_classes
- );
- }
- $url->setOption('attributes', $attributes);
- // update the url of the link
- $link->setUrl($url);
- // overwrite the output
- $variables['output'] = $link->toRenderable();
- }
- }
- }
- function popsu_preprocess_block__entity_field(&$variables){
- $field = &$variables['content']['field'];
- $items = &$field['#items'];
- if ($field['#field_type'] === "entity_reference_revisions") {
- $entity = $items->first()->get('entity');
- $entityAdapter = $entity->getTarget();
- $referencedEntity = $entityAdapter->getValue();
- $field_definitions = $referencedEntity->getFieldDefinitions();
- $all_empty = TRUE;
- foreach ($field_definitions as $field_name => $definition) {
- if (!method_exists($definition, 'isBaseField')) {
- $field_instance = $referencedEntity->get($field_name);
- if (!$field_instance->isEmpty()) {
- $all_empty = FALSE;
- }
- }
- }
- if ($all_empty) {
- $variables['isEmpty'] = true;
- }
- }
- }
|