Headless Drupal এবং Front-end Frameworks (React, Vue) এর সাথে ইন্টিগ্রেশন

Drupal এর RESTful API এবং Headless Drupal - ড্রুপাল (Drupal) - Web Development

232

ড্রুপাল (Drupal) একটি শক্তিশালী কনটেন্ট ম্যানেজমেন্ট সিস্টেম (CMS) যা headless CMS হিসেবে ব্যবহৃত হতে পারে। Headless Drupal হল এমন একটি কনফিগারেশন যেখানে ড্রুপাল কনটেন্ট ব্যবস্থাপনা এবং ব্যাকএন্ডের কাজ করে, এবং ফ্রন্টএন্ডের জন্য আপনি পৃথক একটি ফ্রন্টএন্ড ফ্রেমওয়ার্ক ব্যবহার করেন, যেমন React বা Vue.js। এই ইন্টিগ্রেশন মাধ্যমে আপনি আরও গতিশীল, দ্রুত, এবং ইন্টারঅ্যাকটিভ ওয়েব অ্যাপ্লিকেশন তৈরি করতে পারেন।

এখানে আমরা ড্রুপালকে headless CMS হিসেবে ব্যবহার করে React এবং Vue.js এর সাথে ইন্টিগ্রেশন করার পদ্ধতি আলোচনা করবো।


১. Headless Drupal কী?

Headless Drupal হল ড্রুপাল সিস্টেম যেখানে কনটেন্ট ম্যানেজমেন্ট ব্যাকএন্ড হিসেবে কাজ করে, তবে ফ্রন্টএন্ডের জন্য ড্রুপাল নিজে কোনো HTML বা UI প্রদান করে না। এর পরিবর্তে, ড্রুপাল RESTful API, GraphQL অথবা JSON:API এর মাধ্যমে কনটেন্ট প্রদান করে, যা ফ্রন্টএন্ড অ্যাপ্লিকেশন দ্বারা ব্যবহার করা যায়।

অর্থাৎ, ড্রুপাল কেবল কনটেন্ট ম্যানেজার হিসেবে কাজ করে এবং আপনার কাস্টম ফ্রন্টএন্ড ফ্রেমওয়ার্ক (যেমন React, Vue) কনটেন্ট প্রদর্শন এবং ইন্টারফেস পরিচালনা করে।


২. React এবং Vue.js এর সাথে Headless Drupal ইন্টিগ্রেশন

ড্রুপালকে headless CMS হিসেবে ব্যবহার করে আপনি কাস্টম React বা Vue.js অ্যাপ্লিকেশন তৈরি করতে পারেন। এই ফ্রন্টএন্ড ফ্রেমওয়ার্কগুলি ড্রুপালের কনটেন্ট API এর মাধ্যমে ডেটা গ্রহণ করে এবং তা ব্যবহারকারীদের কাছে প্রদর্শন করে।

প্রথম পদক্ষেপ: Headless Drupal কনফিগারেশন

  1. JSON:API অথবা GraphQL ইনস্টল করা:
    ড্রুপাল API দিয়ে কনটেন্ট পেতে JSON:API অথবা GraphQL মডিউল ইনস্টল করা প্রয়োজন।
    • JSON:API মডিউল ইনস্টল করতে:

      composer require drupal/jsonapi
      

      মডিউলটি সক্রিয় করতে:

      drush en jsonapi
      
    • GraphQL মডিউল ইনস্টল করতে:

      composer require drupal/graphql
      

      মডিউলটি সক্রিয় করতে:

      drush en graphql
      
  2. API রেসপন্স কনফিগারেশন:
    JSON:API অথবা GraphQL এর মাধ্যমে ড্রুপাল API রেসপন্স কনফিগার করুন। উদাহরণস্বরূপ, JSON:API দিয়ে ড্রুপাল থেকে কনটেন্ট ফেচ করতে:

    https://yourdomain.com/jsonapi/node/article
    
  3. CORS কনফিগারেশন:
    CORS (Cross-Origin Resource Sharing) কনফিগার করতে ড্রুপালে CORS সাপোর্ট সক্ষম করুন যাতে React বা Vue অ্যাপ্লিকেশন ড্রুপাল API থেকে ডেটা রিকোয়েস্ট করতে পারে।

    settings.php ফাইলে CORS কনফিগার করুন:

    $settings['trusted_host_patterns'] = array(
      '^yourdomain\.com$',
      '^localhost$',
    );
    

৩. React অথবা Vue.js এর সাথে ড্রুপালের ইন্টিগ্রেশন

React এবং JSON:API ইন্টিগ্রেশন

  1. React অ্যাপ্লিকেশন তৈরি করুন:
    আপনি React অ্যাপ্লিকেশন তৈরি করতে পারেন Create React App দিয়ে:

    npx create-react-app my-drupal-app
    cd my-drupal-app
    
  2. API কল করতে React ফ্রন্টএন্ডে Fetch ব্যবহার করুন:
    React অ্যাপ্লিকেশন থেকে ড্রুপালের JSON:API এ রিকোয়েস্ট পাঠাতে আপনি fetch() বা কোনো API ক্লায়েন্ট লাইব্রেরি (যেমন Axios) ব্যবহার করতে পারেন। উদাহরণস্বরূপ:

    import React, { useEffect, useState } from 'react';
    
    const App = () => {
      const [articles, setArticles] = useState([]);
    
      useEffect(() => {
        fetch('https://yourdomain.com/jsonapi/node/article')
          .then(response => response.json())
          .then(data => setArticles(data.data));
      }, []);
    
      return (
        <div>
          <h1>Articles</h1>
          <ul>
            {articles.map(article => (
              <li key={article.id}>{article.attributes.title}</li>
            ))}
          </ul>
        </div>
      );
    };
    
    export default App;
    
  3. React অ্যাপ্লিকেশন রান করুন:

    npm start
    

Vue.js এবং JSON:API ইন্টিগ্রেশন

  1. Vue.js অ্যাপ্লিকেশন তৈরি করুন:
    Vue অ্যাপ্লিকেশন তৈরি করতে Vue CLI ব্যবহার করুন:

    vue create my-drupal-vue
    cd my-drupal-vue
    
  2. API কল করতে Vue.js এ Axios ব্যবহার করুন:
    Axios লাইব্রেরি ব্যবহার করে Vue.js অ্যাপ্লিকেশন থেকে ড্রুপালের JSON:API রিকোয়েস্ট করুন:

    npm install axios
    

    এরপর App.vue ফাইলে API কল করুন:

    <template>
      <div>
        <h1>Articles</h1>
        <ul>
          <li v-for="article in articles" :key="article.id">{{ article.attributes.title }}</li>
        </ul>
      </div>
    </template>
    
    <script>
    import axios from 'axios';
    
    export default {
      data() {
        return {
          articles: [],
        };
      },
      mounted() {
        axios
          .get('https://yourdomain.com/jsonapi/node/article')
          .then(response => {
            this.articles = response.data.data;
          })
          .catch(error => {
            console.log(error);
          });
      },
    };
    </script>
    
  3. Vue অ্যাপ্লিকেশন রান করুন:

    npm run serve
    

৪. Headless Drupal এবং React/Vue এর সুবিধা

  • ফাস্ট লোডিং: React এবং Vue.js ফ্রেমওয়ার্কগুলি খুবই দ্রুত এবং সাইটের লোডিং টাইম কমাতে সাহায্য করে। কনটেন্ট ডায়নামিকভাবে লোড হয়।
  • এটি একাধিক ডিভাইসে কাজ করে: আপনার অ্যাপ্লিকেশনকে মোবাইল, ট্যাবলেট বা ডেস্কটপের জন্য কাস্টমাইজ করার সুযোগ দেয়।
  • প্লাগ-এন্ড-প্লে উন্নয়ন: ড্রুপাল এবং React/Vue এর মিথস্ক্রিয়া খুব সহজে করা যায়, যা দ্রুত উন্নয়ন এবং কাস্টমাইজেশন সম্ভব করে।

উপসংহার

Headless Drupal এবং React/Vue.js এর ইন্টিগ্রেশন আপনাকে একটি অত্যন্ত গতিশীল এবং ফাস্ট ওয়েব অ্যাপ্লিকেশন তৈরি করার সুবিধা দেয়। ড্রুপাল API ব্যবহার করে আপনি কনটেন্ট পরিচালনা করতে পারেন, এবং React বা Vue.js ফ্রন্টএন্ডে সেই কনটেন্ট ইন্টারঅ্যাকটিভভাবে প্রদর্শন করতে পারবেন। এই ধরনের ইন্টিগ্রেশন আপনাকে মডুলার আর্কিটেকচারের সুবিধা দেয়, যেখানে ব্যাকএন্ড এবং ফ্রন্টএন্ড আলাদা থাকলেও তারা একে অপরের সাথে যোগাযোগ করতে পারে।

Content added By
Promotion

Are you sure to start over?

Loading...