mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-01 05:43:46 +00:00
Bug 943234 - Part 1: return mozContact in updateContact. r=vicamo
From 237b1d77da6e1470979dfc422e3f2e2f30066b43 Mon Sep 17 00:00:00 2001 --- dom/system/gonk/RILContentHelper.js | 29 ++++++++++++++++++++++++++++- dom/system/gonk/ril_worker.js | 7 +++++-- 2 files changed, 33 insertions(+), 3 deletions(-)
This commit is contained in:
parent
52b74dd5ac
commit
5e337e9ab6
@ -1102,6 +1102,7 @@ RILContentHelper.prototype = {
|
||||
|
||||
let request = Services.DOMRequest.createRequest(window);
|
||||
let requestId = this.getRequestId(request);
|
||||
this._windowsMap[requestId] = window;
|
||||
|
||||
// Parsing nsDOMContact to Icc Contact format
|
||||
let iccContact = {};
|
||||
@ -1728,7 +1729,7 @@ RILContentHelper.prototype = {
|
||||
this.handleReadIccContacts(data);
|
||||
break;
|
||||
case "RIL:UpdateIccContact":
|
||||
this.handleSimpleRequest(data.requestId, data.errorMsg, null);
|
||||
this.handleUpdateIccContact(data);
|
||||
break;
|
||||
case "RIL:DataError":
|
||||
this.updateConnectionInfo(data, this.rilContexts[clientId].dataConnectionInfo);
|
||||
@ -1894,6 +1895,32 @@ RILContentHelper.prototype = {
|
||||
this.fireRequestSuccess(message.requestId, result);
|
||||
},
|
||||
|
||||
handleUpdateIccContact: function handleUpdateIccContact(message) {
|
||||
if (message.errorMsg) {
|
||||
this.fireRequestError(message.requestId, message.errorMsg);
|
||||
return;
|
||||
}
|
||||
|
||||
let window = this._windowsMap[message.requestId];
|
||||
delete this._windowsMap[message.requestId];
|
||||
let iccContact = message.contact;
|
||||
let prop = {name: [iccContact.alphaId], tel: [{value: iccContact.number}]};
|
||||
if (iccContact.email) {
|
||||
prop.email = [{value: iccContact.email}];
|
||||
}
|
||||
|
||||
// ANR - Additional Number
|
||||
let anrLen = iccContact.anr ? iccContact.anr.length : 0;
|
||||
for (let i = 0; i < anrLen; i++) {
|
||||
prop.tel.push({value: iccContact.anr[i]});
|
||||
}
|
||||
|
||||
let contact = new window.mozContact(prop);
|
||||
contact.id = iccContact.contactId;
|
||||
|
||||
this.fireRequestSuccess(message.requestId, contact);
|
||||
},
|
||||
|
||||
handleVoicemailNotification: function handleVoicemailNotification(clientId,
|
||||
message) {
|
||||
let changed = false;
|
||||
|
@ -903,6 +903,9 @@ let RIL = {
|
||||
*/
|
||||
updateICCContact: function updateICCContact(options) {
|
||||
let onsuccess = function onsuccess() {
|
||||
let recordIndex =
|
||||
contact.pbrIndex * ICC_MAX_LINEAR_FIXED_RECORDS + contact.recordId;
|
||||
contact.contactId = this.iccInfo.iccid + recordIndex;
|
||||
// Reuse 'options' to get 'requestId' and 'contactType'.
|
||||
RIL.sendChromeMessage(options);
|
||||
}.bind(this);
|
||||
@ -919,15 +922,15 @@ let RIL = {
|
||||
|
||||
let contact = options.contact;
|
||||
let iccid = RIL.iccInfo.iccid;
|
||||
let isValidRecordId = false;
|
||||
if (typeof contact.contactId === "string" &&
|
||||
contact.contactId.startsWith(iccid)) {
|
||||
let recordIndex = contact.contactId.substring(iccid.length);
|
||||
contact.pbrIndex = Math.floor(recordIndex / ICC_MAX_LINEAR_FIXED_RECORDS);
|
||||
contact.recordId = recordIndex % ICC_MAX_LINEAR_FIXED_RECORDS;
|
||||
isValidRecordId = contact.recordId > 0 && contact.recordId < 0xff;
|
||||
}
|
||||
|
||||
let isValidRecordId = contact.recordId > 0 && contact.recordId < 0xff;
|
||||
|
||||
if (DEBUG) {
|
||||
debug("Update ICC Contact " + JSON.stringify(contact));
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user