summaryrefslogtreecommitdiff
path: root/assets/admin/js/prepopulate.js
diff options
context:
space:
mode:
authorprashantsinalkar2019-02-22 15:28:58 +0530
committerprashantsinalkar2019-02-22 15:28:58 +0530
commit05ba8502aadddab8be37b42fec21459730bc1014 (patch)
treecbc04275efc5bce18666961c0a1e9c2bcb5a458a /assets/admin/js/prepopulate.js
parent2b90cf2c2a9c290c4799fbb3a9ca0382aadb28b7 (diff)
downloadpyfoss-05ba8502aadddab8be37b42fec21459730bc1014.tar.gz
pyfoss-05ba8502aadddab8be37b42fec21459730bc1014.tar.bz2
pyfoss-05ba8502aadddab8be37b42fec21459730bc1014.zip
updated the website to django 2.1.7
Diffstat (limited to 'assets/admin/js/prepopulate.js')
-rw-r--r--assets/admin/js/prepopulate.js34
1 files changed, 34 insertions, 0 deletions
diff --git a/assets/admin/js/prepopulate.js b/assets/admin/js/prepopulate.js
new file mode 100644
index 0000000..24f24f9
--- /dev/null
+++ b/assets/admin/js/prepopulate.js
@@ -0,0 +1,34 @@
+(function($) {
+ $.fn.prepopulate = function(dependencies, maxLength) {
+ /*
+ Depends on urlify.js
+ Populates a selected field with the values of the dependent fields,
+ URLifies and shortens the string.
+ dependencies - array of dependent fields id's
+ maxLength - maximum length of the URLify'd string
+ */
+ return this.each(function() {
+ var field = $(this);
+
+ field.data('_changed', false);
+ field.change(function() {
+ field.data('_changed', true);
+ });
+
+ var populate = function () {
+ // Bail if the fields value has changed
+ if (field.data('_changed') == true) return;
+
+ var values = [];
+ $.each(dependencies, function(i, field) {
+ if ($(field).val().length > 0) {
+ values.push($(field).val());
+ }
+ })
+ field.val(URLify(values.join(' '), maxLength));
+ };
+
+ $(dependencies.join(',')).keyup(populate).change(populate).focus(populate);
+ });
+ };
+})(django.jQuery);