Skip to main content

How to create a custom module in Drupal8 PSR-4? (Hello world module in Drupal 8)

Steps to create a custom module in Drupal8. 

Step 1: File Structure.
  In Drupal8 we should keep the Custom module or contributed modules under modules folder on the root directory.

  modules/contrib/
  modules/custom/

  Note:- multisite configuration
        sites/your_site_name/modules/

  Here we have file structure, "modules/custom/example".

Step 2: Creating .info.yml 
  In Drupal8 .info files changes to .info.yml
  Here we have, example.info.yml

Step 3: Creating .routing.yml 
  Before registering the hook_menu we have to write the path in  .routing.yml file.
  In Drupal 8 we won’t need hook_menu() anymore as we make heavy use of the Symfony2 components to handle the routing. This involves defining the     routes as configuration and handling the callback in a controller (the method of a Controller class).
  Here the example.routing.yml

Step 4: Creating Route Controller Class
  We have to create our ModuleController.php according to the PSR-4 naming standard [https://www.drupal.org/node/2156625].
  Here we have file structure, "modules/custom/example/src/Controller/ExampleController.php".
ExampleController.php

Step 5: Creating .module with hook_menu()
  In Drupal 8 hook_menu() function  we have two conditions to follow.
    (1)The paths need to match with path given in ".routing.yml" exactly.
    (2)Should match the name of the route.
Here is the example.module

Finally you can go to "mypage/page", and see the "Hello world is getting printed".
Click on Download-module to download the example module in drupal 8

Comments

Popular posts from this blog

How to configure Drupal7, varnish, authcache2 and ESI in Nginx server?

This is step by step procedure for, how to configure the authcache, varnih and ESI for the drupal7 project in NGINX erver. To configuring the Nginx Server use the procedure from document " http://www.geoffstratton.com/2014/03/nginx-php-fpm-apc-ssl-drupal/ " Well, make sure your nginx server is up and running. 1.Configuring the Authcache module.      Download the module from https://www.drupal.org/project/authcache    Enable only the authcache module    Go to admin/reports/status , then you can see the Authcache area is red and saying that there is no back end has been configured.   2.Configure Varnish on the back-end[nginx server].     Using the Following commands,       $ curl http://repo.varnish-cache.org/debian/GPG-key.txt | sudo apt-key add -     $ echo "deb http://repo.varnish-cache.org/ubuntu/ precise varnish-3.0" | sudo tee -a /etc/apt/sources.list     $ sudo apt-get update ...

How to create the Popup or modal in Drupal 8?

The following code will help you to create the popup in Drupal 8.  use \ Drupal \ Core \ Ajax ; function testingPopup () { $response = new AjaxResponse (); $title = $this -> t ( 'Title for the Popup.' ); $form [ '#attached' ][ 'library' ][] = 'core/drupal.dialog.ajax' ; $response -> setAttachments ( $form [ '#attached' ]); $content = '<div class="test-popup-content">' . 'Content in HTML format' . '</div>' ; $options = array ( 'dialogClass' => 'popup-dialog-class' , 'width' => '75%' , ); $modal = new OpenModalDialogCommand ( $title , $content , $options ); $response -> addCommand ( $modal ); return $response ; } You can call the function testingPopup() , you will get the popup.

Drupal Views exposed filter of Node title as drop down.

It can be done through using "Jump menu" settings in views. Download the Ctools module  http://drupal.org/project/ctools  Enable the Chaos Tools Module. This module provides a Views Style Plugin called "Jump Menu" Create a view of type node with two fields Content:nid and Cotent:title. And the path of the views page is like 'my_node_list'. For the Content:nid make sure you click on  Rewrite the output of the field . The rewritten output of the field should be  my_node_list/[nid]. Make sure you select the  exclude from display  checkbox. In the settings for  Style  in the view, select the  Jump Menu  style. Click on the settings for the style. Make sure the  Path  dropdown has 'Content:nid' choosen. Add a block display to the view. Name the block "Node details" and put the contextual filter to filter with nid. Save the view Go to block configuration under structure and configure the above block (Node details)....