# ইভেন্ট ব্যবহার করে একটি গেম তৈরি করা আপনি কি কখনো ভেবেছেন কীভাবে ওয়েবসাইটগুলো জানে আপনি কখন একটি বোতাম ক্লিক করেন বা একটি টেক্সট বক্সে টাইপ করেন? এটি ইভেন্ট-চালিত প্রোগ্রামিংয়ের জাদু! এই গুরুত্বপূর্ণ দক্ষতা শেখার জন্য একটি টাইপিং স্পিড গেম তৈরি করার চেয়ে ভালো উপায় আর কী হতে পারে, যা আপনার প্রতিটি কীস্ট্রোকে প্রতিক্রিয়া জানায়। আপনি সরাসরি দেখতে পাবেন কীভাবে ওয়েব ব্রাউজার আপনার জাভাস্ক্রিপ্ট কোডের সাথে "কথা বলে"। আপনি যখন ক্লিক করেন, টাইপ করেন বা মাউস সরান, ব্রাউজার ছোট ছোট বার্তা (আমরা এগুলোকে ইভেন্ট বলি) আপনার কোডে পাঠায়, এবং আপনি সিদ্ধান্ত নেন কীভাবে প্রতিক্রিয়া জানাবেন! আমরা যখন শেষ করব, তখন আপনার একটি বাস্তব টাইপিং গেম থাকবে যা আপনার গতি এবং নির্ভুলতা ট্র্যাক করবে। আরও গুরুত্বপূর্ণ, আপনি সেই মৌলিক ধারণাগুলো বুঝতে পারবেন যা আপনি কখনো ব্যবহার করেছেন এমন প্রতিটি ইন্টারেক্টিভ ওয়েবসাইটকে চালিত করে। চলুন শুরু করি! ## প্রি-লেকচার কুইজ [প্রি-লেকচার কুইজ](https://ff-quizzes.netlify.app/web/quiz/21) ## ইভেন্ট-চালিত প্রোগ্রামিং আপনার প্রিয় অ্যাপ বা ওয়েবসাইট সম্পর্কে ভাবুন - কী এটিকে জীবন্ত এবং প্রতিক্রিয়াশীল মনে করে? এটি সবই নির্ভর করে এটি আপনার কাজের প্রতি কীভাবে প্রতিক্রিয়া জানায়! প্রতিটি ট্যাপ, ক্লিক, সোয়াইপ বা কীস্ট্রোক তৈরি করে একটি "ইভেন্ট", এবং এখানেই ওয়েব ডেভেলপমেন্টের আসল জাদু ঘটে। ওয়েবের জন্য প্রোগ্রামিংকে এত আকর্ষণীয় করে তোলে কী? আমরা কখনই জানি না কেউ কখন সেই বোতামটি ক্লিক করবে বা একটি টেক্সট বক্সে টাইপ করা শুরু করবে। তারা হয়তো সঙ্গে সঙ্গে ক্লিক করতে পারে, পাঁচ মিনিট অপেক্ষা করতে পারে, অথবা হয়তো কখনোই ক্লিক করবে না! এই অনিশ্চয়তা মানে আমাদের কোড লেখার বিষয়ে ভিন্নভাবে চিন্তা করতে হবে। রেসিপির মতো উপরে থেকে নিচে কোড লেখার পরিবর্তে, আমরা কোড লিখি যা ধৈর্য ধরে অপেক্ষা করে কিছু ঘটার জন্য। এটি অনেকটা ১৮০০ সালের টেলিগ্রাফ অপারেটরদের মতো যারা তাদের মেশিনের পাশে বসে থাকত, তারের মাধ্যমে একটি বার্তা আসার মুহূর্তে প্রতিক্রিয়া জানাতে প্রস্তুত। তাহলে ঠিক কী একটি "ইভেন্ট"? সহজভাবে বলতে গেলে, এটি এমন কিছু যা ঘটে! আপনি যখন একটি বোতাম ক্লিক করেন - এটি একটি ইভেন্ট। আপনি যখন একটি অক্ষর টাইপ করেন - এটি একটি ইভেন্ট। আপনি যখন আপনার মাউস সরান - এটি আরেকটি ইভেন্ট। ইভেন্ট-চালিত প্রোগ্রামিং আমাদের কোডকে শোনার এবং প্রতিক্রিয়া জানানোর জন্য সেট আপ করতে দেয়। আমরা বিশেষ ফাংশন তৈরি করি যেগুলোকে **ইভেন্ট লিসনার** বলা হয়, যা নির্দিষ্ট কিছু ঘটার জন্য ধৈর্য ধরে অপেক্ষা করে, তারপর তা ঘটলে সক্রিয় হয়। ইভেন্ট লিসনারকে আপনার কোডের জন্য একটি ডোরবেলের মতো ভাবুন। আপনি ডোরবেল সেট আপ করেন (`addEventListener()`), এটি কী শব্দ শুনবে তা জানান (যেমন 'ক্লিক' বা 'keypress'), এবং কেউ এটি বাজালে কী ঘটবে তা নির্দিষ্ট করেন (আপনার কাস্টম ফাংশন)। **ইভেন্ট লিসনার কীভাবে কাজ করে:** - **শোনে** নির্দিষ্ট ব্যবহারকারীর কাজ যেমন ক্লিক, কীস্ট্রোক বা মাউস মুভমেন্ট - **নির্বাহ করে** নির্দিষ্ট ইভেন্ট ঘটলে আপনার কাস্টম কোড - **প্রতিক্রিয়া জানায়** ব্যবহারকারীর ইন্টারঅ্যাকশনের প্রতি, একটি নিরবচ্ছিন্ন অভিজ্ঞতা তৈরি করে - **একাধিক ইভেন্ট পরিচালনা করে** একই উপাদানে বিভিন্ন লিসনার ব্যবহার করে > **NOTE:** উল্লেখ করার মতো বিষয় হলো, ইভেন্ট লিসনার তৈরি করার অনেক উপায় রয়েছে। আপনি অ্যানোনিমাস ফাংশন ব্যবহার করতে পারেন, অথবা নামযুক্ত ফাংশন তৈরি করতে পারেন। আপনি বিভিন্ন শর্টকাট ব্যবহার করতে পারেন, যেমন `click` প্রপার্টি সেট করা, অথবা `addEventListener()` ব্যবহার করা। আমাদের অনুশীলনে আমরা `addEventListener()` এবং অ্যানোনিমাস ফাংশনের উপর ফোকাস করব, কারণ এটি সম্ভবত ওয়েব ডেভেলপাররা সবচেয়ে বেশি ব্যবহার করে। এটি সবচেয়ে নমনীয়, কারণ `addEventListener()` সব ইভেন্টের জন্য কাজ করে এবং ইভেন্টের নাম একটি প্যারামিটার হিসেবে প্রদান করা যেতে পারে। ### সাধারণ ইভেন্ট যদিও ওয়েব ব্রাউজারগুলো আপনাকে শোনার জন্য ডজন ডজন বিভিন্ন ইভেন্ট অফার করে, বেশিরভাগ ইন্টারেক্টিভ অ্যাপ্লিকেশন শুধুমাত্র কয়েকটি প্রয়োজনীয় ইভেন্টের উপর নির্ভর করে। এই মূল ইভেন্টগুলো বোঝা আপনাকে জটিল ব্যবহারকারী ইন্টারঅ্যাকশন তৈরি করার ভিত্তি দেবে। যখন একটি অ্যাপ্লিকেশন তৈরি করা হয় তখন [ডজন ডজন ইভেন্ট](https://developer.mozilla.org/docs/Web/Events) উপলব্ধ থাকে যা আপনি শোনার জন্য ব্যবহার করতে পারেন। মূলত ব্যবহারকারী একটি পৃষ্ঠায় যা কিছু করে তা একটি ইভেন্ট তৈরি করে, যা আপনাকে অনেক ক্ষমতা দেয় যাতে আপনি নিশ্চিত করতে পারেন তারা আপনার ইচ্ছামতো অভিজ্ঞতা পায়। সৌভাগ্যক্রমে, সাধারণত আপনার শুধুমাত্র কয়েকটি ইভেন্টের প্রয়োজন হয়। এখানে কয়েকটি সাধারণ ইভেন্ট রয়েছে (যার মধ্যে দুটি আমরা আমাদের গেম তৈরি করার সময় ব্যবহার করব): | ইভেন্ট | বিবরণ | সাধারণ ব্যবহার | |--------|-------|----------------| | `click` | ব্যবহারকারী কিছু ক্লিক করেছে | বোতাম, লিঙ্ক, ইন্টারেক্টিভ উপাদান | | `contextmenu` | ব্যবহারকারী ডান মাউস বোতাম ক্লিক করেছে | কাস্টম রাইট-ক্লিক মেনু | | `select` | ব্যবহারকারী কিছু টেক্সট হাইলাইট করেছে | টেক্সট এডিটিং, কপি অপারেশন | | `input` | ব্যবহারকারী কিছু টেক্সট ইনপুট করেছে | ফর্ম যাচাই, রিয়েল-টাইম সার্চ | **এই ইভেন্ট টাইপগুলো বোঝা:** - **ট্রিগার করে** যখন ব্যবহারকারীরা আপনার পৃষ্ঠার নির্দিষ্ট উপাদানগুলোর সাথে ইন্টারঅ্যাক্ট করে - **বিস্তারিত তথ্য প্রদান করে** ব্যবহারকারীর কাজ সম্পর্কে ইভেন্ট অবজেক্টের মাধ্যমে - **সক্ষম করে** আপনাকে প্রতিক্রিয়াশীল, ইন্টারেক্টিভ ওয়েব অ্যাপ্লিকেশন তৈরি করতে - **সামঞ্জস্যপূর্ণভাবে কাজ করে** বিভিন্ন ব্রাউজার এবং ডিভাইসে ## গেম তৈরি করা এখন যেহেতু আপনি ইভেন্টগুলো কীভাবে কাজ করে তা বুঝতে পেরেছেন, চলুন সেই জ্ঞান ব্যবহার করে কিছু দরকারী তৈরি করি। আমরা একটি টাইপিং স্পিড গেম তৈরি করব যা ইভেন্ট হ্যান্ডলিং প্রদর্শন করবে এবং আপনাকে একটি গুরুত্বপূর্ণ ডেভেলপার দক্ষতা বিকাশে সাহায্য করবে। আমরা একটি গেম তৈরি করতে যাচ্ছি যাতে জাভাস্ক্রিপ্টে ইভেন্টগুলো কীভাবে কাজ করে তা অন্বেষণ করা যায়। আমাদের গেম একটি প্লেয়ারের টাইপিং দক্ষতা পরীক্ষা করবে, যা সমস্ত ডেভেলপারদের জন্য একটি অত্যন্ত গুরুত্বপূর্ণ দক্ষতা। মজার তথ্য: আমরা আজ যে QWERTY কীবোর্ড লেআউট ব্যবহার করি তা আসলে ১৮৭০-এর দশকে টাইপরাইটারের জন্য ডিজাইন করা হয়েছিল - এবং ভালো টাইপিং দক্ষতা আজও প্রোগ্রামারদের জন্য ঠিক ততটাই মূল্যবান! গেমের সাধারণ প্রবাহটি এরকম হবে: ```mermaid flowchart TD A[Player clicks Start] --> B[Random quote displays] B --> C[Player types in textbox] C --> D{Word complete?} D -->|Yes| E[Highlight next word] D -->|No| F{Correct so far?} F -->|Yes| G[Keep normal styling] F -->|No| H[Show error styling] E --> I{Quote complete?} I -->|No| C I -->|Yes| J[Show success message with time] G --> C H --> C ``` **আমাদের গেম কীভাবে কাজ করবে:** - **শুরু হবে** যখন প্লেয়ার স্টার্ট বোতাম ক্লিক করবে এবং একটি র‍্যান্ডম কোট প্রদর্শন করবে - **ট্র্যাক করবে** প্লেয়ারের টাইপিং অগ্রগতি শব্দ ধরে ধরে রিয়েল-টাইমে - **হাইলাইট করবে** বর্তমান শব্দটি যাতে প্লেয়ারের ফোকাস বজায় থাকে - **তাৎক্ষণিক ভিজ্যুয়াল ফিডব্যাক দেবে** টাইপিং ত্রুটির জন্য - **গণনা করবে** এবং মোট সময় প্রদর্শন করবে যখন কোটটি সম্পন্ন হবে চলুন আমাদের গেম তৈরি করি এবং ইভেন্ট সম্পর্কে শিখি! ### ফাইল স্ট্রাকচার কোডিং শুরু করার আগে, চলুন সংগঠিত হই! শুরু থেকেই একটি পরিষ্কার ফাইল স্ট্রাকচার থাকা ভবিষ্যতে আপনাকে অনেক ঝামেলা থেকে বাঁচাবে এবং আপনার প্রকল্পকে আরও পেশাদার করে তুলবে। 😊 আমরা এটি সহজ রাখব, মাত্র তিনটি ফাইল দিয়ে: `index.html` আমাদের পৃষ্ঠার কাঠামোর জন্য, `script.js` আমাদের গেমের সমস্ত লজিকের জন্য এবং `style.css` সবকিছু সুন্দর দেখানোর জন্য। এটি সেই ক্লাসিক ত্রয়ী যা বেশিরভাগ ওয়েবকে চালিত করে! **একটি নতুন ফোল্ডার তৈরি করুন আপনার কাজের জন্য। কনসোল বা টার্মিনাল উইন্ডো খুলুন এবং নিম্নলিখিত কমান্ডটি দিন:** ```bash # Linux or macOS mkdir typing-game && cd typing-game # Windows md typing-game && cd typing-game ``` **এই কমান্ডগুলো কী করে:** - **একটি নতুন ডিরেক্টরি তৈরি করে** যার নাম `typing-game` যেখানে আপনার প্রকল্প ফাইলগুলো থাকবে - **নতুন তৈরি ডিরেক্টরিতে প্রবেশ করে** স্বয়ংক্রিয়ভাবে - **একটি পরিষ্কার কাজের পরিবেশ সেট আপ করে** আপনার গেম ডেভেলপমেন্টের জন্য **ভিজ্যুয়াল স্টুডিও কোড খুলুন:** ```bash code . ``` **এই কমান্ডটি:** - **ভিজ্যুয়াল স্টুডিও কোড চালু করে** বর্তমান ডিরেক্টরিতে - **আপনার প্রকল্প ফোল্ডারটি খুলে** এডিটরে - **আপনাকে সমস্ত ডেভেলপমেন্ট টুলে অ্যাক্সেস দেয়** যা আপনার প্রয়োজন **ভিজ্যুয়াল স্টুডিও কোডে ফোল্ডারে তিনটি ফাইল যোগ করুন নিম্নলিখিত নাম দিয়ে:** - `index.html` - আপনার গেমের কাঠামো এবং বিষয়বস্তু ধারণ করে - `script.js` - সমস্ত গেম লজিক এবং ইভেন্ট লিসনার পরিচালনা করে - `style.css` - ভিজ্যুয়াল চেহারা এবং স্টাইলিং সংজ্ঞায়িত করে ## ব্যবহারকারী ইন্টারফেস তৈরি করা এখন চলুন সেই মঞ্চ তৈরি করি যেখানে আমাদের গেমের সমস্ত অ্যাকশন ঘটবে! এটি অনেকটা একটি স্পেসশিপের কন্ট্রোল প্যানেল ডিজাইন করার মতো - আমাদের নিশ্চিত করতে হবে যে আমাদের প্লেয়ারদের যা প্রয়োজন তা ঠিক যেখানে তারা আশা করে। চলুন দেখি আমাদের গেমের জন্য আসলে কী কী প্রয়োজন। আপনি যদি একটি টাইপিং গেম খেলতেন, তাহলে আপনি স্ক্রিনে কী দেখতে চাইতেন? এখানে যা যা দরকার: | UI উপাদান | উদ্দেশ্য | HTML উপাদান | |-----------|----------|-------------| | কোট ডিসপ্লে | টাইপ করার টেক্সট দেখায় | `

` যার `id="quote"` | | মেসেজ এরিয়া | স্ট্যাটাস এবং সাফল্যের বার্তা দেখায় | `

` যার `id="message"` | | টেক্সট ইনপুট | যেখানে প্লেয়াররা কোট টাইপ করে | `` যার `id="typed-value"` | | স্টার্ট বোতাম | গেম শুরু করে | ` ``` **এই HTML স্ট্রাকচার কী অর্জন করে তা বিশ্লেষণ:** - **CSS স্টাইলশিট লিঙ্ক করে** ``-এ স্টাইলিংয়ের জন্য - **ব্যবহারকারীদের জন্য একটি পরিষ্কার হেডিং এবং নির্দেশনা তৈরি করে** - **ডাইনামিক কন্টেন্টের জন্য নির্দিষ্ট আইডি সহ প্লেসহোল্ডার প্যারাগ্রাফ স্থাপন করে** - **অ্যাক্সেসিবিলিটি অ্যাট্রিবিউট সহ একটি ইনপুট ফিল্ড অন্তর্ভুক্ত করে** - **গেম ট্রিগার করার জন্য একটি স্টার্ট বোতাম প্রদান করে** - **অপটিমাল পারফরম্যান্সের জন্য শেষে জাভাস্ক্রিপ্ট ফাইল লোড করে** ### অ্যাপ্লিকেশন চালু করা ডেভেলপমেন্টের সময় আপনার অ্যাপ্লিকেশন ঘন ঘন পরীক্ষা করা আপনাকে ত্রুটি দ্রুত ধরতে এবং রিয়েল-টাইমে আপনার অগ্রগতি দেখতে সাহায্য করে। লাইভ সার্ভার একটি অমূল্য টুল যা আপনি ফাইল সেভ করার সময় স্বয়ংক্রিয়ভাবে আপনার ব্রাউজার রিফ্রেশ করে, ডেভেলপমেন্টকে অনেক বেশি কার্যকর করে তোলে। এটি সর্বদা পুনরাবৃত্তিমূলকভাবে বিকাশ করা সেরা যাতে জিনিসগুলো দেখতে কেমন তা দেখা যায়। চলুন আমাদের অ্যাপ্লিকেশন চালু করি। ভিজ্যুয়াল স্টুডিও কোডের জন্য একটি চমৎকার এক্সটেনশন রয়েছে [লাইভ সার্ভার](https://marketplace.visualstudio.com/items?itemName=ritwickdey.LiveServer&WT.mc_id=academic-77807-sagibbon) যা আপনার অ্যাপ্লিকেশনটি লোকালভাবে হোস্ট করবে এবং আপনি ফাইল সেভ করার সময় ব্রাউজার রিফ্রেশ করবে। **[লাইভ সার্ভার](https://marketplace.visualstudio.com/items?itemName=ritwickdey.LiveServer&WT.mc_id=academic-77807-sagibbon) ইনস্টল করুন লিঙ্কটি অনুসরণ করে এবং ইনস্টল ক্লিক করুন:** **ইনস্টলেশনের সময় যা ঘটে:** - **আপনার ব্রাউজারকে ভিজ্যুয়াল স্টুডিও কোড খুলতে প্রম্পট করে** - **এক্সটেনশন ইনস্টলেশন প্রক্রিয়ার মাধ্যমে আপনাকে গাইড করে** - **সম্পূর্ণ সেটআপের জন্য ভিজ্যুয়াল স্টুডিও কোড পুনরায় চালু করার প্রয়োজন হতে পারে** **ইনস্টল হয়ে গেলে, ভিজ্যুয়াল স্টুডিও কোডে Ctrl-Shift-P (অথবা Cmd-Shift-P) ক্লিক করুন কমান্ড প্যালেট খুলতে:** **কমান্ড প্যালেট বোঝা:** - **ভিজ্যুয়াল স্টুডিও কোডের সমস্ত কমান্ডে দ্রুত অ্যাক্সেস প্রদান করে** - **আপনার টাইপ করার সময় কমান্ডগুলো অনুসন্ধান করে** - **দ্রুত ডেভেলপমেন্টের জন্য কীবোর্ড শর্টকাট অফার করে** **"Live Server: Open with Live Server" টাইপ করুন:** **লাইভ সার্ভার কী করে:** - **আপনার প্রকল্পের জন্য একটি লোকাল ডেভেলপমেন্ট সার্ভার শুরু করে** - **আপনি ফাইল সেভ করলে স্বয়ংক্রিয়ভাবে ব্রাউজার রিফ্রেশ করে** - **আপনার ফাইলগুলো একটি লোকাল URL থেকে সরবরাহ করে (সাধারণত `localhost:5500`)** **একটি ব্রাউজার খুলুন এবং `https://localhost:5500`-এ যান:** আপনি এখন আপনার তৈরি করা পৃষ্ঠাটি দেখতে পাবেন! চলুন কিছু কার্যকারিতা যোগ করি। ## CSS যোগ করা এখন চলুন জিনিসগুলো সুন্দর করে তুলি! ভিজ্যুয়াল ফিডব্যাক ব্যবহারকারী ইন্টারফেসের জন্য কম্পিউটিংয়ের শুরুর দিনগুলো থেকে গুরুত্বপূর্ণ ছিল। ১৯৮০-এর দশকে গবেষকরা আবিষ্কার করেছিলেন যে তাৎক্ষণিক ভিজ্যুয়াল ফিডব্যাক ব্যবহারকারীর পারফরম্যান্সকে নাটকীয়ভাবে উন্নত করে এবং ত্রুটি কমায়। ঠিক সেটাই আমরা তৈরি করতে যাচ্ছি। আমাদের গেমটি কী ঘটছে তা স্পষ্টভাবে দেখাতে হবে। প্লেয়ারদের সঙ্গে সঙ্গে জানা উচিত তারা কোন শব্দটি টাইপ করতে যাচ্ছে, এবং যদি তারা কোনো ভুল করে, তাহলে তা সঙ্গে সঙ্গে দেখতে পাওয়া উচিত। চলুন কিছু সহজ কিন্তু কার্যকর স্টাইলিং তৈরি করি: একটি নতুন ফাইল তৈরি করুন যার নাম `style.css` এবং নিম্নলিখিত সিনট্যাক্স যোগ করুন। ```css /* inside style.css */ .highlight { background-color: yellow; } .error { background-color: lightcoral; border: red; } ``` **এই CSS ক্লাসগুলো বোঝা:** - **বর্তমান শব্দটি হাইলাইট করে** একটি হলুদ ব্যাকগ্রাউন্ড দিয়ে স্পষ্ট ভিজ্যুয়াল নির্দেশনা প্রদান করে - **টাইপিং ত্রুটি নির্দেশ করে** একটি লাইট কোরাল ব্যাকগ্রাউন্ড রঙ দিয়ে - **তাৎক্ষণিক ফিডব্যাক প্রদান করে** ব্যবহারকারীর টাইপিং প্রব | উদ্ধৃতির অ্যারে | গেমের জন্য সমস্ত সম্ভাব্য উদ্ধৃতি সংরক্ষণ করুন | `['উদ্ধৃতি ১', 'উদ্ধৃতি ২', ...]` | | শব্দের অ্যারে | বর্তমান উদ্ধৃতিকে পৃথক শব্দে বিভক্ত করুন | `['যখন', 'তুমি', 'আছে', ...]` | | শব্দ সূচক | প্লেয়ার কোন শব্দ টাইপ করছে তা ট্র্যাক করুন | `0, 1, 2, 3...` | | শুরুর সময় | স্কোরিংয়ের জন্য সময় গণনা করুন | `Date.now()` | **আমাদের UI উপাদানগুলোর রেফারেন্সও প্রয়োজন হবে:** | উপাদান | ID | উদ্দেশ্য | |---------|----|---------| | টেক্সট ইনপুট | `typed-value` | যেখানে প্লেয়াররা টাইপ করবে | | উদ্ধৃতি প্রদর্শন | `quote` | টাইপ করার জন্য উদ্ধৃতি দেখায় | | বার্তা এলাকা | `message` | স্ট্যাটাস আপডেট দেখায় | ```javascript // inside script.js // all of our quotes const quotes = [ 'When you have eliminated the impossible, whatever remains, however improbable, must be the truth.', 'There is nothing more deceptive than an obvious fact.', 'I ought to know by this time that when a fact appears to be opposed to a long train of deductions it invariably proves to be capable of bearing some other interpretation.', 'I never make exceptions. An exception disproves the rule.', 'What one man can invent another can discover.', 'Nothing clears up a case so much as stating it to another person.', 'Education never ends, Watson. It is a series of lessons, with the greatest for the last.', ]; // store the list of words and the index of the word the player is currently typing let words = []; let wordIndex = 0; // the starting time let startTime = Date.now(); // page elements const quoteElement = document.getElementById('quote'); const messageElement = document.getElementById('message'); const typedValueElement = document.getElementById('typed-value'); ``` **এই সেটআপ কোডটি কী অর্জন করে তা বিশ্লেষণ করা যাক:** - **সংরক্ষণ করে** Sherlock Holmes-এর উদ্ধৃতির একটি অ্যারে `const` ব্যবহার করে, কারণ উদ্ধৃতিগুলো পরিবর্তন হবে না - **ট্র্যাকিং ভেরিয়েবলগুলো** `let` দিয়ে আরম্ভ করে, কারণ এই মানগুলো গেমপ্লের সময় আপডেট হবে - **DOM উপাদানগুলোর রেফারেন্স সংগ্রহ করে** `document.getElementById()` ব্যবহার করে কার্যকরী অ্যাক্সেসের জন্য - **গেমের সমস্ত কার্যকারিতার ভিত্তি স্থাপন করে** পরিষ্কার, বর্ণনামূলক ভেরিয়েবল নাম দিয়ে - **সম্পর্কিত ডেটা এবং উপাদানগুলোকে** সহজ কোড রক্ষণাবেক্ষণের জন্য যৌক্তিকভাবে সংগঠিত করে ✅ আপনার গেমে আরও উদ্ধৃতি যোগ করুন > 💡 **প্রো টিপ**: আমরা যখনই চাই তখন কোডে উপাদানগুলো পুনরুদ্ধার করতে পারি `document.getElementById()` ব্যবহার করে। যেহেতু আমরা নিয়মিত এই উপাদানগুলো উল্লেখ করব, তাই স্ট্রিং লিটারাল টাইপো এড়াতে আমরা কনস্ট্যান্ট ব্যবহার করব। [Vue.js](https://vuejs.org/) বা [React](https://reactjs.org/) এর মতো ফ্রেমওয়ার্কগুলো আপনার কোডকে কেন্দ্রীভূতভাবে পরিচালনা করতে সাহায্য করতে পারে। > **এই পদ্ধতিটি এত ভালোভাবে কাজ করার কারণ:** - **স্পেলিং ভুল প্রতিরোধ করে** যখন উপাদানগুলো একাধিকবার উল্লেখ করা হয় - **কোডের পাঠযোগ্যতা উন্নত করে** বর্ণনামূলক কনস্ট্যান্ট নাম দিয়ে - **ভালো IDE সাপোর্ট সক্ষম করে** অটোকমপ্লিট এবং ত্রুটি চেকিংয়ের মাধ্যমে - **রিফ্যাক্টরিং সহজ করে** যদি উপাদানের ID পরে পরিবর্তন হয় `const`, `let` এবং `var` ব্যবহারের উপর একটি ভিডিও দেখুন [![ভেরিয়েবলের প্রকার](https://img.youtube.com/vi/JNIXfGiDWM8/0.jpg)](https://youtube.com/watch?v=JNIXfGiDWM8 "ভেরিয়েবলের প্রকার") > 🎥 উপরের ছবিতে ক্লিক করুন ভেরিয়েবল সম্পর্কে একটি ভিডিও দেখতে। ### শুরু করার লজিক যোগ করুন এখানেই সবকিছু একসাথে ক্লিক করবে! 🚀 আপনি আপনার প্রথম ইভেন্ট লিসেনার লিখতে যাচ্ছেন, এবং এটি একটি বোতাম ক্লিকের প্রতিক্রিয়া দেখার মতো সন্তোষজনক কিছু। ভাবুন: কোথাও একজন প্লেয়ার "Start" বোতামে ক্লিক করতে যাচ্ছে, এবং আপনার কোডকে তাদের জন্য প্রস্তুত থাকতে হবে। আমরা জানি না তারা কখন ক্লিক করবে - তাৎক্ষণিক হতে পারে, অথবা কফি খাওয়ার পরে হতে পারে - কিন্তু যখন তারা করবে, তখন আপনার গেমটি জীবন্ত হয়ে উঠবে। যখন ব্যবহারকারী `start` ক্লিক করবে, তখন আমাদের একটি উদ্ধৃতি নির্বাচন করতে হবে, ইউজার ইন্টারফেস সেটআপ করতে হবে এবং বর্তমান শব্দ এবং টাইমিং ট্র্যাকিং সেটআপ করতে হবে। নিচে প্রয়োজনীয় JavaScript দেওয়া হলো; আমরা স্ক্রিপ্ট ব্লকের পরে এটি আলোচনা করব। ```javascript // at the end of script.js document.getElementById('start').addEventListener('click', () => { // get a quote const quoteIndex = Math.floor(Math.random() * quotes.length); const quote = quotes[quoteIndex]; // Put the quote into an array of words words = quote.split(' '); // reset the word index for tracking wordIndex = 0; // UI updates // Create an array of span elements so we can set a class const spanWords = words.map(function(word) { return `${word} `}); // Convert into string and set as innerHTML on quote display quoteElement.innerHTML = spanWords.join(''); // Highlight the first word quoteElement.childNodes[0].className = 'highlight'; // Clear any prior messages messageElement.innerText = ''; // Setup the textbox // Clear the textbox typedValueElement.value = ''; // set focus typedValueElement.focus(); // set the event handler // Start the timer startTime = new Date().getTime(); }); ``` **কোডকে যৌক্তিক বিভাগে বিভক্ত করে বিশ্লেষণ করা যাক:** **📊 শব্দ ট্র্যাকিং সেটআপ:** - **একটি র‍্যান্ডম উদ্ধৃতি নির্বাচন করে** `Math.floor()` এবং `Math.random()` ব্যবহার করে বৈচিত্র্যের জন্য - **উদ্ধৃতিকে পৃথক শব্দের অ্যারেতে রূপান্তর করে** `split(' ')` ব্যবহার করে - **`wordIndex` রিসেট করে** কারণ প্লেয়ার প্রথম শব্দ থেকে শুরু করে - **গেম স্টেট প্রস্তুত করে** একটি নতুন রাউন্ডের জন্য **🎨 UI সেটআপ এবং প্রদর্শন:** - **একটি `` উপাদানের অ্যারে তৈরি করে**, প্রতিটি শব্দকে পৃথক স্টাইলিংয়ের জন্য মোড়ানো - **স্প্যান উপাদানগুলোকে একটি স্ট্রিংয়ে যোগ করে** কার্যকরী DOM আপডেটের জন্য - **প্রথম শব্দটি হাইলাইট করে** `highlight` CSS ক্লাস যোগ করে - **আগের গেম বার্তাগুলো পরিষ্কার করে** একটি পরিষ্কার পাতা প্রদান করতে **⌨️ টেক্সটবক্স প্রস্তুতি:** - **ইনপুট ফিল্ডে বিদ্যমান টেক্সট পরিষ্কার করে** - **টেক্সটবক্সে ফোকাস সেট করে** যাতে প্লেয়াররা সাথে সাথে টাইপ শুরু করতে পারে - **নতুন গেম সেশনের জন্য ইনপুট এলাকা প্রস্তুত করে** **⏱️ টাইমার ইনিশিয়ালাইজেশন:** - **বর্তমান টাইমস্ট্যাম্প সংগ্রহ করে** `new Date().getTime()` ব্যবহার করে - **টাইপিং স্পিড এবং সম্পূর্ণ করার সময় সঠিকভাবে গণনা করতে সক্ষম করে** - **গেম সেশনের জন্য পারফরম্যান্স ট্র্যাকিং শুরু করে** ### টাইপিং লজিক যোগ করুন এখানে আমরা আমাদের গেমের মূল অংশটি মোকাবিলা করব! যদি এটি প্রথমে একটু বেশি মনে হয় তবে চিন্তা করবেন না - আমরা প্রতিটি অংশের মধ্য দিয়ে যাব, এবং শেষে আপনি দেখবেন এটি কতটা যৌক্তিক। আমরা এখানে যা তৈরি করছি তা বেশ উন্নত: কেউ যখন একটি অক্ষর টাইপ করে, আমাদের কোডটি যাচাই করবে তারা কী টাইপ করেছে, তাদের প্রতিক্রিয়া দেবে এবং পরবর্তী কী ঘটবে তা সিদ্ধান্ত নেবে। এটি অনেকটা ১৯৭০-এর দশকের প্রাথমিক ওয়ার্ড প্রসেসর যেমন WordStar-এর মতো, যা টাইপিস্টদের রিয়েল-টাইম ফিডব্যাক দিত। ```javascript // at the end of script.js typedValueElement.addEventListener('input', () => { // Get the current word const currentWord = words[wordIndex]; // get the current value const typedValue = typedValueElement.value; if (typedValue === currentWord && wordIndex === words.length - 1) { // end of sentence // Display success const elapsedTime = new Date().getTime() - startTime; const message = `CONGRATULATIONS! You finished in ${elapsedTime / 1000} seconds.`; messageElement.innerText = message; } else if (typedValue.endsWith(' ') && typedValue.trim() === currentWord) { // end of word // clear the typedValueElement for the new word typedValueElement.value = ''; // move to the next word wordIndex++; // reset the class name for all elements in quote for (const wordElement of quoteElement.childNodes) { wordElement.className = ''; } // highlight the new word quoteElement.childNodes[wordIndex].className = 'highlight'; } else if (currentWord.startsWith(typedValue)) { // currently correct // highlight the next word typedValueElement.className = ''; } else { // error state typedValueElement.className = 'error'; } }); ``` **টাইপিং লজিক প্রবাহ বুঝুন:** এই ফাংশনটি একটি ওয়াটারফল পদ্ধতি ব্যবহার করে, সবচেয়ে নির্দিষ্ট থেকে সবচেয়ে সাধারণ শর্তগুলো পরীক্ষা করে। প্রতিটি পরিস্থিতি বিশ্লেষণ করা যাক: ```mermaid flowchart TD A[Player types character] --> B[Get current word and typed value] B --> C{Quote complete?} C -->|Yes| D[Show completion message with time] C -->|No| E{Word complete with space?} E -->|Yes| F[Clear input, move to next word, update highlight] E -->|No| G{Typing correctly so far?} G -->|Yes| H[Remove error styling] G -->|No| I[Show error styling] ``` **🏁 উদ্ধৃতি সম্পূর্ণ (পরিস্থিতি ১):** - **যাচাই করে** টাইপ করা মান বর্তমান শব্দের সাথে মিলে এবং আমরা শেষ শব্দে আছি কিনা - **গণনা করে** শুরুর সময় থেকে বর্তমান সময় বাদ দিয়ে অতিবাহিত সময় - **মিলিসেকেন্ডকে সেকেন্ডে রূপান্তর করে** ১,০০০ দিয়ে ভাগ করে - **সম্পূর্ণ করার সময় সহ অভিনন্দন বার্তা প্রদর্শন করে** **✅ শব্দ সম্পূর্ণ (পরিস্থিতি ২):** - **শব্দ সম্পূর্ণ হওয়া সনাক্ত করে** যখন ইনপুটটি একটি স্পেস দিয়ে শেষ হয় - **যাচাই করে** যে ট্রিম করা ইনপুটটি বর্তমান শব্দের সাথে সঠিকভাবে মিলে - **ইনপুট ফিল্ড পরিষ্কার করে** পরবর্তী শব্দের জন্য - **পরবর্তী শব্দে অগ্রসর হয়** `wordIndex` ইনক্রিমেন্ট করে - **ভিজ্যুয়াল হাইলাইটিং আপডেট করে** সমস্ত ক্লাস সরিয়ে নতুন শব্দটি হাইলাইট করে **📝 টাইপিং চলমান (পরিস্থিতি ৩):** - **যাচাই করে** যে বর্তমান শব্দটি এখন পর্যন্ত টাইপ করা অংশ দিয়ে শুরু হয়েছে - **যেকোনো ত্রুটি স্টাইলিং সরিয়ে দেয়** দেখানোর জন্য যে ইনপুটটি সঠিক - **টাইপিং চালিয়ে যাওয়ার অনুমতি দেয়** কোনো বাধা ছাড়াই **❌ ত্রুটি অবস্থা (পরিস্থিতি ৪):** - **সক্রিয় করে** যখন টাইপ করা টেক্সট প্রত্যাশিত শব্দের শুরু অংশের সাথে মেলে না - **ত্রুটি CSS ক্লাস প্রয়োগ করে** তাৎক্ষণিক ভিজ্যুয়াল ফিডব্যাক প্রদান করতে - **প্লেয়ারদের দ্রুত ত্রুটি সনাক্ত এবং সংশোধন করতে সাহায্য করে** ## আপনার অ্যাপ্লিকেশন পরীক্ষা করুন দেখুন আপনি কী অর্জন করেছেন! 🎉 আপনি ইভেন্ট-চালিত প্রোগ্রামিং ব্যবহার করে স্ক্র্যাচ থেকে একটি বাস্তব, কার্যকরী টাইপিং গেম তৈরি করেছেন। এটি একটি ছোট অর্জন নয়! এখন পরীক্ষার সময়! এটি প্রত্যাশিতভাবে কাজ করবে? আমরা কি কিছু মিস করেছি? বিষয়টি হলো: যদি কিছু প্রথমে পুরোপুরি কাজ না করে, তবে এটি সম্পূর্ণ স্বাভাবিক। অভিজ্ঞ ডেভেলপাররাও নিয়মিত তাদের কোডে বাগ খুঁজে পান। এটি উন্নয়ন প্রক্রিয়ার অংশ! `start` ক্লিক করুন এবং টাইপ করা শুরু করুন! এটি আগের অ্যানিমেশনের মতো দেখতে হবে। ![গেমটি চলমান অবস্থার অ্যানিমেশন](../../../../4-typing-game/images/demo.gif) **আপনার অ্যাপ্লিকেশনে কী পরীক্ষা করবেন:** - **যাচাই করে** যে Start ক্লিক করলে একটি র‍্যান্ডম উদ্ধৃতি প্রদর্শিত হয় - **নিশ্চিত করে** যে টাইপিং বর্তমান শব্দটি সঠিকভাবে হাইলাইট করে - **পরীক্ষা করে** যে ভুল টাইপিংয়ের জন্য ত্রুটি স্টাইলিং প্রদর্শিত হয় - **নিশ্চিত করে** যে শব্দ সম্পূর্ণ হলে হাইলাইট সঠিকভাবে অগ্রসর হয় - **পরীক্ষা করে** যে উদ্ধৃতি সম্পূর্ণ হলে টাইমিং সহ সম্পূর্ণ বার্তা প্রদর্শিত হয় **সাধারণ ডিবাগিং টিপস:** - **ব্রাউজার কনসোল (F12) পরীক্ষা করুন** JavaScript ত্রুটির জন্য - **যাচাই করুন** যে সমস্ত ফাইলের নাম সঠিকভাবে মিলে (কেস-সেনসিটিভ) - **নিশ্চিত করুন** Live Server চালু আছে এবং সঠিকভাবে রিফ্রেশ হচ্ছে - **বিভিন্ন উদ্ধৃতি পরীক্ষা করুন** র‍্যান্ডম নির্বাচন সঠিকভাবে কাজ করছে কিনা তা নিশ্চিত করতে --- ## GitHub Copilot Agent Challenge 🎮 Agent মোড ব্যবহার করে নিম্নলিখিত চ্যালেঞ্জ সম্পন্ন করুন: **বর্ণনা:** প্লেয়ারের পারফরম্যান্সের উপর ভিত্তি করে গেমটি সামঞ্জস্য করার জন্য একটি ডিফিকাল্টি সিস্টেম বাস্তবায়ন করুন। এই চ্যালেঞ্জটি আপনাকে উন্নত ইভেন্ট হ্যান্ডলিং, ডেটা বিশ্লেষণ এবং ডাইনামিক UI আপডেট অনুশীলনে সাহায্য করবে। **প্রম্পট:** টাইপিং গেমের জন্য একটি ডিফিকাল্টি অ্যাডজাস্টমেন্ট সিস্টেম তৈরি করুন যা: 1. প্লেয়ারের টাইপিং স্পিড (প্রতি মিনিটে শব্দ) এবং সঠিকতার শতাংশ ট্র্যাক করে 2. স্বয়ংক্রিয়ভাবে তিনটি ডিফিকাল্টি লেভেলে সামঞ্জস্য করে: সহজ (সহজ উদ্ধৃতি), মাঝারি (বর্তমান উদ্ধৃতি), কঠিন (জটিল উদ্ধৃতি, যেগুলোতে বিরামচিহ্ন রয়েছে) 3. বর্তমান ডিফিকাল্টি লেভেল এবং প্লেয়ারের পরিসংখ্যান UI-তে প্রদর্শন করে 4. একটি স্ট্রিক কাউন্টার বাস্তবায়ন করে যা ৩টি ধারাবাহিক ভালো পারফরম্যান্সের পরে ডিফিকাল্টি বৃদ্ধি করে 5. ভিজ্যুয়াল ফিডব্যাক (রঙ, অ্যানিমেশন) যোগ করে ডিফিকাল্টি পরিবর্তন নির্দেশ করতে প্রয়োজনীয় HTML উপাদান, CSS স্টাইল এবং JavaScript ফাংশন যোগ করুন এই ফিচারটি বাস্তবায়নের জন্য। সঠিক ত্রুটি হ্যান্ডলিং অন্তর্ভুক্ত করুন এবং নিশ্চিত করুন যে গেমটি অ্যাক্সেসযোগ্য থাকে যথাযথ ARIA লেবেল সহ। [Agent মোড সম্পর্কে আরও জানুন](https://code.visualstudio.com/blogs/2025/02/24/introducing-copilot-agent-mode) এখানে। ## 🚀 চ্যালেঞ্জ আপনার টাইপিং গেমকে পরবর্তী স্তরে নিয়ে যেতে প্রস্তুত? ইভেন্ট হ্যান্ডলিং এবং DOM ম্যানিপুলেশনের গভীর অনুশীলনের জন্য এই উন্নত ফিচারগুলো বাস্তবায়ন করার চেষ্টা করুন: **আরও কার্যকারিতা যোগ করুন:** | ফিচার | বর্ণনা | আপনি যে দক্ষতা অনুশীলন করবেন | |---------|-------------|------------------------| | **ইনপুট কন্ট্রোল** | সম্পূর্ণ হলে `input` ইভেন্ট লিসেনার নিষ্ক্রিয় করুন এবং বোতাম ক্লিক করলে পুনরায় সক্রিয় করুন | ইভেন্ট ম্যানেজমেন্ট এবং স্টেট কন্ট্রোল | | **UI স্টেট ম্যানেজমেন্ট** | প্লেয়ার উদ্ধৃতি সম্পূর্ণ করলে টেক্সটবক্স নিষ্ক্রিয় করুন | DOM প্রপার্টি ম্যানিপুলেশন | | **মডাল ডায়ালগ** | সফলতার বার্তা সহ একটি মডাল ডায়ালগ বক্স প্রদর্শন করুন | উন্নত UI প্যাটার্ন এবং অ্যাক্সেসিবিলিটি | | **হাই স্কোর সিস্টেম** | `localStorage` ব্যবহার করে হাই স্কোর সংরক্ষণ করুন | ব্রাউজার স্টোরেজ API এবং ডেটা স্থায়িত্ব | **বাস্তবায়নের টিপস:** - **গবেষণা করুন** `localStorage.setItem()` এবং `localStorage.getItem()` স্থায়ী স্টোরেজের জন্য - **অনুশীলন করুন** ডায়নামিকভাবে ইভেন্ট লিসেনার যোগ এবং সরানো - **অন্বেষণ করুন** HTML ডায়ালগ উপাদান বা CSS মডাল প্যাটার্ন - **বিবেচনা করুন** অ্যাক্সেসিবিলিটি যখন ফর্ম কন্ট্রোল নিষ্ক্রিয় এবং সক্রিয় করা হয় ## পোস্ট-লেকচার কুইজ [পোস্ট-লেকচার কুইজ](https://ff-quizzes.netlify.app/web/quiz/22) --- ## 🚀 আপনার টাইপিং গেম মাস্টারি টাইমলাইন ### ⚡ **আপনি পরবর্তী ৫ মিনিটে যা করতে পারেন** - [ ] বিভিন্ন উদ্ধৃতি দিয়ে আপনার টাইপিং গেম পরীক্ষা করুন এটি মসৃণভাবে কাজ করছে কিনা তা নিশ্চিত করতে - [ ] CSS স্টাইলিং নিয়ে পরীক্ষা করুন - হাইলাইট এবং ত্রুটি রঙ পরিবর্তন করার চেষ্টা করুন - [ ] আপনার ব্রাউজারের DevTools (F12) খুলুন এবং খেলার সময় কনসোল দেখুন - [ ] নিজেকে চ্যালেঞ্জ করুন একটি উদ্ধৃতি যত দ্রুত সম্ভব সম্পূর্ণ করতে ### ⏰ **আপনি এই ঘণ্টায় যা অর্জন করতে পারেন** - [ ] অ্যারেতে আরও উদ্ধৃতি যোগ করুন (সম্ভবত আপনার প্রিয় বই বা সিনেমা থেকে) - [ ] চ্যালেঞ্জ সেকশনের localStorage হাই স্কোর সিস্টেম বাস্তবায়ন করুন - [ ] প্রতিটি গেমের পরে প্রদর্শিত একটি প্রতি মিনিটে শব্দ গণনা করার ক্যালকুলেটর তৈরি করুন - [ ] সঠিক টাইপিং, ত্রুটি এবং সম্পূর্ণ করার জন্য সাউন্ড ইফেক্ট যোগ করুন ### 📅 **আপনার সপ্তাহব্যাপী অভিযান** - [ ] একটি মাল্টিপ্লেয়ার সংস্করণ তৈরি করুন যেখানে বন্ধুরা পাশাপাশি প্রতিযোগিতা করতে পারে - [ ] উদ্ধৃতির জটিলতার পরিবর্তন সহ বিভিন্ন ডিফিকাল্টি লেভেল তৈরি করুন - [ ] একটি প্রগ্রেস বার যোগ করুন যা দেখায় উদ্ধৃতির কতটুকু সম্পূর্ণ হয়েছে - [ ] ব্যক্তিগত পরিসংখ্যান ট্র্যাকিং সহ ব্যবহারকারী অ্যাকাউন্ট তৈরি করুন - [ ] কাস্টম থিম ডিজাইন করুন এবং ব্যবহারকারীদের তাদের পছন্দের স্টাইলিং বেছে নেওয়ার অনুমতি দিন ### 🗓️ **আপনার মাসব্যাপী রূপান্তর** - [ ] একটি টাইপিং কোর্স তৈরি করুন যা ক্রমাগত সঠিক আঙুলের অবস্থান শেখায় - [ ] বিশ্লেষণ তৈরি করুন যা দেখায় কোন অক্ষর বা শব্দ সবচেয়ে বেশি ত্রুটি সৃষ্টি করে - [ ] বিভিন্ন ভাষা এবং কীবোর্ড লেআউটের জন্য সমর্থন যোগ করুন - [ ] শিক্ষামূলক API-এর সাথে ইন্টিগ্রেট করুন যাতে সাহিত্য ডাটাবেস থেকে উদ্ধৃতি টানা যায় - [ ] আপনার উন্নত টাইপিং গেমটি অন্যদের ব্যবহারের জন্য প্রকাশ করুন এবং উপভোগ করুন ### 🎯 **চূড়ান্ত প্রতিফলন চেক-ইন** **অগ্রসর হওয়ার আগে, উদযাপন করুন:** - গেমটি তৈরি করার সময় সবচেয়ে সন্তোষজনক মুহূর্তটি কী ছিল? - ইভেন্ট-চালিত প্রোগ্রামিং সম্পর্কে আপনার অনুভূতি এখন কেমন, যখন আপনি শুরু করেছিলেন তার তুলনায়? - এমন একটি ফিচার কী যা আপনি যোগ করতে আগ্রহী, যা এই গেমটিকে আপনার নিজস্ব করে তুলবে? - আপনি কীভাবে ইভেন্ট হ্যান্ডলিং ধারণাগুলো অন্য প্রকল্পে প্রয়োগ করতে পারেন? ```mermaid journey title Your Event Programming Confidence Journey section Today Understanding Events: 3: You Building UI: 4: You Writing Event Listeners: 5: You section This Week Adding Features: 4: You Debugging Issues: 5: You Enhancing UX: 4: You section Next Month Building Complex Apps: 5: You Teaching Others: 5: You Creating Frameworks: 5: You ``` > 🌟 **মনে রাখবেন**: আপনি মাত্র একটি মূল ধারণা আয়ত্ত করেছেন যা প্রতিটি ইন্টারঅ্যাকটিভ ওয়েবসাইট এবং অ্যাপ্লিকেশনকে চালিত করে। ইভেন্ট-চালিত প্রোগ্রামিংই ওয়েবকে জীবন্ত এবং প্রতিক্রিয়াশীল করে তো --- **অস্বীকৃতি**: এই নথিটি AI অনুবাদ পরিষেবা [Co-op Translator](https://github.com/Azure/co-op-translator) ব্যবহার করে অনুবাদ করা হয়েছে। আমরা যথাসাধ্য সঠিকতার জন্য চেষ্টা করি, তবে অনুগ্রহ করে মনে রাখবেন যে স্বয়ংক্রিয় অনুবাদে ত্রুটি বা অসঙ্গতি থাকতে পারে। মূল ভাষায় থাকা নথিটিকে প্রামাণিক উৎস হিসেবে বিবেচনা করা উচিত। গুরুত্বপূর্ণ তথ্যের জন্য, পেশাদার মানব অনুবাদ সুপারিশ করা হয়। এই অনুবাদ ব্যবহারের ফলে কোনো ভুল বোঝাবুঝি বা ভুল ব্যাখ্যার জন্য আমরা দায়বদ্ধ নই।