aboutsummaryrefslogtreecommitdiffhomepage
path: root/main/app/sprinkles/account/assets/userfrosting/js/pages/register.js
diff options
context:
space:
mode:
authorMarvin Borner2018-06-08 20:03:25 +0200
committerMarvin Borner2018-06-08 20:03:25 +0200
commit92b7dd3335a6572debeacfb5faa82c63a5e67888 (patch)
tree7ebbca22595d542ec5e2912a24a0400ac8f6b113 /main/app/sprinkles/account/assets/userfrosting/js/pages/register.js
parent22a1bb27f94ea33042b0bdd35bef1a5cfa96cc0d (diff)
Some minor fixes
Diffstat (limited to 'main/app/sprinkles/account/assets/userfrosting/js/pages/register.js')
-rw-r--r--main/app/sprinkles/account/assets/userfrosting/js/pages/register.js186
1 files changed, 93 insertions, 93 deletions
diff --git a/main/app/sprinkles/account/assets/userfrosting/js/pages/register.js b/main/app/sprinkles/account/assets/userfrosting/js/pages/register.js
index a311305..4539d9b 100644
--- a/main/app/sprinkles/account/assets/userfrosting/js/pages/register.js
+++ b/main/app/sprinkles/account/assets/userfrosting/js/pages/register.js
@@ -1,93 +1,93 @@
-/**
- * Page-specific Javascript file. Should generally be included as a separate asset bundle in your page template.
- * example: {{ assets.js('js/pages/sign-in-or-register') | raw }}
- *
- * This script depends on validation rules specified in pages/partials/page.js.twig.
- *
- * Target page: account/register
- */
-$(document).ready(function () {
- // TOS modal
- $(this).find('.js-show-tos').click(function () {
- $("body").ufModal({
- sourceUrl: site.uri.public + "/modals/account/tos",
- msgTarget: $("#alerts-page")
- });
- });
-
- // Auto-generate username when name is filled in
- var autoGenerate = true;
- $("#register").find('input[name=first_name], input[name=last_name]').on('input change', function () {
- if (!autoGenerate) {
- return;
- }
-
- var form = $("#register");
-
- var firstName = form.find('input[name=first_name]').val().trim();
- var lastName = form.find('input[name=last_name]').val().trim();
-
- if (!firstName && !lastName) {
- return;
- }
-
- var userName = getSlug(firstName + ' ' + lastName, {
- separator: '.'
- });
- // Set slug
- form.find('input[name=user_name]').val(userName);
- });
-
- // Autovalidate username field on a delay
- var timer;
- $("#register").find('input[name=first_name], input[name=last_name], input[name=user_name]').on('input change', function () {
- clearTimeout(timer); // Clear the timer so we don't end up with dupes.
- timer = setTimeout(function () { // assign timer a new timeout
- $("#register").find('input[name=user_name]').valid();
- }, 50);
- });
-
- // Enable/disable username suggestions in registration page
- $("#register").find('#form-register-username-suggest').on('click', function (e) {
- e.preventDefault();
- var form = $("#register");
- $.getJSON(site.uri.public + '/account/suggest-username')
- .done(function (data) {
- // Set suggestion
- form.find('input[name=user_name]').val(data.user_name);
- });
- });
-
- // Turn off autogenerate when someone enters stuff manually in user_name
- $("#register").find('input[name=user_name]').on('input', function () {
- autoGenerate = false;
- });
-
- // Add remote rule for checking usernames on the fly
- var registrationValidators = $.extend(
- true, // deep extend
- page.validators.register,
- {
- rules: {
- user_name: {
- remote: {
- url: site.uri.public + '/account/check-username',
- dataType: 'text'
- }
- }
- }
- }
- );
-
- // Handles form submission
- $("#register").ufForm({
- validators: registrationValidators,
- msgTarget: $("#alerts-page"),
- keyupDelay: 500
- }).on("submitSuccess.ufForm", function () {
- window.location.reload();
- }).on("submitError.ufForm", function () {
- // Reload captcha
- $("#captcha").captcha();
- });
-});
+/**
+ * Page-specific Javascript file. Should generally be included as a separate asset bundle in your page template.
+ * example: {{ assets.js('js/pages/sign-in-or-register') | raw }}
+ *
+ * This script depends on validation rules specified in pages/partials/page.js.twig.
+ *
+ * Target page: account/register
+ */
+$(document).ready(function () {
+ // TOS modal
+ $(this).find('.js-show-tos').click(function () {
+ $("body").ufModal({
+ sourceUrl: site.uri.public + "/modals/account/tos",
+ msgTarget: $("#alerts-page")
+ });
+ });
+
+ // Auto-generate username when name is filled in
+ var autoGenerate = true;
+ $("#register").find('input[name=first_name], input[name=last_name]').on('input change', function () {
+ if (!autoGenerate) {
+ return;
+ }
+
+ var form = $("#register");
+
+ var firstName = form.find('input[name=first_name]').val().trim();
+ var lastName = form.find('input[name=last_name]').val().trim();
+
+ if (!firstName && !lastName) {
+ return;
+ }
+
+ var userName = getSlug(firstName + ' ' + lastName, {
+ separator: '.'
+ });
+ // Set slug
+ form.find('input[name=user_name]').val(userName);
+ });
+
+ // Autovalidate username field on a delay
+ var timer;
+ $("#register").find('input[name=first_name], input[name=last_name], input[name=user_name]').on('input change', function () {
+ clearTimeout(timer); // Clear the timer so we don't end up with dupes.
+ timer = setTimeout(function () { // assign timer a new timeout
+ $("#register").find('input[name=user_name]').valid();
+ }, 50);
+ });
+
+ // Enable/disable username suggestions in registration page
+ $("#register").find('#form-register-username-suggest').on('click', function (e) {
+ e.preventDefault();
+ var form = $("#register");
+ $.getJSON(site.uri.public + '/account/suggest-username')
+ .done(function (data) {
+ // Set suggestion
+ form.find('input[name=user_name]').val(data.user_name);
+ });
+ });
+
+ // Turn off autogenerate when someone enters stuff manually in user_name
+ $("#register").find('input[name=user_name]').on('input', function () {
+ autoGenerate = false;
+ });
+
+ // Add remote rule for checking usernames on the fly
+ var registrationValidators = $.extend(
+ true, // deep extend
+ page.validators.register,
+ {
+ rules: {
+ user_name: {
+ remote: {
+ url: site.uri.public + '/account/check-username',
+ dataType: 'text'
+ }
+ }
+ }
+ }
+ );
+
+ // Handles form submission
+ $("#register").ufForm({
+ validators: registrationValidators,
+ msgTarget: $("#alerts-page"),
+ keyupDelay: 500
+ }).on("submitSuccess.ufForm", function () {
+ window.location.reload();
+ }).on("submitError.ufForm", function () {
+ // Reload captcha
+ $("#captcha").captcha();
+ });
+});