Tengo un problema que me está volviendo loco. Estoy intentando modificar el selector de apertura para admitir Facebook. Estoy usando RPXNow como mi proveedor, por lo que requiere que el formulario se envíe a una URL diferente a la estándar.Cambiar la acción de un formulario con JavaScript/jQuery
Por ejemplo. RpxNow me obliga a configurar mi formulario como el siguiente:
<form action="https://wikipediamaze.rpxnow.com/openid/start?token_url=...">
Esto funciona para todos los proveedores, a excepción Facebook y Myspace. Los que requieren que el formulario sea enviado a una dirección URL diferente como esto:
<form action="https://wikipediamaze.rpxnow.com/facebook/start?token_url=...">
y
<form action="https://wikipediamaze.rpxnow.com/myspace/start?token_url=...">
El selector de ID abierto tiene un montón de botones en la forma que representan cada uno de los proveedores de OpenID . Lo que trato de hacer es detectar cuando se hace clic en el botón de Facebook o de Myspace y se cambia la acción en el formulario antes de enviarlo. Sin embargo, no está funcionando. Aquí está mi código.
He intentado varias variaciones, todas con el mismo "no es compatible" excepción
$("#openid_form").attr("action", form_url)
document.forms[0].action = form_url
¿Alguna sugerencia?
actualización
Aquí hay más información sobre el código. He omitido algo por brevedad. Lo único que he hecho es agregar la sección de Facebook al objeto "providers_large" (que agrega con éxito el logotipo al sitio web), y en lugar de proporcionar una url que identifica al usuario, estoy creando una propiedad llamada "form_url" que es a lo que quiero establecer la acción de mi formulario. Si mira el título de la sección "Haga clic en la imagen del proveedor", verá dónde estoy comprobando la presencia de la propiedad "form_url" y el uso de jQuery para cambiar la acción y enviar el formulario. Sin embargo, cuando paso por el JavaScript en modo de depuración, me dice que es una operación no válida.
var providers_large = {
google: {
name: 'Google',
url: 'https://www.google.com/accounts/o8/id'
},
facebook: {
name: 'Facebook',
form_url: 'http://wikipediamaze.rpxnow.com/facebook/start?token_url=http://www.wikipediamaze.com/Accounts/Logon'
},
};
var providers_small = {
myopenid: {
name: 'MyOpenID',
label: 'Enter your MyOpenID username.',
url: 'http://{username}.myopenid.com/'
},
livejournal: {
name: 'LiveJournal',
label: 'Enter your Livejournal username.',
url: 'http://{username}.livejournal.com/'
},
flickr: {
name: 'Flickr',
label: 'Enter your Flickr username.',
url: 'http://flickr.com/{username}/'
},
technorati: {
name: 'Technorati',
label: 'Enter your Technorati username.',
url: 'http://technorati.com/people/technorati/{username}/'
},
wordpress: {
name: 'Wordpress',
label: 'Enter your Wordpress.com username.',
url: 'http://{username}.wordpress.com/'
},
blogger: {
name: 'Blogger',
label: 'Your Blogger account',
url: 'http://{username}.blogspot.com/'
},
verisign: {
name: 'Verisign',
label: 'Your Verisign username',
url: 'http://{username}.pip.verisignlabs.com/'
},
vidoop: {
name: 'Vidoop',
label: 'Your Vidoop username',
url: 'http://{username}.myvidoop.com/'
},
verisign: {
name: 'Verisign',
label: 'Your Verisign username',
url: 'http://{username}.pip.verisignlabs.com/'
},
claimid: {
name: 'ClaimID',
label: 'Your ClaimID username',
url: 'http://claimid.com/{username}'
}
};
var providers = $.extend({}, providers_large, providers_small);
var openid = {
cookie_expires: 6*30, // 6 months.
cookie_name: 'openid_provider',
cookie_path: '/',
img_path: 'images/',
input_id: null,
provider_url: null,
init: function(input_id) {
var openid_btns = $('#openid_btns');
this.input_id = input_id;
$('#openid_choice').show();
$('#openid_input_area').empty();
// add box for each provider
for (id in providers_large) {
openid_btns.append(this.getBoxHTML(providers_large[id], 'large', '.gif'));
}
if (providers_small) {
openid_btns.append('<br/>');
for (id in providers_small) {
openid_btns.append(this.getBoxHTML(providers_small[id], 'small', '.ico'));
}
}
$('#openid_form').submit(this.submit);
var box_id = this.readCookie();
if (box_id) {
this.signin(box_id, true);
}
},
getBoxHTML: function(provider, box_size, image_ext) {
var box_id = provider["name"].toLowerCase();
return '<a title="'+provider["name"]+'" href="javascript: openid.signin(\''+ box_id +'\');"' +
' style="background: #FFF url(' + this.img_path + box_id + image_ext+') no-repeat center center" ' +
'class="' + box_id + ' openid_' + box_size + '_btn"></a>';
},
/* Provider image click */
signin: function(box_id, onload) {
var provider = providers[box_id];
if (! provider) {
return;
}
this.highlight(box_id);
this.setCookie(box_id);
// prompt user for input?
if (provider['label']) {
this.useInputBox(provider);
this.provider_url = provider['url'];
}
else if(provider['form_url']) {
$('#openid_form').attr("action", provider['form_url']);
$('#openid_form').submit();
}
else {
this.setOpenIdUrl(provider['url']);
if (! onload) {
$('#openid_form').submit();
}
}
},
/* Sign-in button click */
submit: function() {
var url = openid.provider_url;
if (url) {
url = url.replace('{username}', $('#openid_username').val());
openid.setOpenIdUrl(url);
}
return true;
},
setOpenIdUrl: function (url) {
var hidden = $('#'+this.input_id);
if (hidden.length > 0) {
hidden.value = url;
} else {
$('#openid_form').append('<input type="hidden" id="' + this.input_id + '" name="' + this.input_id + '" value="'+url+'"/>');
}
},
highlight: function (box_id) {
// remove previous highlight.
var highlight = $('#openid_highlight');
if (highlight) {
highlight.replaceWith($('#openid_highlight a')[0]);
}
// add new highlight.
$('.'+box_id).wrap('<div id="openid_highlight"></div>');
},
setCookie: function (value) {
var date = new Date();
date.setTime(date.getTime()+(this.cookie_expires*24*60*60*1000));
var expires = "; expires="+date.toGMTString();
document.cookie = this.cookie_name+"="+value+expires+"; path=" + this.cookie_path;
},
readCookie: function() {
var nameEQ = this.cookie_name + "=";
var ca = document.cookie.split(';');
for(var i=0;i < ca.length;i++) {
var c = ca[i];
while (c.charAt(0)==' ') c = c.substring(1,c.length);
if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
}
return null;
},
useInputBox: function (provider) {
var input_area = $('#openid_input_area');
var html = '';
var id = 'openid_username';
var value = '';
var label = provider['label'];
var style = '';
if (label) {
html = '<p>' + label + '</p>';
}
if (provider['name'] == 'OpenID') {
id = this.input_id;
value = 'http://';
style = 'background:#FFF url('+this.img_path+'openid-inputicon.gif) no-repeat scroll 0 50%; padding-left:18px;';
}
html += '<input id="'+id+'" type="text" style="'+style+'" name="'+id+'" value="'+value+'" />' +
'<input id="openid_submit" type="submit" value="Sign-In"/>';
input_area.empty();
input_area.append(html);
$('#'+id).focus();
}
};
Realmente necesitamos más código. ¿Cómo se ve el HTML de los botones? ¿Por qué no le das a la forma abierta una identificación para una fácil selección? ¿Está fuera de tu control? –
No estoy seguro de qué más código puedo darle. El problema no es mi selección. Puedo llamar con éxito $ ("# openid_form"). Submit(). El problema es que cuando trato de cambiar el atributo de acción del formulario arroja un error. – Micah
@Micah - ¿Pudo resolver este problema? ¿Mi respuesta te ayudó? –