কখনও কখনও আপনি আপনার অ্যাপের ব্যবহারকারীদের একটি ইমেল বা চ্যাট অ্যাপ্লিকেশনের মাধ্যমে বার্তা পাঠাতে তাদের পরিচিতিগুলির মধ্যে একটি নির্বাচন করতে দিতে চান, বা তাদের পরিচিতিগুলির মধ্যে কোনটি ইতিমধ্যে একটি সামাজিক প্ল্যাটফর্মে যোগদান করেছে তা আবিষ্কার করতে সহায়তা করতে চান৷
আধুনিক উপায়
যোগাযোগ পিকার API ব্যবহার করে
ঠিকানা বই থেকে পরিচিতি পেতে, আপনাকে যোগাযোগ পিকার API ব্যবহার করতে হবে, যা ব্যবহারকারীদের তাদের যোগাযোগের তালিকা থেকে এন্ট্রি নির্বাচন করতে এবং আপনার অ্যাপের সাথে নির্বাচিত এন্ট্রিগুলির সীমিত বিবরণ ভাগ করতে দেয়। name
, email
, tel
, address
এবং icon
মতো বেশ কয়েকটি বৈশিষ্ট্য উপলব্ধ। সুনির্দিষ্টভাবে সমর্থিত বৈশিষ্ট্যগুলি সম্পর্কে জানতে, navigator.contacts.getProperties()
কল করুন। ব্যবহারকারীকে একাধিক পরিচিতি নির্বাচন করার অনুমতি দিতে, navigator.contacts.select()
এর দ্বিতীয় প্যারামিটার হিসাবে {multiple: true}
পাস করুন।
কন্টাক্ট পিকার API সংস্করণ 80 থেকে Chrome এর Android সংস্করণে উপলব্ধ।
ক্লাসিক উপায়
একটি নিয়মিত ফর্ম ব্যবহার করে
ফলব্যাক পদ্ধতি হল একটি নিয়মিত ফর্ম ব্যবহার করা যা ব্যবহারকারীকে পরিচিতির বিবরণ লিখতে দেয়।
প্রগতিশীল বর্ধিতকরণ
যোগাযোগ পিকার API সমর্থিত হলে, স্ট্যাটিক ফর্ম ক্ষেত্রগুলি লুকান এবং পরিবর্তে একটি পিকার বোতাম দেখান৷
const button = document.querySelector('button');
const name = document.querySelector('.name');
const address = document.querySelector('.address');
const email = document.querySelector('.email');
const tel = document.querySelector('.tel');
const pre = document.querySelector('pre');
const autofills = document.querySelectorAll('.autofill');
if ('contacts' in navigator) {
button.hidden = false;
for (const autofill of autofills) {
autofill.parentElement.style.display = 'none';
}
address.parentElement.style.display = 'block';
button.addEventListener('click', async () => {
const props = ['name', 'email', 'tel', 'address'];
const opts = { multiple: false };
try {
const [contact] = await navigator.contacts.select(props, opts);
name.value = contact.name;
address.value = contact.address;
tel.value = contact.tel;
email.value = contact.email;
} catch (err) {
pre.textContent = `${err.name}: ${err.message}`;
}
});
}
আরও পড়া
ডেমো
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<link
rel="icon"
href="data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text y=%22.9em%22 font-size=%2290%22>🎉</text></svg>"
/>
<title>How to access contacts from the address book</title>
</head>
<body>
<h1>How to access contacts from the address book</h1>
<p>Ship your order as a present to a friend.</p>
<button hidden type="button">Open address book</button>
<pre></pre>
<label> Name <input class="name" autocomplete="name"></label>
<label hidden>Address <input class="address" required></label>
<label>Street <input class="autofill" autocomplete="address-line1" required></label>
<label>City <input class="autofill" autocomplete="address-level2" required></label>
<label>State / Province / Region (optional) <input class="autofill" autocomplete="address-level1"></label>
<label>ZIP / Postal code (optional) <input class="autofill" autocomplete="postal-code"></label>
<label>Country <input class="autofill" autocomplete="country"></label>
<label>Email<input class="email" autocomplete="email"></label>
<label>Telephone<input class="tel" autocomplete="tel"></label>
</body>
</html>
html {
box-sizing: border-box;
font-family: system-ui, sans-serif;
color-scheme: dark light;
}
*, *:before, *:after {
box-sizing: inherit;
}
body {
margin: 1rem;
}
input {
display: block;
margin-block-end: 1rem;
}
const button = document.querySelector('button');
const name = document.querySelector('.name')
const address = document.querySelector('.address')
const email = document.querySelector('.email')
const tel = document.querySelector('.tel')
const pre = document.querySelector('pre')
const autofills = document.querySelectorAll('.autofill')
if ('contacts' in navigator) {
button.hidden = false;
for (const autofill of autofills) {
autofill.parentElement.style.display = 'none'
}
address.parentElement.style.display = 'block';
button.addEventListener('click', async () => {
const props = ['name', 'email', 'tel', 'address'];
const opts = {multiple: false};
try {
const [contact] = await navigator.contacts.select(props, opts);
name.value = contact.name;
address.value = contact.address;
tel.value = contact.tel
email.value = contact.email;
} catch (err) {
pre.textContent = `${err.name}: ${err.message}`
}
});
}