f1caa0b316
- Disable an ESLint check rather than work around it (by converting `OAuthRememberMe` from a regular class to a static class. - Scope `$` calls inside `OAuthRememberMe`
32 lines
909 B
JavaScript
32 lines
909 B
JavaScript
/**
|
|
* OAuth-based login buttons have a separate "remember me" checkbox.
|
|
*
|
|
* Toggling this checkbox adds/removes a `remember_me` parameter to the
|
|
* login buttons' href, which is passed on to the omniauth callback.
|
|
**/
|
|
|
|
export default class OAuthRememberMe {
|
|
constructor(opts = {}) {
|
|
this.container = opts.container || '';
|
|
this.loginLinkSelector = '.oauth-login';
|
|
}
|
|
|
|
bindEvents() {
|
|
$('#remember_me', this.container).on('click', this.toggleRememberMe);
|
|
}
|
|
|
|
// eslint-disable-next-line class-methods-use-this
|
|
toggleRememberMe(event) {
|
|
const rememberMe = $(event.target).is(':checked');
|
|
|
|
$('.oauth-login', this.container).each((i, element) => {
|
|
const href = $(element).attr('href');
|
|
|
|
if (rememberMe) {
|
|
$(element).attr('href', `${href}?remember_me=1`);
|
|
} else {
|
|
$(element).attr('href', href.replace('?remember_me=1', ''));
|
|
}
|
|
});
|
|
}
|
|
}
|