ব্রাউজারের বাইরে একটি PWA তার নিজস্ব উইন্ডো পরিচালনা করে। এই অধ্যায়ে, আপনি অপারেটিং সিস্টেমের মধ্যে একটি উইন্ডো পরিচালনা করার জন্য API এবং ক্ষমতাগুলি বুঝতে পারবেন।
PWA উইন্ডো
আপনার নিজের উইন্ডোতে চালানো, আপনার PWA দ্বারা পরিচালিত, সেই অপারেটিং সিস্টেমের যেকোনো উইন্ডোর সমস্ত সুবিধা এবং দায়িত্ব রয়েছে, যেমন:
- উইন্ডোজ বা ChromeOS-এর মতো মাল্টি-উইন্ডো অপারেটিং সিস্টেমে উইন্ডোটির আকার পরিবর্তন ও সরানোর ক্ষমতা।
- iPadOS স্প্লিট মোড বা Android স্প্লিট-স্ক্রিন মোডের মতো অন্যান্য অ্যাপ উইন্ডোর সাথে স্ক্রিন শেয়ার করা।
- ডক, টাস্কবারে এবং ডেস্কটপে Alt-ট্যাব মেনুতে এবং মোবাইল ডিভাইসে মাল্টি-টাস্ক উইন্ডো তালিকায় প্রদর্শিত হচ্ছে।
- ছোট করার ক্ষমতা, স্ক্রীন এবং ডেস্কটপ জুড়ে উইন্ডোটি সরানো এবং যে কোনো সময় এটি বন্ধ করা।
উইন্ডোটি সরানো এবং আকার পরিবর্তন করা হচ্ছে
আপনার PWA উইন্ডো যেকোন আকারের হতে পারে এবং ডেস্কটপ অপারেটিং সিস্টেমে স্ক্রিনের যে কোন জায়গায় অবস্থান করতে পারে। ডিফল্টরূপে, যখন ব্যবহারকারী প্রথমবার ইনস্টলেশনের পরে PWA খোলে, তখন PWA বর্তমান স্ক্রিনের শতাংশের একটি ডিফল্ট উইন্ডো আকার পায়, যার সর্বোচ্চ রেজোলিউশন 1920x1080 স্ক্রিনের উপরের-বাম কোণায় অবস্থিত।
ব্যবহারকারী উইন্ডোটি সরাতে এবং আকার পরিবর্তন করতে পারে এবং ব্রাউজারটি শেষ পছন্দটি মনে রাখবে, তাই পরের বার ব্যবহারকারী অ্যাপটি খুললে, উইন্ডোটি পূর্ববর্তী ব্যবহারের থেকে আকার এবং অবস্থান বজায় রাখবে।
ম্যানিফেস্টের মধ্যে আপনার PWA এর পছন্দের আকার এবং অবস্থান নির্ধারণ করার কোনো উপায় নেই। আপনি জাভাস্ক্রিপ্ট এপিআই ব্যবহার করে শুধুমাত্র উইন্ডোটির রিপজিশন এবং রিসাইজ করতে পারেন। আপনার কোড থেকে, আপনি window
অবজেক্টের moveTo(x, y)
এবং resizeTo(x, y)
ফাংশন ব্যবহার করে আপনার নিজস্ব PWA উইন্ডোটি সরাতে এবং পুনরায় আকার দিতে পারেন।
উদাহরণস্বরূপ, যখন PWA লোড হয় তখন আপনি আপনার PWA উইন্ডোর আকার পরিবর্তন করতে এবং সরাতে পারেন:
document.addEventListener("DOMContentLoaded", event => {
// we can move only if we are not in a browser's tab
isBrowser = matchMedia("(display-mode: browser)").matches;
if (!isBrowser) {
window.moveTo(16, 16);
window.resizeTo(800, 600);
}
});
আপনি window.screen
অবজেক্ট ব্যবহার করে বর্তমান পর্দার আকার এবং অবস্থান জিজ্ঞাসা করতে পারেন; window
অবজেক্ট থেকে resize
ইভেন্ট ব্যবহার করে উইন্ডোটির আকার পরিবর্তন করা হলে আপনি সনাক্ত করতে পারেন। উইন্ডো মুভ ক্যাপচার করার জন্য কোন ইভেন্ট নেই, তাই আপনার বিকল্প হল পজিশনটি ঘন ঘন জিজ্ঞাসা করা।
অন্যান্য সাইটে ব্রাউজিং
আপনি যদি ব্যবহারকারীকে এমন একটি বাহ্যিক সাইটে পাঠাতে চান যা আপনার PWA এর সুযোগের বাইরে, তাহলে আপনি এটি একটি মানক <a href>
HTML উপাদান দিয়ে, location.href
ব্যবহার করে বা সামঞ্জস্যপূর্ণ প্ল্যাটফর্মে একটি নতুন উইন্ডো খুলতে পারেন৷
বর্তমানে সমস্ত ব্রাউজারে, যদি আপনার PWA ইনস্টল করা থাকে, আপনি যখন আপনার ম্যানিফেস্টের সুযোগের বাইরে একটি URL-এ ব্রাউজ করেন, তখন আপনার PWA-এর ব্রাউজার ইঞ্জিন আপনার উইন্ডোর প্রেক্ষাপটে একটি ইন-অ্যাপ ব্রাউজার রেন্ডার করবে।
ইন-অ্যাপ ব্রাউজারগুলির কিছু বৈশিষ্ট্য হল:
- এগুলি আপনার সামগ্রীর উপরে প্রদর্শিত হয়।
- তাদের একটি স্ট্যাটিক URL বার রয়েছে যা বর্তমান উত্স, উইন্ডোর শিরোনাম এবং একটি মেনু দেখাচ্ছে৷ সাধারণত, তারা আপনার ম্যানিফেস্টের
theme_color
দিয়ে থিমযুক্ত। - প্রাসঙ্গিক মেনু থেকে, আপনি ব্রাউজারে সেই URLটি খুলতে পারেন।
- ব্যবহারকারীরা ব্রাউজার বন্ধ বা ফিরে যেতে পারেন.
অনুমোদন প্রবাহ
অনেক ওয়েব প্রমাণীকরণ এবং অনুমোদনের প্রবাহের মধ্যে একটি টোকেন অর্জনের জন্য ব্যবহারকারীকে একটি ভিন্ন মূলের একটি ভিন্ন URL-এ পুনঃনির্দেশিত করা জড়িত যা আপনার PWA এর মূলে ফিরে আসবে, যেমন OAuth 2.0 ব্যবহার করা।
এই ক্ষেত্রে, ইন-অ্যাপ ব্রাউজার নিম্নলিখিত প্রক্রিয়া অনুসরণ করে:
- ব্যবহারকারী আপনার PWA খোলে এবং লগইন ক্লিক করে।
- আপনার PWA ব্যবহারকারীকে এমন URL-এ পুনঃনির্দেশ করে যা PWA এর সুযোগের বাইরে যাতে রেন্ডারিং ইঞ্জিন আপনার PWA-এর মধ্যে একটি ইন-অ্যাপ ব্রাউজার খুলবে।
- ব্যবহারকারী অ্যাপ-মধ্যস্থ ব্রাউজার বাতিল করতে পারেন এবং যেকোনো সময় আপনার PWA-তে ফিরে যেতে পারেন।
- ব্যবহারকারী ইন-অ্যাপ ব্রাউজারে লগ ইন করে। প্রমাণীকরণ সার্ভার ব্যবহারকারীকে আপনার PWA মূলে পুনঃনির্দেশ করে, একটি যুক্তি হিসাবে টোকেন পাঠায়।
- অ্যাপ-মধ্যস্থ ব্রাউজারটি নিজেই বন্ধ হয়ে যায় যখন এটি একটি URL সনাক্ত করে যা PWA এর সুযোগের অংশ।
- ইন-অ্যাপ ব্রাউজারে থাকাকালীন প্রমাণীকরণ সার্ভার যে URLটিতে গিয়েছিল ইঞ্জিনটি মূল PWA উইন্ডো নেভিগেশনটিকে পুনঃনির্দেশ করে।
- আপনার PWA টোকেন পায়, টোকেন সংরক্ষণ করে এবং PWA রেন্ডার করে।
একটি ব্রাউজারের নেভিগেশন জোর করে
আপনি যদি একটি URL দিয়ে ব্রাউজার খুলতে চান এবং একটি ইন-অ্যাপ ব্রাউজার নয়, তাহলে আপনি <a href>
উপাদানগুলির _blank
লক্ষ্য ব্যবহার করতে পারেন। এটি শুধুমাত্র ডেস্কটপ PWA-তে কাজ করে; মোবাইল ডিভাইসে, একটি URL সহ একটি ব্রাউজার খোলার কোন বিকল্প নেই।
function openBrowser(url) {
window.open("url", "_blank", "");
}
নতুন উইন্ডো খুলছে
ডেস্কটপে, ব্যবহারকারীরা একই PWA এর একাধিক উইন্ডো খুলতে পারে। প্রতিটি উইন্ডো একই start_url
এ একটি ভিন্ন নেভিগেশন হবে, যেন আপনি একই URL এর দুটি ব্রাউজার ট্যাব খুলছেন। PWA এর মেনু থেকে, ব্যবহারকারীরা ফাইল তারপর নতুন উইন্ডো নির্বাচন করতে পারেন এবং আপনার PWA কোড থেকে, আপনি open()
ফাংশন সহ একটি নতুন উইন্ডো খুলতে পারেন। বিস্তারিত জানার জন্য ডকুমেন্টেশন চেক করুন.
function openNewWindow() {
window.open("/", "new-window", "width=600,height=600");
}
iOS বা iPadOS-এ PWA উইন্ডোর মধ্যে open()
কল করলে তা null
হয়ে যায় এবং কোনো উইন্ডো খোলে না। অ্যান্ড্রয়েডে নতুন উইন্ডো খোলার ফলে ইউআরএল-এর জন্য একটি নতুন অ্যাপ-মধ্যস্থ ব্রাউজার তৈরি হয়—এমনকি যদি URL আপনার PWA-এর সুযোগের মধ্যে থাকে—যা সাধারণত কোনও বাহ্যিক ব্রাউজিং অভিজ্ঞতা ট্রিগার করে না।
উইন্ডো শিরোনাম
একটি ব্রাউজার ট্যাবের মধ্যে স্থান সীমিত হওয়ায় <title>
উপাদানটি প্রাথমিকভাবে SEO উদ্দেশ্যে ব্যবহৃত হয়েছিল। আপনি যখন একটি PWA-তে ব্রাউজার থেকে আপনার উইন্ডোতে যান, তখন সমস্ত শিরোনাম দণ্ডের স্থান আপনার জন্য উপলব্ধ থাকে।
আপনি শিরোনাম বারের বিষয়বস্তু সংজ্ঞায়িত করতে পারেন:
- স্থিরভাবে আপনার HTML
<title>
উপাদানে। - যেকোন সময়
document.title
স্ট্রিং প্রপার্টি ডাইনামিকভাবে পরিবর্তন করা।
ডেস্কটপ পিডব্লিউএ-তে, শিরোনামটি অপরিহার্য, এবং এটি উইন্ডোর শিরোনাম বারে এবং কখনও কখনও টাস্ক ম্যানেজার বা মাল্টি-টাস্ক নির্বাচনে ব্যবহৃত হয়। আপনার যদি একটি একক-পৃষ্ঠার অ্যাপ্লিকেশন থাকে, আপনি প্রতিটি রুটে আপনার শিরোনাম আপডেট করতে চাইতে পারেন।
ট্যাবড মোড
একটি পরীক্ষামূলক ক্ষমতা, যা ট্যাবড মোড নামে পরিচিত— আপনার PWA একটি ওয়েব ব্রাউজারের মতো একটি ট্যাব-ভিত্তিক ডিজাইন থাকতে দেবে। এই ক্ষেত্রে, ব্যবহারকারী একই PWA থেকে একাধিক ট্যাব খোলা থাকতে পারে কিন্তু সবগুলি একই অপারেটিং সিস্টেম উইন্ডোতে একসাথে বাঁধা, আপনি নিম্নলিখিত ভিডিওতে দেখতে পারেন:
আপনি PWA এর জন্য ট্যাবড অ্যাপ্লিকেশন মোডে এই পরীক্ষামূলক ক্ষমতা সম্পর্কে আরও পড়তে পারেন।
উইন্ডো নিয়ন্ত্রণ ওভারলে
আমরা উল্লেখ করেছি যে আপনি <title>
উপাদান বা document.title
সম্পত্তির মান নির্ধারণ করে উইন্ডোর শিরোনাম পরিবর্তন করতে পারেন। কিন্তু এটা সবসময় একটি স্ট্রিং মান. আমরা যদি এইচটিএমএল, সিএসএস এবং ইমেজ সহ আমাদের ইচ্ছামতো টাইটেল বার ডিজাইন করতে পারি? সেখানেই উইন্ডো কন্ট্রোল ওভারলে আসে, ডেস্কটপ পিডব্লিউএ-র জন্য মাইক্রোসফ্ট এজ এবং গুগল ক্রোমে একটি নতুন পরীক্ষামূলক ক্ষমতা।
আপনি আপনার PWA এর শিরোনাম বারের উইন্ডো নিয়ন্ত্রণ ওভারলে কাস্টমাইজ করুন-এ এই ক্ষমতা সম্পর্কে আরও পড়তে পারেন।
জানালা ব্যবস্থাপনা
একাধিক স্ক্রিনের সাথে, ব্যবহারকারীরা তাদের জন্য উপলব্ধ সমস্ত স্থান ব্যবহার করতে চাইবেন। যেমন:
- মাল্টি-উইন্ডো গ্রাফিক্স এডিটর à la Gimp সঠিকভাবে অবস্থান করা উইন্ডোতে বিভিন্ন সম্পাদনা সরঞ্জাম রাখতে পারে।
- ভার্চুয়াল ট্রেডিং ডেস্ক একাধিক উইন্ডোতে বাজারের প্রবণতা দেখাতে পারে যার যেকোনো একটি ফুলস্ক্রিন মোডে দেখা যেতে পারে।
- স্লাইডশো অ্যাপগুলি অভ্যন্তরীণ প্রাথমিক স্ক্রিনে স্পিকার নোট এবং একটি বহিরাগত প্রজেক্টরে উপস্থাপনা দেখাতে পারে।
উইন্ডো ম্যানেজমেন্ট এপিআই পিডব্লিউএ-কে এটি এবং আরও অনেক কিছু করার অনুমতি দেয়।
স্ক্রীনের বিশদ বিবরণ পাওয়া যাচ্ছে
উইন্ডো ম্যানেজমেন্ট এপিআই একটি নতুন পদ্ধতি যোগ করে, window.getScreenDetails()
, যা সংযুক্ত স্ক্রিনগুলির একটি অপরিবর্তনীয় অ্যারে হিসাবে স্ক্রীন সহ একটি অবজেক্ট প্রদান করে। এছাড়াও একটি লাইভ অবজেক্ট রয়েছে যা ScreenDetails.currentScreen
থেকে অ্যাক্সেসযোগ্য, বর্তমান window.screen
এর সাথে সম্পর্কিত।
প্রত্যাবর্তিত বস্তুটি একটি screenschange
ইভেন্টও ফায়ার করে যখন screens
অ্যারে পরিবর্তন হয়। (যখন পৃথক স্ক্রিনের বৈশিষ্ট্যগুলি পরিবর্তন করা হয় তখন এটি ঘটে না৷) পৃথক স্ক্রিন, window.screen
বা screens
অ্যারেতে একটি স্ক্রীন, যখন তাদের বৈশিষ্ট্যগুলি পরিবর্তিত হয় তখন একটি change
ইভেন্টও চালু করে৷
// Request an object with a screen objects
const screenDetails = await window.getScreenDetails();
screenDetails.screens[0].isPrimary; // e.g. true
screenDetails.screens[0].isInternal; // e.g. true
screenDetails.screens[0].pointerTypes; // e.g. ["touch"]
screenDetails.screens[0].label; // e.g. 'Samsung Electric Company 28"'
// Access the live object corresponding to the current `window.screen`.
// The object is updated on cross-screen window placements or device changes.
screenDetails.currentScreen;
screenDetails.addEventListener('screenschange', function() {
// NOTE: Does not fire on changes to attributes of individual screens.
const screenCount = screenDetails.screens.length;
const currentScreen screenDetails.currentScreen.id;
});
যদি ব্যবহারকারী বা অপারেটিং সিস্টেম আপনার PWA এর উইন্ডোটিকে এক স্ক্রীন থেকে অন্য স্ক্রীনে নিয়ে যায়, তাহলে স্ক্রিন ডিটেইলস অবজেক্ট থেকে একটি currentscreenchange
ইভেন্টও ফায়ার করা হবে।
স্ক্রীন ওয়েক লক
এটি কল্পনা করুন: আপনি আপনার ট্যাবলেটে একটি রেসিপি অনুসরণ করে রান্নাঘরে আছেন। আপনি সবেমাত্র আপনার উপাদান প্রস্তুত শেষ করেছেন. আপনার হাতগুলি একটি জগাখিচুড়ি, এবং আপনি পরবর্তী ধাপ পড়তে আপনার ডিভাইসে ফিরে যান। বিপর্যয় ! পর্দা কালো হয়ে গেছে! স্ক্রিন ওয়েক লক এপিআই আপনার জন্য এখানে রয়েছে এবং একটি PWA-কে স্ক্রীনগুলিকে ম্লান হওয়া, ঘুমানো বা লক করা থেকে বিরত রাখতে দেয়, ব্যবহারকারীদেরকে থামাতে, শুরু করতে, ছেড়ে যেতে এবং উদ্বেগ ছাড়াই ফিরে যেতে দেয়৷
// Request a screen wake lock
const wakeLock = await navigator.wakeLock.request();
// Listen for wake lock release
wakeLock.addEventListener('release', () => {
console.log(`Screen Wake Lock released: ${wakeLock.released}`);
});
// Manually release the wake lock
wakeLock.release();
ভার্চুয়াল কীবোর্ড
টাচ-ভিত্তিক ডিভাইস, যেমন ফোন এবং ট্যাবলেট, একটি ভার্চুয়াল অন-স্ক্রিন কীবোর্ড অফার করে যাতে ব্যবহারকারী যখন আপনার PWA-এর ফর্ম উপাদানগুলি ফোকাসে থাকে তখন টাইপ করতে পারে।
VirtualKeyboard API- কে ধন্যবাদ, আপনার PWA এখন navigator.virtualKeyboard
ইন্টারফেস ব্যবহার করে সামঞ্জস্যপূর্ণ প্ল্যাটফর্মে কীবোর্ডের আরও নিয়ন্ত্রণ করতে পারে, যার মধ্যে রয়েছে:
-
navigator.virtualKeyboard.show()
এবংnavigator.virtualKeyboard.hide()
ফাংশন সহ ভার্চুয়াল কীবোর্ড দেখানো এবং লুকানো। - ব্রাউজারকে বলা যে আপনি
navigator.virtualKeyboard.overlaysContent
কেtrue
সমান সেট করে ভার্চুয়াল কীবোর্ড বন্ধ করার যত্ন নিচ্ছেন। -
navigator.virtualKeyboard
এর ইভেন্টgeometrychange
সাথে কীবোর্ডটি কখন উপস্থিত হয় এবং অদৃশ্য হয়ে যায় তা জানা। - ভার্চুয়াল কীবোর্ড পলিসি
virtualkeyboardpolicy
অ্যাট্রিবিউট সহ হোস্ট উপাদান (contenteditable
ব্যবহার করে) সম্পাদনা করার জন্য ভার্চুয়াল কীবোর্ড নীতি সেট করা। একটি নীতি আপনাকে সিদ্ধান্ত নিতে দেয় যে আপনি ভার্চুয়াল কীবোর্ডটিauto
মান ব্যবহার করে ব্রাউজার দ্বারা স্বয়ংক্রিয়ভাবে পরিচালনা করতে চান বাmanual
মান ব্যবহার করে আপনার স্ক্রিপ্ট দ্বারা পরিচালনা করতে চান। -
keyboard-inset-height
এবংkeyboard-inset-top
মতো ভার্চুয়াল কীবোর্ডের উপস্থিতি সম্পর্কে তথ্য পাওয়ার জন্য CSS পরিবেশগত ভেরিয়েবল ব্যবহার করা।
আপনি VirtualKeyboard API এর সাথে সম্পূর্ণ নিয়ন্ত্রণে এই API সম্পর্কে আরও পড়তে পারেন।
সম্পদ
- মাল্টি-স্ক্রিন উইন্ডো প্লেসমেন্ট এপিআই সহ বেশ কয়েকটি ডিসপ্লে পরিচালনা করা
- PWA-এর জন্য ট্যাবযুক্ত অ্যাপ্লিকেশন মোড
- স্ক্রীন ওয়েক লক এপিআই দিয়ে জাগ্রত থাকুন
- VirtualKeyboard API এর সাথে সম্পূর্ণ নিয়ন্ত্রণ
- আপনার PWA এর শিরোনাম বারের উইন্ডো নিয়ন্ত্রণ ওভারলে কাস্টমাইজ করুন
- শিরোনাম বারে বিষয়বস্তু প্রদর্শন করুন