বর্ধিতকরণ

আপনার PWA এর রূপান্তর এবং ব্যবহার উন্নত করতে পারে এমন অনেক বর্ধন রয়েছে।

অ্যাপ শর্টকাট হল আপনার PWA-তে গভীর লিঙ্কগুলির একটি স্ট্যাটিক তালিকা, সেগুলি আপনার ম্যানিফেস্টে লেখা আছে। ওয়েব অ্যাপ ম্যানিফেস্ট স্পেক । এটি আপনাকে আপনার PWA-তে বিভিন্ন অংশ বা বৈশিষ্ট্যগুলির শর্টকাটগুলির একটি তালিকা সংজ্ঞায়িত করতে দেয়, তারা ঘন ঘন অ্যাক্সেস করা বিভাগে নেভিগেশনকে ত্বরান্বিত করে।

অ্যাপের শর্টকাটগুলি বেশিরভাগ ডেস্কটপ অপারেটিং সিস্টেমে এবং WebAPK সহ Android এ উপলব্ধ, এবং সেগুলি হোম স্ক্রীন, ডক বা টাস্কবারে অ্যাপের আইকনে একটি প্রাসঙ্গিক মেনুতে প্রদর্শিত হয়, যেমনটি নিম্নলিখিত চিত্রে রয়েছে:

Android এবং macOS-এ অ্যাপ শর্টকাট।

এই মেনু অ্যাক্সেস করতে, ব্যবহারকারীদের পিডব্লিউএ-এর আইকনে ডান-ক্লিক করতে হবে বা দীর্ঘক্ষণ-টিপতে হবে।

ম্যানিফেস্টের shortcuts সদস্যে শর্টকাট সংজ্ঞায়িত করা হয়। এটি নিম্নলিখিত বৈশিষ্ট্য সহ সদস্যদের একটি অ্যারে নেয়:

name
পাঠ্য যা ব্যবহারকারীকে দেখানো হবে, সাধারণত একটি প্রসঙ্গ মেনুতে।
url
ব্যবহারকারী যখন এই শর্টকাট থেকে শুরু করে তখন PWA-এর যে URL লোড করা উচিত। এটি আপনার PWA স্কোপের মধ্যে একটি URL হওয়া উচিত এবং name বা short_name বর্ণনা করা বৈশিষ্ট্যের সাথে এটিকে গভীর-লিঙ্ক করা উচিত।
short_name
(ঐচ্ছিক) name ক্ষেত্রের সম্পূর্ণ মান প্রদর্শন করার জন্য পর্যাপ্ত জায়গা না থাকলে একটি ছোট নাম ব্যবহার করা হয়।
description
(ঐচ্ছিক) এই শর্টকাটটি কী করবে তার একটি বিবরণ৷
icons
(ঐচ্ছিক) src , type , sizes এবং ঐচ্ছিক purpose ক্ষেত্র সহ আইকন অবজেক্টের একটি বিন্যাস, কোন চিত্রগুলিকে শর্টকাট উপস্থাপন করা উচিত তা বর্ণনা করে

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

নিম্নলিখিত কোড নমুনাটি বিভিন্ন অ্যাপ শর্টকাটকে সংজ্ঞায়িত করে যে আপনি যদি Chrome এর সাথে Android এ বা Edge বা Chrome এর সাথে ডেস্কটপে অ্যাপটি ইনস্টল করেন তবে আপনি চেষ্টা করতে পারেন।

iOS এবং iPadOS

PWAs প্রকাশ করার সময়, কিছু বর্ধিতকরণ রয়েছে যা iOS/iPadOS-এ Safari-এ ব্যবহারকারীদের অভিজ্ঞতা উন্নত করতে পারে।

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

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

এই ছবিগুলি অ্যাপল ডিভাইসে স্টার্টআপ ইমেজ হিসাবে পরিচিত এবং তারা apple-touch-startup-image মান সহ rel সম্পত্তি ব্যবহার করে, যেমন:

<link rel="apple-touch-startup-image" href="ios-startup.png">

চ্যালেঞ্জ হল যে স্টার্টআপ ইমেজটি অবশ্যই আপনার পিডব্লিউএ খোলার সময় সঠিক উইন্ডোর আকার থাকতে হবে। সুতরাং, বিভিন্ন iOS এবং iPadOS ডিভাইসের জন্য বিভিন্ন চিত্রের প্রয়োজন হবে। আইপ্যাডে আরও পরিস্থিতি কভার করা দরকার, যেমন ল্যান্ডস্কেপ/পোর্ট্রেট খোলা এবং মাল্টিটাস্ক মোডে PWA রেন্ডার করা (যেমন 1/3,1/2, অথবা 2/3 স্ক্রীন)।

আপনি Apple হিউম্যান ইন্টারফেস নির্দেশিকাগুলিতে iOS এবং iPadOS স্ক্রীন আকারের একটি আপডেট করা তালিকা পরীক্ষা করতে পারেন

লঞ্চ ইমেজের বিভিন্ন সংস্করণ media অ্যাট্রিবিউটের ভিতরে একটি মিডিয়া ক্যোয়ারী দিয়ে সেট করা যেতে পারে:

<link rel="apple-touch-startup-image" href="ios-startup.png"
     
media="orientation: portrait">
<link rel="apple-touch-startup-image" href="ios-startup-landscape.png"
     
media="orientation: landscape">

iOS স্টার্টআপ ইমেজের জন্য ডিজাইন প্যাটার্ন

স্টার্টআপ চিত্রগুলিকে সংজ্ঞায়িত করা কঠিন কাজ, তাই আমাদের কাছে স্বয়ংক্রিয় প্রজন্ম এবং কনফিগারেশনের জন্য কয়েকটি সরঞ্জাম রয়েছে:

  • স্ট্যাটিক জেনারেশন আপনার বিল্ড সিস্টেমের সাথে ইন্টিগ্রেট করে, সমস্ত PNG স্ট্যাটিক ইমেজ তৈরি করে এবং আপনার ডকুমেন্টে ইনজেক্ট করার জন্য আপনাকে <link> উপাদান সহ HTML কোড দেয়। PWA সম্পদ জেনারেটর এই ধরনের একটি টুলের উদাহরণ।
  • ক্লায়েন্ট-সাইড জেনারেটর, একটি জাভাস্ক্রিপ্ট টুল যা বর্তমান ডিভাইসের ধরন এবং স্ক্রিনের আকারের উপর ভিত্তি করে স্টার্টআপ ইমেজের এক বা একাধিক বেস64 সংস্করণকে <link> ইনজেক্ট করা উপাদানগুলিতে এম্বেড করতে পারে। আপনি একটি ইন-মেমরি ক্যানভাস ব্যবহার করতে পারেন, চিত্রটি রেন্ডার করতে পারেন এবং এটিকে একটি data: একটি PNG ফাইল সহ URI৷ PWA কম্প্যাট লাইব্রেরি হল একটি সহজে ব্যবহারযোগ্য ক্লায়েন্ট-সাইড লাইব্রেরি যা অ্যান্ড্রয়েডের সাধারণ লঞ্চ স্ক্রীন ক্লোন করে এটি করে।

অ্যাপল মোবাইল প্ল্যাটফর্মে একটি PWA সনাক্ত করা হচ্ছে

আপনার পিডব্লিউএ-তে প্রোগ্রেসিভ এনহ্যান্সমেন্ট এবং ফিচার ডিটেকশন ব্যবহার করা উচিত, এমন কিছু এজ কেস থাকতে পারে যেখানে আমাদের জানতে হবে যে ব্যবহারকারী অ্যাপল মোবাইল প্ল্যাটফর্মে পিডব্লিউএ-তে আছেন কিনা, যেমন আপনি যখন ইনস্টলেশন নির্দেশাবলী অফার করতে চান বা প্ল্যাটফর্মে লিঙ্ক যোগ করতে চান। শুধুমাত্র iOS-এর জন্য নির্দিষ্ট অ্যাপ।

ইউজার এজেন্ট স্ট্রিং পড়া এড়াতে, navigator অবজেক্টের standalone বৈশিষ্ট্য পরীক্ষা করুন। এটি একটি অ-মানক সম্পত্তি, এবং এটি শুধুমাত্র iOS এবং iPadOS-এর ওয়েবকিট ইঞ্জিনে উপলব্ধ৷

  • যদি navigator.standalone undefined হয় তার মানে ব্যবহারকারী একটি iPadOS বা iOS ডিভাইসে নেই।
  • যদি navigator.standalone false হয় তার মানে ব্যবহারকারী ব্রাউজারে PWA খুলেছেন এবং সেখানে এটি ব্যবহার করছেন।
  • যদি navigator.standalone true হয় তার মানে ব্যবহারকারী হোম স্ক্রীন থেকে PWA খুলেছেন এবং স্বতন্ত্র PWA অভিজ্ঞতা পাচ্ছেন।

ফুলস্ক্রিন সমর্থন

iOS এবং iPads-এ Safari-এ, শুধুমাত্র display: standalone আপনার PWA-এর জন্য ডিসপ্লে মোড হিসেবে সমর্থিত।

পরের ছবিতে, আপনি বাম দিকে একটি থিম রঙের সাথে একটি ডিফল্ট স্বতন্ত্র ডিজাইন দেখতে পারেন এবং ডানদিকে একটি ফুলস্ক্রিন iOS মোড সহ একটি PWA দেখতে পারেন যা আপনাকে স্ট্যাটাস বারের পিছনে সামগ্রী রেন্ডার করতে দেয়৷

একটি স্বতন্ত্র ডিফল্ট আচরণ (বাম) এবং একটি পূর্ণস্ক্রীন iOS স্ক্রীন (ডান)।

আপনি যদি আপনার HTML-এ নিম্নলিখিত ট্যাগটি যোগ করেন তাহলে iOS এবং iPadOS-এ আপনার PWA পূর্ণ-স্ক্রীন মোডে প্রবেশ করবে, কিন্তু এটি Android থেকে আলাদা।

<meta name="apple-mobile-web-app-status-bar-style" content="black-translucent">

এই মোডে, ডিভাইসের স্ট্যাটাস বার (উপরে যেখানে আপনি ঘড়ি, ব্যাটারি স্তর এবং বিজ্ঞপ্তি আইকনগুলি দেখতে পান) এখনও দৃশ্যমান কিন্তু একটি স্বচ্ছ ব্যাকগ্রাউন্ড সহ আপনার সামগ্রীর উপরে রেন্ডার করা হয়েছে৷

এই মোডটি ব্যবহার করার সময়, আপনার ডিজাইনের সাথে সতর্ক থাকুন কারণ অপারেটিং সিস্টেম সবসময় আইকনগুলিকে সাদা রঙে রেন্ডার করবে, তাই আপনার সর্বদা হালকা বিষয়বস্তুর সাথে স্ক্রিনের শীর্ষের জন্য আপনার ব্যাকগ্রাউন্ডের বিপরীতে থাকা উচিত। এছাড়াও, অ্যাপ ডিজাইন অধ্যায়ে যেমন দেখা যায়, নিরাপদ এলাকায় সামগ্রী রেন্ডার করতে CSS এনভায়রনমেন্ট ভেরিয়েবল ব্যবহার করা গুরুত্বপূর্ণ।

আপনার ভিউপোর্টের উপরের 0px ডিফল্টভাবে স্ট্যাটাস বারের নিচে থাকে; আপনি যদি একটি কালো-অস্বচ্ছ মেটা ট্যাগ যোগ করেন, তাহলে আপনার ভিউপোর্টের শীর্ষ 0px পর্দার প্রকৃত শীর্ষের সাথে মিলবে

ইনস্টলেশন নির্ভরযোগ্যতা

15.4-এর আগে iOS এবং iPadOS-এ, ম্যানিফেস্ট ফাইলটি শুধুমাত্র নেটওয়ার্ক থেকে লোড হয় যখন ব্যবহারকারী শেয়ার শীটটি খোলে - ব্রাউজারের মধ্যে শেয়ার আইকন ব্যবহার করে- এবং পৃষ্ঠা লোড হওয়ার সময় নয়। তাই, ব্রাউজার সেই মুহুর্ত পর্যন্ত আপনার ওয়েবসাইট PWA কিনা তা পরীক্ষা করে না, যার ফলে ম্যানিফেস্ট লোড করা যায় না বা খুব বেশি সময় লাগে এবং ব্রাউজার এটি উপেক্ষা করে।

ব্রাউজার যখন সময়মতো ম্যানিফেস্ট লোড করতে পারে না, তখন "হোম স্ক্রীনে যোগ করুন" টিপে হোম স্ক্রিনে একটি আইকন থাকে, কিন্তু একটি অ্যাপ অভিজ্ঞতা প্রদান করে না; এটি শুধুমাত্র একটি ব্রাউজার ট্যাবের একটি শর্টকাট হবে।

সম্পদ