ওয়েব অ্যাপ ম্যানিফেস্ট

ওয়েব অ্যাপ ম্যানিফেস্ট হল আপনার তৈরি করা একটি ফাইল যা ব্রাউজারকে বলে যে আপনি কীভাবে আপনার ওয়েব সামগ্রীকে অপারেটিং সিস্টেমে একটি অ্যাপ হিসেবে প্রদর্শন করতে চান৷ ম্যানিফেস্টে মৌলিক তথ্য যেমন অ্যাপের নাম, আইকন এবং থিমের রঙ অন্তর্ভুক্ত থাকতে পারে; উন্নত পছন্দ, যেমন পছন্দসই ওরিয়েন্টেশন এবং অ্যাপ শর্টকাট; এবং ক্যাটালগ মেটাডেটা, যেমন স্ক্রিনশট।

প্রতিটি পিডব্লিউএ-তে অ্যাপ্লিকেশন প্রতি একটি একক ম্যানিফেস্ট অন্তর্ভুক্ত করা উচিত, সাধারণত রুট ফোল্ডারে হোস্ট করা হয় এবং আপনার PWA ইনস্টল করা যেতে পারে এমন সমস্ত HTML পৃষ্ঠাগুলিতে লিঙ্ক করা উচিত। এর অফিসিয়াল এক্সটেনশন হল .webmanifest , তাই আপনি আপনার ম্যানিফেস্টের নাম দিতে পারেন app.webmanifest মত।

আপনার PWA-তে একটি ওয়েব অ্যাপ ম্যানিফেস্ট যোগ করা হচ্ছে

একটি ওয়েব অ্যাপ ম্যানিফেস্ট তৈরি করতে, প্রথমে একটি JSON অবজেক্টের সাথে একটি পাঠ্য ফাইল তৈরি করুন যাতে একটি স্ট্রিং মান সহ অন্তত একটি name ক্ষেত্র থাকে:

app.webmanifest:

{
   "name": "My First Application"
}

কিন্তু ফাইল তৈরি করা যথেষ্ট নয়, ব্রাউজারকে জানতে হবে এটি বিদ্যমান রয়েছে।

আপনার ম্যানিফেস্ট লিঙ্ক করা

আপনার ওয়েব অ্যাপ ম্যানিফেস্ট সম্পর্কে ব্রাউজারকে সচেতন করতে, আপনাকে একটি <link> HTML উপাদান এবং আপনার PWA-এর সমস্ত HTML পৃষ্ঠাগুলিতে manifest জন্য rel অ্যাট্রিবিউট সেট ব্যবহার করে এটিকে আপনার PWA-তে লিঙ্ক করতে হবে। আপনি কিভাবে একটি নথির সাথে একটি CSS স্টাইলশীট লিঙ্ক করেন এটি একই রকম।

index.html:

<html lang="en">
  <title>This is my first PWA</title>
  <link rel="manifest" href="/app.webmanifest">

ম্যানিফেস্ট ডিবাগ করা হচ্ছে

ম্যানিফেস্টটি সঠিকভাবে সেট আপ করা হয়েছে তা নিশ্চিত করতে, আপনি প্রতিটি Chromium-ভিত্তিক ব্রাউজারে Firefox এবং DevTools-এ Inspector ব্যবহার করতে পারেন৷

Chromium ব্রাউজারগুলির জন্য

DevTools-এ

  1. বাম ফলকে, অ্যাপ্লিকেশনের অধীনে, ম্যানিফেস্ট নির্বাচন করুন।
  2. ব্রাউজার দ্বারা পার্স করা ম্যানিফেস্টের ক্ষেত্রগুলি পরীক্ষা করুন৷

ফায়ারফক্সের জন্য

  1. ইন্সপেক্টর খুলুন।
  2. অ্যাপ্লিকেশন ট্যাবে যান।
  3. বাম প্যানেলে ম্যানিফেস্ট বিকল্পটি নির্বাচন করুন।
  4. ব্রাউজার দ্বারা পার্স করা ম্যানিফেস্টের ক্ষেত্রগুলি পরীক্ষা করুন৷

আপনার PWA অভিজ্ঞতা ডিজাইন করা

আপনার PWA এখন এর ম্যানিফেস্টের সাথে সংযুক্ত, আপনার ব্যবহারকারীদের জন্য অভিজ্ঞতা নির্ধারণ করতে বাকি ক্ষেত্রগুলি পূরণ করার সময় এসেছে৷

মৌলিক ক্ষেত্র

ক্ষেত্রগুলির প্রথম সেটটি আপনার PWA সম্পর্কে মূল তথ্য উপস্থাপন করে। এগুলি ইনস্টল করা PWA এর আইকন এবং উইন্ডো তৈরি করতে এবং এটি কীভাবে শুরু হয় তা নির্ধারণ করতে ব্যবহৃত হয়। তারা হল:

name
আপনার PWA এর পুরো নাম। এটি অপারেটিং সিস্টেমের হোম স্ক্রীন, লঞ্চার, ডক বা মেনুতে আইকনের সাথে প্রদর্শিত হবে।
short_name
ঐচ্ছিক, আপনার PWA-এর একটি ছোট নাম, যখন name ক্ষেত্রের সম্পূর্ণ মান প্রদর্শন করার জন্য পর্যাপ্ত জায়গা না থাকে তখন ব্যবহার করা হয়। ছেঁটে ফেলার সম্ভাবনা কমাতে 12টি অক্ষরের নিচে রাখুন।
icons
src , type , sizes এবং ঐচ্ছিক purpose ক্ষেত্র সহ আইকন অবজেক্টের অ্যারে, কোন চিত্রগুলিকে PWA প্রতিনিধিত্ব করা উচিত তা বর্ণনা করে।
start_url
ব্যবহারকারী ইনস্টল করা আইকন থেকে শুরু করলে PWA-এর যে URL লোড করা উচিত। একটি পরম পথ বাঞ্ছনীয়, তাই যদি আপনার PWA-এর হোম পেজটি আপনার সাইটের মূল হয়, তাহলে আপনার অ্যাপ শুরু হলে এটি খুলতে আপনি এটিকে '/' এ সেট করতে পারেন। আপনি যদি একটি স্টার্ট URL প্রদান না করেন, তাহলে ব্রাউজারটি সেই URLটি ব্যবহার করতে পারে যেটি PWA শুরু থেকে ইনস্টল করা হয়েছিল৷ এটি একটি গভীর লিঙ্ক হতে পারে, যেমন আপনার হোম স্ক্রিনের পরিবর্তে একটি পণ্যের বিবরণ।
display
OS-এর PWA উইন্ডোটি কীভাবে আঁকতে হবে তা বর্ণনা করে fullscreen , standalone , minimal-ui বা browser মধ্যে একটি। আপনি অ্যাপ ডিজাইন অধ্যায়ে বিভিন্ন ডিসপ্লে মোড সম্পর্কে আরও পড়তে পারেন। বেশিরভাগ ব্যবহারের ক্ষেত্রে standalone প্রয়োগ করা হয়।
id
একটি স্ট্রিং যা একই উত্সে হোস্ট করা হতে পারে এমন অন্যদের বিরুদ্ধে এই PWA কে স্বতন্ত্রভাবে সনাক্ত করে। এটি সেট না থাকলে, start_url একটি ফলব্যাক মান হিসাবে ব্যবহার করা হবে৷ মনে রাখবেন যে ভবিষ্যতে start_url পরিবর্তন করে (যেমন একটি ক্যোয়ারী স্ট্রিং মান পরিবর্তন করার সময়) আপনি একটি PWA ইতিমধ্যেই ইনস্টল করা আছে তা সনাক্ত করার জন্য ব্রাউজারের ক্ষমতা সরিয়ে ফেলতে পারেন।

আইকন

আপনার PWA এর আইকনটি ইনস্টল করার সময় আপনার ব্যবহারকারীদের ডিভাইস জুড়ে এটির ভিজ্যুয়াল পরিচয়, তাই এটি অন্তত একটি সংজ্ঞায়িত করা গুরুত্বপূর্ণ। যেহেতু icons সম্পত্তি আইকন বস্তুর একটি সংগ্রহ, আপনি আপনার ব্যবহারকারীদের জন্য সেরা আইকন অভিজ্ঞতা প্রদান করতে বিভিন্ন বিন্যাসে বেশ কয়েকটি আইকন সংজ্ঞায়িত করতে পারেন। প্রতিটি ব্রাউজার তার প্রয়োজনীয়তার উপর ভিত্তি করে এক বা একাধিক আইকন বাছাই করবে এবং এটি যে অপারেটিং সিস্টেমে ইনস্টল করা আছে, প্রয়োজনীয় স্পেসিফিকেশনের কাছাকাছি আইকন।

আপনি যদি শুধুমাত্র একটি আইকন আকার বাছাই করতে চান তবে এটি 512 বাই 512 পিক্সেল হওয়া উচিত। যাইহোক, 192 বাই 192, 384 বাই 384 এবং 1024 বাই 1024 পিক্সেল-আকারের ছবি সহ আরও মাপ প্রদানের সুপারিশ করা হয়।

"icons": [
   {
      "src": "icons/512.png",
      "type": "image/png",
      "sizes": "512x512"
   },
   {
      "src": "icons/1024.png",
      "type": "image/png",
      "sizes": "1024x1024"
   }
]

আপনি যদি একটি আইকন প্রদান না করেন বা আইকনগুলি প্রস্তাবিত আকারে না থাকে, কিছু প্ল্যাটফর্মে আপনি ইনস্টলেশনের মানদণ্ডে উত্তীর্ণ হবেন না৷ অন্যান্য প্ল্যাটফর্মে, আইকনটি স্বয়ংক্রিয়ভাবে তৈরি হবে, উদাহরণস্বরূপ PWA-এর স্ক্রিনশট থেকে বা জেনেরিক আইকন ব্যবহার করে।

মাস্কযোগ্য আইকন

কিছু অপারেটিং সিস্টেম, যেমন অ্যান্ড্রয়েড, বিভিন্ন আকার এবং আকারে আইকনগুলিকে মানিয়ে নেয়৷ উদাহরণস্বরূপ, Android 12-এ, বিভিন্ন নির্মাতারা বা সেটিংস আইকনগুলির আকৃতি বৃত্ত থেকে স্কোয়ার থেকে বৃত্তাকার-কোণে বর্গক্ষেত্রে পরিবর্তন করতে পারে। এই ধরনের অভিযোজিত আইকন সমর্থন করতে, আপনি purpose ক্ষেত্র ব্যবহার করে একটি মাস্কযোগ্য আইকন প্রদান করতে পারেন।

এটি করার জন্য, একটি বর্গাকার চিত্র ফাইল প্রদান করুন যেটির প্রধান আইকনটি একটি "নিরাপদ অঞ্চল" এর মধ্যে রয়েছে, আইকনের প্রস্থের 40 শতাংশ ব্যাসার্ধ সহ আইকনে কেন্দ্রীভূত একটি বৃত্ত। (নীচের চিত্রটি দেখুন।) মাস্কযোগ্য আইকনগুলিকে সমর্থন করে এমন ডিভাইসগুলি আপনার আইকনকে প্রয়োজন অনুসারে মাস্ক করবে।

বর্গাকার আইকনের মধ্যে 40 শতাংশ ব্যাসার্ধ কেন্দ্রিক বৃত্ত হিসেবে চিহ্নিত নিরাপদ এলাকা

এখানে একটি মাস্কযোগ্য আইকনের একটি উদাহরণ রয়েছে যা সাধারণভাবে ব্যবহৃত বিভিন্ন আকারে রেন্ডার করা হয়েছে:

নিচের ছবিতে, আপনি যদি বাম দিকের আইকনটিকে একটি মাস্কযোগ্য আইকন হিসেবে ব্যবহার করেন, তাহলে শেপ মাস্ক প্রয়োগ করা হলে আপনি ডিভাইসে খারাপ ফলাফল পাবেন।

একটি আইকন যা একটি মুখোশযোগ্য আইকনের জন্য উপযুক্ত নয়।

এই ছবিটি আরও প্যাডিং দিয়ে ব্যবহারযোগ্য করা যেতে পারে।

আরও প্যাডিং সহ আইকনটি মুখোশের জন্য উপযুক্ত।

মাস্কেবল আইকন কমপক্ষে 512 by 512 হওয়া উচিত। একটি তৈরি করে, আপনি সমর্থিত ডিভাইসগুলির অভিজ্ঞতা উন্নত করতে এটিকে আপনার icons সংগ্রহে যোগ করতে পারেন:

"icons": [
   {
      "src": "/icons/512.png",
      "type": "image/png",
      "sizes": "512x512"
   },
   {
      "src": "/icons/1024.png",
      "type": "image/png",
      "sizes": "1024x1024"
   },
   {
      "src": "/icons/512-maskable.png",
      "type": "image/png",
      "sizes": "512x512",
      "purpose": "maskable"
   },
]

বেশিরভাগ ক্ষেত্রে, যদি আপনার মুখোশযোগ্য আইকনটি ভালভাবে প্রদর্শিত না হয়, আপনি আরও প্যাডিং যোগ করে এটিকে উন্নত করতে পারেন। Maskable.app আপনার আইকনের একটি মাস্কযোগ্য সংস্করণ পরীক্ষা এবং তৈরি করার জন্য একটি বিনামূল্যের অনলাইন টুল।

যদি আপনার আইকনটি সাধারণ এবং মুখোশযোগ্য উদ্দেশ্যে পরিবেশন করে, আপনি purpose ক্ষেত্রটিকে "any maskable" তে সেট করতে পারেন৷ বিস্তারিত জানার জন্য MDN ওয়েব অ্যাপ ম্যানিফেস্ট ডকুমেন্টেশন পড়ুন।

ক্ষেত্রগুলির পরবর্তী সেটগুলি অন্তর্ভুক্ত করার জন্য যেগুলি আপনার ব্যবহারকারীর অভিজ্ঞতাকে উন্নত করবে, যদিও সেগুলি ইনস্টল করার জন্য প্রয়োজনীয় নয়৷

theme_color
অ্যাপ্লিকেশনের জন্য ডিফল্ট রঙ, কখনও কখনও OS কীভাবে সাইটটি প্রদর্শন করে তা প্রভাবিত করে (উদাহরণস্বরূপ, ডেস্কটপে উইন্ডো এবং শিরোনাম বারের রঙ, বা মোবাইল ডিভাইসে স্ট্যাটাস বারের রঙ)। এই রঙটি HTML theme-color <meta> উপাদান দ্বারা ওভাররাইড করা যেতে পারে।
background_color
স্টাইলশীট লোড হওয়ার আগে অ্যাপ্লিকেশনের ব্যাকগ্রাউন্ডে প্রদর্শনের জন্য প্লেসহোল্ডার রঙ। iOS এবং iPadOS-এ Safari এবং বেশিরভাগ ডেস্কটপ ব্রাউজার বর্তমানে এই ক্ষেত্রটিকে উপেক্ষা করে।
scope
PWA এর নেভিগেশন স্কোপ পরিবর্তন করে, আপনাকে ইনস্টল করা অ্যাপের উইন্ডোর মধ্যে কী প্রদর্শিত হবে এবং কী হবে না তা নির্ধারণ করতে দেয়। উদাহরণস্বরূপ, যদি আপনি সুযোগের বাইরে কোনো পৃষ্ঠার সাথে লিঙ্ক করেন, তাহলে এটি আপনার PWA উইন্ডোর পরিবর্তে একটি ইন-অ্যাপ ব্রাউজারে রেন্ডার করা হবে। তবে এটি আপনার পরিষেবা কর্মীর সুযোগ পরিবর্তন করবে না।

পরবর্তী চিত্রটি দেখায় যে আপনি যখন একটি PWA ইনস্টল করেন তখন একটি ডেস্কটপ ডিভাইসে শিরোনাম বারের জন্য theme_color ক্ষেত্রটি কীভাবে ব্যবহার করা হয়।

একই PWA ডেস্কটপে একটি ভিন্ন থিমের রঙ সহ ইনস্টল করা হয়েছে।

ম্যানিফেস্টে রং সংজ্ঞায়িত করার সময়, যেমন theme_color এবং background_color মধ্যে, আপনার CSS নামের রং ব্যবহার করা উচিত, যেমন salmon বা orange , RGB রং যেমন #FF5500 , অথবা স্বচ্ছতা ছাড়া রঙ ফাংশন যেমন rgb() বা hsl() । আরও তথ্যের জন্য অ্যাপ ডিজাইন অধ্যায় দেখুন।

চেষ্টা করে দেখুন

স্প্ল্যাশ পর্দা

কিছু ডিভাইসে, ব্যবহারকারীকে তাৎক্ষণিক প্রতিক্রিয়া প্রদানের জন্য আপনার PWA লোড করার সময় একটি স্ট্যাটিক ইমেজ রেন্ডার করা হয়।

অ্যান্ড্রয়েড স্প্ল্যাশ স্ক্রিন তৈরি করতে theme_color , background_color এবং icon মান ব্যবহার করে।

আপনি যখন Android এ একটি PWA ইনস্টল করেন, তখন ডিভাইসটি একটি স্প্ল্যাশ স্ক্রিন তৈরি করবে যা আপনার ম্যানিফেস্ট থেকে আসে যা নিম্নলিখিত চিত্রে দেখা যায়।

অ্যান্ড্রয়েড স্প্ল্যাশ স্ক্রিনে একটি PWA ম্যানিফেস্ট থেকে বিভিন্ন মান গ্রহণ করে৷

অন্যদিকে, iOS এবং iPadOS-এ Safari, স্প্ল্যাশ স্ক্রিন তৈরি করতে ওয়েব অ্যাপ ম্যানিফেস্ট ব্যবহার করে না। পরিবর্তে, তারা আইকনগুলি কীভাবে পরিচালনা করে তার অনুরূপ একটি মালিকানাধীন <link> উপাদান থেকে লিঙ্ক করা একটি চিত্র ব্যবহার করে। আরও বিস্তারিত জানার জন্য বর্ধিতকরণ অধ্যায় দেখুন।

বর্ধিত ক্ষেত্র

ক্ষেত্রগুলির পরবর্তী সেট আপনার PWA সম্পর্কে অতিরিক্ত তথ্য সরবরাহ করে। তারা সব ঐচ্ছিক.

lang
একটি ভাষা ট্যাগ যা ম্যানিফেস্টের মানগুলির প্রাথমিক ভাষা নির্দিষ্ট করে, যেমন ইংরেজির জন্য en , ব্রাজিলিয়ান পর্তুগিজের জন্য pt-BR , বা in জন্য।
dir
দিকনির্দেশ-সক্ষম ম্যানিফেস্ট ক্ষেত্রগুলি প্রদর্শনের দিক (যেমন name , short_name , এবং description )। বৈধ মান হল auto , ltr (বাম থেকে ডানে), এবং rtl (ডান থেকে বামে)।
orientation
একবার ইনস্টল হয়ে গেলে অ্যাপটির জন্য পছন্দসই অভিযোজন। একটি গেম এটি একটি ল্যান্ডস্কেপ-শুধু অভিযোজন অনুরোধ করতে সেট করতে পারে। বেশ কয়েকটি মান গৃহীত হয়, তবে অন্তর্ভুক্ত করা হলে এটি সাধারণত portrait বা landscape স্পষ্টভাবে।

প্রচারমূলক ক্ষেত্র

ক্ষেত্রগুলির চতুর্থ সেট আপনাকে আপনার PWA সম্পর্কে প্রচারমূলক তথ্য প্রদান করতে দেয়, উদাহরণস্বরূপ, ইনস্টল ফ্লো, তালিকা এবং অনুসন্ধান ফলাফলে।

description
PWA কি করে তার একটি ব্যাখ্যা।
screenshots
PWA প্রদর্শনের উদ্দেশ্যে src , type এবং sizes ( icons অবজেক্টের অনুরূপ) সহ স্ক্রিনশট অবজেক্টের অ্যারে। কোন আকার সীমাবদ্ধতা আছে.
categories
বিভাগগুলির অ্যারে PWA-কে তালিকার জন্য ইঙ্গিত হিসাবে ব্যবহার করা উচিত, ঐচ্ছিকভাবে পরিচিত বিভাগের তালিকা থেকে। এই মানগুলি সাধারণত ছোট হাতের হয়।
iarc_rating_id
PWA-এর জন্য ইন্টারন্যাশনাল এজ রেটিং কোয়ালিশন সার্টিফিকেশন কোড, যদি আপনার কাছে থাকে। আপনার PWA কোন বয়সের জন্য উপযুক্ত তা নির্ধারণ করতে এটি ব্যবহার করার উদ্দেশ্যে করা হয়েছে।

আপনি আজ এই প্রচারমূলক ক্ষেত্রগুলিকে কার্যে দেখতে পারেন। অ্যান্ড্রয়েডে, উদাহরণস্বরূপ, যদি আপনার PWA ইনস্টল করা যায় এবং আপনি অন্তত description এবং screenshots ক্ষেত্রের মান প্রদান করেন, তাহলে ইনস্টলেশন ডায়ালগ অভিজ্ঞতা একটি সাধারণ "হোম স্ক্রিনে যোগ করুন" তথ্য বার থেকে একটি সমৃদ্ধ ইনস্টলেশন ডায়ালগে রূপান্তরিত হয় একটি অ্যাপ স্টোর থেকে।

অ্যান্ড্রয়েডে, আপনি যদি প্রচারমূলক ক্ষেত্রগুলির জন্য মান প্রদান করেন তবে আপনি একটি সুন্দর ইনস্টলেশন UI পেতে পারেন, যেমন আপনি পরবর্তী ভিডিওতে দেখতে পাবেন

এই প্রচারমূলক ক্ষেত্রগুলি কর্মে দেখুন:

ক্ষমতা ক্ষেত্র

অবশেষে, বিভিন্ন ক্ষমতার সাথে সম্পর্কিত বেশ কয়েকটি ক্ষেত্র রয়েছে যা আপনার PWA সমর্থিত ব্রাউজারগুলিতে ব্যবহার করতে পারে, যেমন shortcuts , share_target , display_override ক্ষেত্রগুলি যেমন আমরা সক্ষমতা অধ্যায়ে কভার করেছি। এছাড়াও ক্ষেত্র রয়েছে, যেমন related_apps এবং prefer_related_apps (আরো তথ্যের জন্য সনাক্তকরণ অধ্যায় দেখুন), ইনস্টল করা অ্যাপগুলির সাথে আপনার PWA সংযোগ করতে, প্রায়শই একটি অ্যাপ স্টোর থেকে।

ব্রাউজারগুলি প্রগতিশীল ওয়েব অ্যাপগুলিতে আরও ক্ষমতা যুক্ত করার সময় ভবিষ্যতে অনেক নতুন ক্ষেত্র উপস্থিত হতে পারে৷

সম্পদ