forked from mirrors/gecko-dev
MozReview-Commit-ID: LjrRXr1thc8 --HG-- rename : toolkit/components/payments/.eslintrc.js => browser/components/payments/.eslintrc.js rename : toolkit/components/payments/content/paymentDialogFrameScript.js => browser/components/payments/content/paymentDialogFrameScript.js rename : toolkit/components/payments/content/paymentDialogWrapper.css => browser/components/payments/content/paymentDialogWrapper.css rename : toolkit/components/payments/content/paymentDialogWrapper.js => browser/components/payments/content/paymentDialogWrapper.js rename : toolkit/components/payments/content/paymentDialogWrapper.xhtml => browser/components/payments/content/paymentDialogWrapper.xhtml rename : toolkit/components/payments/docs/index.rst => browser/components/payments/docs/index.rst rename : toolkit/components/payments/jar.mn => browser/components/payments/jar.mn rename : toolkit/components/payments/moz.build => browser/components/payments/moz.build rename : toolkit/components/payments/paymentUIService.js => browser/components/payments/paymentUIService.js rename : toolkit/components/payments/payments.manifest => browser/components/payments/payments.manifest rename : toolkit/components/payments/res/PaymentsStore.js => browser/components/payments/res/PaymentsStore.js rename : toolkit/components/payments/res/components/address-option.css => browser/components/payments/res/components/address-option.css rename : toolkit/components/payments/res/components/address-option.js => browser/components/payments/res/components/address-option.js rename : toolkit/components/payments/res/components/basic-card-option.css => browser/components/payments/res/components/basic-card-option.css rename : toolkit/components/payments/res/components/basic-card-option.js => browser/components/payments/res/components/basic-card-option.js rename : toolkit/components/payments/res/components/currency-amount.js => browser/components/payments/res/components/currency-amount.js rename : toolkit/components/payments/res/components/labelled-checkbox.js => browser/components/payments/res/components/labelled-checkbox.js rename : toolkit/components/payments/res/components/payment-details-item.css => browser/components/payments/res/components/payment-details-item.css rename : toolkit/components/payments/res/components/payment-details-item.js => browser/components/payments/res/components/payment-details-item.js rename : toolkit/components/payments/res/components/rich-option.js => browser/components/payments/res/components/rich-option.js rename : toolkit/components/payments/res/components/rich-select.css => browser/components/payments/res/components/rich-select.css rename : toolkit/components/payments/res/components/rich-select.js => browser/components/payments/res/components/rich-select.js rename : toolkit/components/payments/res/components/shipping-option.css => browser/components/payments/res/components/shipping-option.css rename : toolkit/components/payments/res/components/shipping-option.js => browser/components/payments/res/components/shipping-option.js rename : toolkit/components/payments/res/containers/address-picker.js => browser/components/payments/res/containers/address-picker.js rename : toolkit/components/payments/res/containers/basic-card-form.js => browser/components/payments/res/containers/basic-card-form.js rename : toolkit/components/payments/res/containers/order-details.css => browser/components/payments/res/containers/order-details.css rename : toolkit/components/payments/res/containers/order-details.js => browser/components/payments/res/containers/order-details.js rename : toolkit/components/payments/res/containers/payment-dialog.js => browser/components/payments/res/containers/payment-dialog.js rename : toolkit/components/payments/res/containers/payment-method-picker.js => browser/components/payments/res/containers/payment-method-picker.js rename : toolkit/components/payments/res/containers/shipping-option-picker.js => browser/components/payments/res/containers/shipping-option-picker.js rename : toolkit/components/payments/res/debugging.css => browser/components/payments/res/debugging.css rename : toolkit/components/payments/res/debugging.html => browser/components/payments/res/debugging.html rename : toolkit/components/payments/res/debugging.js => browser/components/payments/res/debugging.js rename : toolkit/components/payments/res/mixins/ObservedPropertiesMixin.js => browser/components/payments/res/mixins/ObservedPropertiesMixin.js rename : toolkit/components/payments/res/mixins/PaymentStateSubscriberMixin.js => browser/components/payments/res/mixins/PaymentStateSubscriberMixin.js rename : toolkit/components/payments/res/paymentRequest.css => browser/components/payments/res/paymentRequest.css rename : toolkit/components/payments/res/paymentRequest.js => browser/components/payments/res/paymentRequest.js rename : toolkit/components/payments/res/paymentRequest.xhtml => browser/components/payments/res/paymentRequest.xhtml rename : toolkit/components/payments/res/unprivileged-fallbacks.js => browser/components/payments/res/unprivileged-fallbacks.js rename : toolkit/components/payments/res/vendor/custom-elements.min.js => browser/components/payments/res/vendor/custom-elements.min.js rename : toolkit/components/payments/res/vendor/custom-elements.min.js.map => browser/components/payments/res/vendor/custom-elements.min.js.map rename : toolkit/components/payments/server.py => browser/components/payments/server.py rename : toolkit/components/payments/test/PaymentTestUtils.jsm => browser/components/payments/test/PaymentTestUtils.jsm rename : toolkit/components/payments/test/browser/.eslintrc.js => browser/components/payments/test/browser/.eslintrc.js rename : toolkit/components/payments/test/browser/blank_page.html => browser/components/payments/test/browser/blank_page.html rename : toolkit/components/payments/test/browser/browser.ini => browser/components/payments/test/browser/browser.ini rename : toolkit/components/payments/test/browser/browser_card_edit.js => browser/components/payments/test/browser/browser_card_edit.js rename : toolkit/components/payments/test/browser/browser_change_shipping.js => browser/components/payments/test/browser/browser_change_shipping.js rename : toolkit/components/payments/test/browser/browser_host_name.js => browser/components/payments/test/browser/browser_host_name.js rename : toolkit/components/payments/test/browser/browser_profile_storage.js => browser/components/payments/test/browser/browser_profile_storage.js rename : toolkit/components/payments/test/browser/browser_request_serialization.js => browser/components/payments/test/browser/browser_request_serialization.js rename : toolkit/components/payments/test/browser/browser_request_shipping.js => browser/components/payments/test/browser/browser_request_shipping.js rename : toolkit/components/payments/test/browser/browser_request_summary.js => browser/components/payments/test/browser/browser_request_summary.js rename : toolkit/components/payments/test/browser/browser_shippingaddresschange_error.js => browser/components/payments/test/browser/browser_shippingaddresschange_error.js rename : toolkit/components/payments/test/browser/browser_show_dialog.js => browser/components/payments/test/browser/browser_show_dialog.js rename : toolkit/components/payments/test/browser/browser_total.js => browser/components/payments/test/browser/browser_total.js rename : toolkit/components/payments/test/browser/head.js => browser/components/payments/test/browser/head.js rename : toolkit/components/payments/test/mochitest/.eslintrc.js => browser/components/payments/test/mochitest/.eslintrc.js rename : toolkit/components/payments/test/mochitest/formautofill/mochitest.ini => browser/components/payments/test/mochitest/formautofill/mochitest.ini rename : toolkit/components/payments/test/mochitest/formautofill/test_editCreditCard.html => browser/components/payments/test/mochitest/formautofill/test_editCreditCard.html rename : toolkit/components/payments/test/mochitest/mochitest.ini => browser/components/payments/test/mochitest/mochitest.ini rename : toolkit/components/payments/test/mochitest/payments_common.js => browser/components/payments/test/mochitest/payments_common.js rename : toolkit/components/payments/test/mochitest/test_ObservedPropertiesMixin.html => browser/components/payments/test/mochitest/test_ObservedPropertiesMixin.html rename : toolkit/components/payments/test/mochitest/test_PaymentStateSubscriberMixin.html => browser/components/payments/test/mochitest/test_PaymentStateSubscriberMixin.html rename : toolkit/components/payments/test/mochitest/test_PaymentsStore.html => browser/components/payments/test/mochitest/test_PaymentsStore.html rename : toolkit/components/payments/test/mochitest/test_address_picker.html => browser/components/payments/test/mochitest/test_address_picker.html rename : toolkit/components/payments/test/mochitest/test_basic_card_form.html => browser/components/payments/test/mochitest/test_basic_card_form.html rename : toolkit/components/payments/test/mochitest/test_currency_amount.html => browser/components/payments/test/mochitest/test_currency_amount.html rename : toolkit/components/payments/test/mochitest/test_labelled_checkbox.html => browser/components/payments/test/mochitest/test_labelled_checkbox.html rename : toolkit/components/payments/test/mochitest/test_order_details.html => browser/components/payments/test/mochitest/test_order_details.html rename : toolkit/components/payments/test/mochitest/test_payer_address_picker.html => browser/components/payments/test/mochitest/test_payer_address_picker.html rename : toolkit/components/payments/test/mochitest/test_payment_details_item.html => browser/components/payments/test/mochitest/test_payment_details_item.html rename : toolkit/components/payments/test/mochitest/test_payment_dialog.html => browser/components/payments/test/mochitest/test_payment_dialog.html rename : toolkit/components/payments/test/mochitest/test_payment_method_picker.html => browser/components/payments/test/mochitest/test_payment_method_picker.html rename : toolkit/components/payments/test/mochitest/test_rich_select.html => browser/components/payments/test/mochitest/test_rich_select.html rename : toolkit/components/payments/test/mochitest/test_shipping_option_picker.html => browser/components/payments/test/mochitest/test_shipping_option_picker.html rename : toolkit/components/payments/test/unit/.eslintrc.js => browser/components/payments/test/unit/.eslintrc.js rename : toolkit/components/payments/test/unit/head.js => browser/components/payments/test/unit/head.js rename : toolkit/components/payments/test/unit/test_response_creation.js => browser/components/payments/test/unit/test_response_creation.js rename : toolkit/components/payments/test/unit/xpcshell.ini => browser/components/payments/test/unit/xpcshell.ini
200 lines
6.1 KiB
JavaScript
200 lines
6.1 KiB
JavaScript
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
/* import-globals-from ../../../../../browser/extensions/formautofill/content/autofillEditForms.js*/
|
|
import LabelledCheckbox from "../components/labelled-checkbox.js";
|
|
import PaymentStateSubscriberMixin from "../mixins/PaymentStateSubscriberMixin.js";
|
|
import paymentRequest from "../paymentRequest.js";
|
|
|
|
/* import-globals-from ../unprivileged-fallbacks.js */
|
|
|
|
/**
|
|
* <basic-card-form></basic-card-form>
|
|
*
|
|
* XXX: Bug 1446164 - This form isn't localized when used via this custom element
|
|
* as it will be much easier to share the logic once we switch to Fluent.
|
|
*/
|
|
|
|
export default class BasicCardForm extends PaymentStateSubscriberMixin(HTMLElement) {
|
|
constructor() {
|
|
super();
|
|
|
|
this.genericErrorText = document.createElement("div");
|
|
|
|
this.backButton = document.createElement("button");
|
|
this.backButton.addEventListener("click", this);
|
|
|
|
this.saveButton = document.createElement("button");
|
|
this.saveButton.addEventListener("click", this);
|
|
|
|
this.persistCheckbox = new LabelledCheckbox();
|
|
|
|
// The markup is shared with form autofill preferences.
|
|
let url = "formautofill/editCreditCard.xhtml";
|
|
this.promiseReady = this._fetchMarkup(url).then(doc => {
|
|
this.form = doc.getElementById("form");
|
|
return this.form;
|
|
});
|
|
}
|
|
|
|
_fetchMarkup(url) {
|
|
return new Promise((resolve, reject) => {
|
|
let xhr = new XMLHttpRequest();
|
|
xhr.responseType = "document";
|
|
xhr.addEventListener("error", reject);
|
|
xhr.addEventListener("load", evt => {
|
|
resolve(xhr.response);
|
|
});
|
|
xhr.open("GET", url);
|
|
xhr.send();
|
|
});
|
|
}
|
|
|
|
connectedCallback() {
|
|
this.promiseReady.then(form => {
|
|
this.appendChild(form);
|
|
|
|
let record = {};
|
|
let addresses = [];
|
|
this.formHandler = new EditCreditCard({
|
|
form,
|
|
}, record, addresses, {
|
|
isCCNumber: PaymentDialogUtils.isCCNumber,
|
|
getAddressLabel: PaymentDialogUtils.getAddressLabel,
|
|
});
|
|
|
|
this.appendChild(this.persistCheckbox);
|
|
this.appendChild(this.genericErrorText);
|
|
this.appendChild(this.backButton);
|
|
this.appendChild(this.saveButton);
|
|
// Only call the connected super callback(s) once our markup is fully
|
|
// connected, including the shared form fetched asynchronously.
|
|
super.connectedCallback();
|
|
});
|
|
}
|
|
|
|
render(state) {
|
|
this.backButton.textContent = this.dataset.backButtonLabel;
|
|
this.saveButton.textContent = this.dataset.saveButtonLabel;
|
|
this.persistCheckbox.label = this.dataset.persistCheckboxLabel;
|
|
|
|
let record = {};
|
|
let {
|
|
page,
|
|
savedAddresses,
|
|
selectedShippingAddress,
|
|
} = state;
|
|
let basicCards = paymentRequest.getBasicCards(state);
|
|
|
|
this.genericErrorText.textContent = page.error;
|
|
|
|
let editing = !!page.guid;
|
|
this.form.querySelector("#cc-number").disabled = editing;
|
|
|
|
// If a card is selected we want to edit it.
|
|
if (editing) {
|
|
record = basicCards[page.guid];
|
|
if (!record) {
|
|
throw new Error("Trying to edit a non-existing card: " + page.guid);
|
|
}
|
|
// When editing an existing record, prevent changes to persistence
|
|
this.persistCheckbox.hidden = true;
|
|
} else {
|
|
if (selectedShippingAddress) {
|
|
record.billingAddressGUID = selectedShippingAddress;
|
|
}
|
|
// Adding a new record: default persistence to checked when in a not-private session
|
|
this.persistCheckbox.hidden = false;
|
|
this.persistCheckbox.checked = !state.isPrivate;
|
|
}
|
|
|
|
this.formHandler.loadRecord(record, savedAddresses);
|
|
}
|
|
|
|
handleEvent(event) {
|
|
switch (event.type) {
|
|
case "click": {
|
|
this.onClick(event);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
onClick(evt) {
|
|
switch (evt.target) {
|
|
case this.backButton: {
|
|
this.requestStore.setState({
|
|
page: {
|
|
id: "payment-summary",
|
|
},
|
|
});
|
|
break;
|
|
}
|
|
case this.saveButton: {
|
|
this.saveRecord();
|
|
break;
|
|
}
|
|
default: {
|
|
throw new Error("Unexpected click target");
|
|
}
|
|
}
|
|
}
|
|
|
|
saveRecord() {
|
|
let record = this.formHandler.buildFormObject();
|
|
let {
|
|
page,
|
|
tempBasicCards,
|
|
} = this.requestStore.getState();
|
|
let editing = !!page.guid;
|
|
let tempRecord = editing && tempBasicCards[page.guid];
|
|
|
|
for (let editableFieldName of ["cc-name", "cc-exp-month", "cc-exp-year"]) {
|
|
record[editableFieldName] = record[editableFieldName] || "";
|
|
}
|
|
|
|
// Only save the card number if we're saving a new record, otherwise we'd
|
|
// overwrite the unmasked card number with the masked one.
|
|
if (!editing) {
|
|
record["cc-number"] = record["cc-number"] || "";
|
|
}
|
|
|
|
if (!tempRecord && this.persistCheckbox.checked) {
|
|
log.debug(`BasicCardForm: persisting creditCard record: ${page.guid || "(new)"}`);
|
|
paymentRequest.updateAutofillRecord("creditCards", record, page.guid, {
|
|
errorStateChange: {
|
|
page: {
|
|
id: "basic-card-page",
|
|
error: this.dataset.errorGenericSave,
|
|
},
|
|
},
|
|
preserveOldProperties: true,
|
|
selectedStateKey: "selectedPaymentCard",
|
|
successStateChange: {
|
|
page: {
|
|
id: "payment-summary",
|
|
},
|
|
},
|
|
});
|
|
} else {
|
|
// This record will never get inserted into the store
|
|
// so we generate a faux-guid for a new record
|
|
record.guid = page.guid || "temp-" + Math.abs(Math.random() * 0xffffffff|0);
|
|
|
|
log.debug(`BasicCardForm: saving temporary record: ${record.guid}`);
|
|
this.requestStore.setState({
|
|
page: {
|
|
id: "payment-summary",
|
|
},
|
|
selectedPaymentCard: record.guid,
|
|
tempBasicCards: Object.assign({}, tempBasicCards, {
|
|
// Mix-in any previous values - equivalent to the store's preserveOldProperties: true,
|
|
[record.guid]: Object.assign({}, tempRecord, record),
|
|
}),
|
|
});
|
|
}
|
|
}
|
|
}
|
|
|
|
customElements.define("basic-card-form", BasicCardForm);
|