إضافة مربعات الحوار في كوردوفا
توفر هذه الإضافة إمكانية الوصول إلى بعض مربعات الحوار الأصلية عبر الكائن العام navigator.notification
.
على الرغم من أن هذا الكائن مربوط بالنطاق العام للكائن navigator
، إلا أنه لن يكون متوفرًا إلا بعد إطلاق الحدث deviceready
.
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
console.log(navigator.notification);
}
التثبيت
يمكن تثبيت هذه الإضافة عبر الأمر:
cordova plugin add cordova-plugin-dialogs
التوابع
يُظهر التابع alert
مربع حوار (dialog box) أو مربع تنبيه (alert box) مخصص. معظم تنفيذات (implementations) كوردوفا لهذا التابع تستخدم مربع حوار أصلي لهذه الميزة، لكن بعض المنصات تستخدم دالة المتصفح alert
، والتي تكون عادةً أقل قابلية للتخصيص.
navigator.notification.alert(message, alertCallback, [title], [buttonName])
المعاملات هي:
message
: سلسلة نصية تمثِّل رسالة مربع الحوار.alertCallback
: دالة رد نداء (Callback) تُستدعَى عند إنهاء مربع التنبيه (alert dialog).title
: سلسلة نصية تمثِّل عنوان مربع الحوار. هذا المعامل اختياري. القيمة الافتراضية هي:Alert
.buttonName
: سلسلة نصية تمثِّل اسم الزر. هذا المعامل اختياري. القيمة الافتراضية هي:OK
.
إليك المثال التالي:
function alertDismissed() {
// افعل شيئا ما
}
navigator.notification.alert(
'You are the winner!', // الرسالة
alertDismissed, // دالة الاستجابة
'Game Over', // العنوان
'Done' // اسم الزر
);
المنصات المدعومة:
- أندرويد
- Browser
- iOS
- ويندوز
يعرض هذا التابع مربع تأكيد (confirmation dialog box) قابل للتخصيص.
navigator.notification.confirm(message, confirmCallback, [title], [buttonLabels])
المعاملات المُمرَّرة إلى هذا التابع هي:
message
: سلسلة نصية تمثِّل رسالة مربع الحوار.confirmCallback
: دالة رد نداء (Callback) تُستدعَى مع فهرس الزر الذي ضغط عليه المستخدم (1
أو2
أو3
) أو عند إنهاء مربع الحوار دون الضغط على أي زر (0
).title
: عنوان مربع الحوار (سلسلة نصية، اختياري، القيمة الافتراضية هيConfirm
)buttonLabels
: مصفوفة من السلاسل النصية تحدد تسميات (labels) الأزرار. هذا المعامل اختياري. القيمة الافتراضية هي[OK,Cancel]
.
تُنفّذ دالة رد النداء confirmCallback
عندما يضغط المستخدم على أحد الأزرار في مربع التأكيد.
تأخذ هذه الدالة الوسيط buttonIndex
(وهو عدد) الذي يمثل فهرس الزر المضغوط (تذكر أن الفهرسة تبدأ بالعدد واحد، وبالتالي فالقيم الممكنة هي 1
، 2
، 3
، ...إلخ).
اطلع على المثال التالي:
function onConfirm(buttonIndex) {
alert('You selected button ' + buttonIndex);
}
navigator.notification.confirm(
'You are the winner!', // الرسالة
onConfirm, // دالة الاستجابة التي ستُستدعى مع فهرس الزر المضغوط
'Game Over', // العنوان
['Restart','Exit'] // اسم الزر
);
المنصات المدعومة:
- أندرويد
- Browser
- iOS
- ويندوز
ملاحظات خاصة بمنصة أندرويد
- يدعم أندرويد ثلاثة أزرار كحد أقصى، ويتجاهل الأزرار الإضافية.
ملاحظات خاصة بمنصة ويندوز
- على منصتي ويندوز 8 و8.1، ليس من الممكن إضافة أكثر من ثلاثة أزرار إلى النُسخة (instance)
MessageDialog
. - على منصة Windows Phone 8.1، لا يمكن إظهار مربع حوار بأكثر من زرين.
يعرض هذا التابع مربع حوار أصلي أكثر قابلية للتخصيص من دالة المتصفح prompt
.
navigator.notification.prompt(message, promptCallback, [title], [buttonLabels], [defaultText])
المعاملات المُمرَّرة إلى التابع هي:
message
: سلسلة نصية تمثِّل رسالة مربع الحوار.promptCallback
: دالة رد نداء (callback) تُستدعى مع فهرس الزر الذي ضغط عليه المستخدم (1
أو2
أو3
) أو عندما يتم إنهاء مربع الحوار دون الضغط على أيِّ زر (0
).title
: سلسلة نصية تمثِّل عنوان مربع الحوار. هذا المعامل اختياري. القيمة الافتراضية هيPrompt
.buttonLabels
: مصفوفة من السلاسل النصية التي تحدد تسميات الأزرار. هذا المعامل اختياري. القيمة الافتراضية هي["OK","Cancel"]
.defaultText
: سلسلة نصية تمثِّل القيمة الافتراضية لمربع الإدخال textbox. هذا المعامل اختياري. القيمة الافتراضية هي:""
.
تُنفذ دالة رد النداء promptCallback
عندما يضغط المستخدم على أحد الأزرار في مربع الطلب (prompt dialog box). يحتوي الكائن results
الممرّر إلى دالة الاستجابة على الخاصيات التالية:
buttonIndex
: فهرس الزر المضغوط (عدد)، تذكر أن الفهرس يبدأ من العدد واحد، وبالتالي فإن القيم الممكنة هي1
و2
و3
، ...إلخ.input1
: النص المُدخل في مربع الطلب (سلسلة نصية).
إليك المثال التالي:
function onPrompt(results) {
alert("You selected button number " + results.buttonIndex + " and entered " + results.input1);
}
navigator.notification.prompt(
'Please enter your name', // الرسالة
onPrompt, // دالة الاستجابة المراد استدعاؤها
'Registration', // العنوان
['Ok','Exit'], // اسم الزر
'Jane Doe' // النص الافتراضي
);
المنصات المدعومة:
- أندرويد
- Browser
- iOS
- ويندوز
ملاحظات خاصة بمنصة أندرويد
- يدعم أندرويد ثلاثة أزرار كحد أقصى، ويتجاهل ما زاد عن ذلك.
- في الإصدار أندرويد 3.0 وما بعده، تُعرَض الأزرار بالترتيب العكسي على الأجهزة التي تستخدم القالب Holo.
ملاحظات خاصة بمنصة ويندوز
- على منصة ويندوز، يُبنَى مُربع الطلب بلغة html بسبب عدم وجود واجهة برمجية أصلية لهذا الغرض.
عند تنفيذ هذا التابع، يطلق الجهاز صوت تنبيه (صافرة).
navigator.notification.beep(times);
المعاملات المُمرَّرة إلى التابع هي:
times
: عدد يحدِّد عدد مرات تكرار الصافرة.
اطلع على المثال التالي:
// إطلاق صافرتين
navigator.notification.beep(2);
المنصات المدعومة:
- أندرويد
- Browser
- iOS
- ويندوز
ملاحظات خاصة بمنصة أندرويد
- يطلق أندرويد النغمة الافتراضية
Notification ringtone
المحددة في الإعدادSettings/Sound & Display
.