]> git.mjollnir.org Git - moodle.git/commitdiff
MDL-8096 user edit form - some more refactoring and fixes
authorskodak <skodak>
Fri, 26 Jan 2007 18:42:47 +0000 (18:42 +0000)
committerskodak <skodak>
Fri, 26 Jan 2007 18:42:47 +0000 (18:42 +0000)
user/edit.php
user/edit_form.php
user/editadvanced.php
user/editadvanced_form.php
user/editlib.php [moved from user/edit_form_common.php with 83% similarity]

index 79db2c500a48ba0a56a46c6a45f30a75370a4f59..2502b59ae24f99bae7a0a1dca0c1bc507693f7dc 100644 (file)
@@ -3,6 +3,7 @@
     require_once('../config.php');
     require_once($CFG->libdir.'/gdlib.php');
     require_once($CFG->dirroot.'/user/edit_form.php');
+    require_once($CFG->dirroot.'/user/editlib.php');
     require_once($CFG->dirroot.'/user/profile/lib.php');
 
     $course = optional_param('course', SITEID, PARAM_INT);   // course id (defaults to Site)
         redirect($CFG->wwwroot . "/user/view.php?course={$course->id}");
     }
 
-    //load preferences
-    if (!empty($user->id) and $preferences = get_user_preferences(null, null, $user->id)) {
-        foreach($preferences as $name=>$value) {
-            $user->{'preference_'.$name} = $value;
-        }
-    }
-    //TODO: Load the custom profile fields
+    //load user preferences
+    useredit_load_preferences($user);
+
+    //Load custom profile fields data
+    profile_load_data($user);
 
     //create form
     $userform = new user_edit_form();
         }
 
         //update preferences
-        $ua = (array)$usernew;
-        foreach($ua as $key=>$value) {
-            if (strpos($key, 'preference_') === 0) {
-                $name = substr($key, strlen('preference_'));
-                set_user_preference($name, $value, $usernew->id);
-            }
-        }
+        useredit_update_user_preference($usernew);
 
+        //update user picture
         if (!empty($CFG->gdversion) and empty($CFG->disableuserimages)) {
-             //update user picture
-            if ($usernew->deletepicture) {
-                //TODO - delete the files
-                set_field('user', 'picture', 0, 'id', $usernew->id);
-            } else if ($usernew->picture = save_profile_image($usernew->id, $userform->get_um(), 'users')) {
-                set_field('user', 'picture', 1, 'id', $usernew->id);
-            }
+            useredit_update_picture($usernew, $userform);
         }
 
         // update mail bounces
-        if ($user->email !== $usernew->email) {
-            set_bounce_count($usernew,true);
-            set_send_count($usernew,true);
-        }
+        useredit_update_bounces($user, $usernew);
 
-        /// Update forum track preference.
-        if (($usernew->trackforums != $user->trackforums) and !$usernew->trackforums) {
-            require_once($CFG->dirroot.'/mod/forum/lib.php');
-            forum_tp_delete_read_records($usernew->id);
-        }
+        /// update forum track preference
+        useredit_update_trackforums($user, $usernew);
 
-        //TODO: Save the custom profile fields
+        // save custom profile fields data
+        profile_save_data($usernew);
 
         // Override old $USER session variable
         $usernew = (array)get_record('user', 'id', $newuser->id); // reload from db
index 38c888ebcd62952deee6eb80021d216266f7bb05..f7d7173225bf065fca01bc04e59ff750f3b0a797 100644 (file)
@@ -19,7 +19,8 @@ class user_edit_form extends moodleform {
         /// Print the required moodle fields first
         $mform->addElement('header', 'moodle', $strrequired);
 
-        require('edit_form_common.php');
+        /// shared fields
+        useredit_shared_definition($mform);
 
         /// extra settigs
         $mform->addRule('description', $strrequired, 'required', null, 'client');
@@ -91,7 +92,7 @@ class user_edit_form extends moodleform {
         } else if (($usernew->email !== $user->email) and record_exists('user', 'email', $usernew->email, 'mnethostid', $CFG->mnet_localhost_id)) {
             $err['email'] = get_string('emailexists');
         }
-        
+
         if ($usernew->email === $user->email and over_bounce_threshold($user)) {
             $err['email'] = get_string('toomanybounces');
         }
index bebcc019ce5e88ed651cfef7ba376cce5363c578..5a2c1b55641dbf604589f9f344ce7cbfc613b9dd 100644 (file)
@@ -4,6 +4,7 @@
     require_once($CFG->libdir.'/gdlib.php');
     require_once($CFG->libdir.'/adminlib.php');
     require_once($CFG->dirroot.'/user/editadvanced_form.php');
+    require_once($CFG->dirroot.'/user/editlib.php');
     require_once($CFG->dirroot.'/user/profile/lib.php');
 
     $id     = optional_param('id', $USER->id, PARAM_INT);    // user id; -1 if creating new user
         print_error('guestnoeditprofileother');
     }
 
-    //load preferences
-    if (!empty($user->id) and $preferences = get_user_preferences(null, null, $user->id)) {
-        foreach($preferences as $name=>$value) {
-            $user->{'preference_'.$name} = $value;
-        }
-    }
-    
+    //load user preferences
+    useredit_load_preferences($user);
+
     //Load custom profile fields data
     profile_load_data($user);
 
@@ -64,7 +61,7 @@
         if (empty($usernew->auth)) {
             //user editing self
             $authplugin = get_auth_plugin($user->auth);
-            unset($usernew->auth);
+            unset($usernew->auth); //can not change/remove
         } else {
             $authplugin = get_auth_plugin($usernew->auth);
         }
@@ -73,7 +70,7 @@
         $usernew->timemodified = time();
 
         if ($usernew->id == -1) {
-            //TODO check out that it makes sense to create account with this auth plugin and what to do with the password
+            //TODO check out if it makes sense to create account with this auth plugin and what to do with the password
             unset($usernew->id);
             $usernew->mnethostid = $CFG->mnet_localhost_id; // always local user
             $usernew->confirmed  = 1;
             }
         }
 
-
         //update preferences
-        $ua = (array)$usernew;
-        foreach($ua as $key=>$value) {
-            if (strpos($key, 'preference_') === 0) {
-                $name = substr($key, strlen('preference_'));
-                set_user_preference($name, $value, $usernew->id);
-            }
-        }
+        useredit_update_user_preference($usernew);
 
         //update user picture
         if (!empty($CFG->gdversion)) {
-            if ($usernew->deletepicture) {
-                //TODO - delete the files
-                set_field('user', 'picture', 0, 'id', $usernew->id);
-            } else if ($usernew->picture = save_profile_image($usernew->id, $userform->get_um(), 'users')) {
-                set_field('user', 'picture', 1, 'id', $usernew->id);
-            }
+            useredit_update_picture($usernew, $userform);
         }
 
         // update mail bounces
-        if ($user->email !== $usernew->email) {
-            set_bounce_count($usernew,true);
-            set_send_count($usernew,true);
-        }
+        useredit_update_bounces($user, $usernew);
 
-        /// Update forum track preference.
-        if (($usernew->trackforums != $user->trackforums) and !$usernew->trackforums) {
-            require_once($CFG->dirroot.'/mod/forum/lib.php');
-            forum_tp_delete_read_records($usernew->id);
-        }
+        /// update forum track preference
+        useredit_update_trackforums($user, $usernew);
 
         // save custom profile fields data
         profile_save_data($usernew);
                 unset($USER->newadminuser);
                 // redirect to admin/ to continue with installation
                 redirect("$CFG->wwwroot/$CFG->admin/");
-            } else { 
+            } else {
                 redirect("$CFG->wwwroot/user/view.php?id=$USER->id&course=$course->id");
             }
         } else {
index 88a9879418e63459bfe44f874dc6cf44c2de5db6..ef5ebe742571dcce4ab3e4e1e6aa87a19dda1fb1 100644 (file)
@@ -39,7 +39,8 @@ class user_editadvanced_form extends moodleform {
         $mform->addElement('checkbox', 'preference_auth_forcepasswordchange', get_string('forcepasswordchange'));
         //TODO: add missing help - user will be forced to change password
 
-        require('edit_form_common.php');
+        /// shared fields
+        useredit_shared_definition($mform);
 
         /// Next the customisable profile fields
         profile_definition($mform);
similarity index 83%
rename from user/edit_form_common.php
rename to user/editlib.php
index 50990463e296e74674d77256f11c9996ac98c58d..b7eb065fdcc4c56935b7661436a92218dd4449df 100644 (file)
@@ -1,8 +1,60 @@
 <?php  //$Id$
 
-    if (!defined('MOODLE_INTERNAL')) {
-        die('Direct access to this script is forbidden.');    ///  It must be included from a Moodle page
+
+function useredit_load_preferences(&$user) {
+    if (!empty($user->id) and $preferences = get_user_preferences(null, null, $user->id)) {
+        foreach($preferences as $name=>$value) {
+            $user->{'preference_'.$name} = $value;
+        }
+    }
+}
+
+function useredit_update_user_preference($usernew) {
+    $ua = (array)$usernew;
+    foreach($ua as $key=>$value) {
+        if (strpos($key, 'preference_') === 0) {
+            $name = substr($key, strlen('preference_'));
+            set_user_preference($name, $value, $usernew->id);
+        }
+    }
+}
+
+function useredit_update_picture(&$usernew, &$userform) {
+    if (isset($usernew->deletepicture) and $usernew->deletepicture) {
+        //TODO - delete the file
+        set_field('user', 'picture', 0, 'id', $usernew->id);
+    } else if ($usernew->picture = save_profile_image($usernew->id, $userform->get_um(), 'users')) {
+        set_field('user', 'picture', 1, 'id', $usernew->id);
+    }
+}
+
+function useredit_update_bounces($user, $usernew) {
+    if (!isset($usernew->email)) {
+        //locked field
+        return;
     }
+    if ($user->email !== $usernew->email) {
+        set_bounce_count($usernew,true);
+        set_send_count($usernew,true);
+    }
+}
+
+function useredit_update_trackforums($user, $usernew) {
+    global $CFG;
+    if (!isset($usernew->trackforums)) {
+        //locked field
+        return;
+    }
+    if (($usernew->trackforums != $user->trackforums) and !$usernew->trackforums) {
+        require_once($CFG->dirroot.'/mod/forum/lib.php');
+        forum_tp_delete_read_records($usernew->id);
+    }
+}
+
+function useredit_shared_definition(&$mform) {
+    global $CFG;
+
+    $strrequired = get_string('required');
 
     $mform->addElement('text', 'firstname', get_string('firstname'), 'maxlength="100" size="30"');
     $mform->addRule('firstname', $strrequired, 'required', null, 'client');
 
     $mform->addElement('text', 'address', get_string('address'), 'maxlength="70" size="25"');
     $mform->setType('address', PARAM_MULTILANG);
-
+}
 
 ?>
\ No newline at end of file