new profile tables, profile clone
authorMike Macgirvin <mike@macgirvin.com>
Fri, 9 Jul 2010 23:28:50 +0000 (16:28 -0700)
committerMike Macgirvin <mike@macgirvin.com>
Fri, 9 Jul 2010 23:28:50 +0000 (16:28 -0700)
mod/profiles.php
updates.sql
view/profile_edit.tpl
view/style.css

index e2cb021845ba1e7f3e12c70a8402f09c595ece42..ea0b9afcb898bc1d6f148a160ae9092eaa148a30 100644 (file)
@@ -131,6 +131,46 @@ function profiles_content(&$a) {
                goaway($a->get_baseurl() . '/profiles');
        }                
 
+       if(($a->argc > 2) && ($a->argv[1] == 'clone')) {
+
+               $r0 = q("SELECT `id` FROM `profile` WHERE `uid` = %d",
+                       intval($_SESSION['uid']));
+               $num_profiles = count($r0);
+
+               $name = "Profile-" . ($num_profiles + 1);
+               $r1 = q("SELECT * FROM `profile` WHERE `uid` = %d AND `id` = %d LIMIT 1",
+                       intval($_SESSION['uid']),
+                       intval($a->argv[2])
+               );
+               if(! count($r1)) {
+                       notice("Profile unavailable to clone." . EOL);
+                       return;
+               }
+               unset($r1[0]['id']);
+               $r1[0]['is-default'] = 0;
+               $r1[0]['publish'] = 0;  
+               $r1[0]['profile-name'] = dbesc($name);
+
+               $r2 = q("INSERT INTO `profile` (`" 
+                       . implode("`, `", array_keys($r1[0])) 
+                       . "`) VALUES ('" 
+                       . implode("', '", array_values($r1[0])) 
+                       . "')" );
+
+               $r3 = q("SELECT `id` FROM `profile` WHERE `uid` = %d AND `profile-name` = '%s' LIMIT 1",
+                       intval($_SESSION['uid']),
+                       dbesc($name)
+               );
+               $_SESSION['sysmsg'] .= "New profile created." . EOL;
+               if(count($r3) == 1)
+                       goaway($a->get_baseurl() . '/profiles/' . $r3[0]['id']);
+       goaway($a->get_baseurl() . '/profiles');
+       return; // NOTREACHED
+       }                
+
+
+
+
 
        if(intval($a->argv[1])) {
                $r = q("SELECT * FROM `profile` WHERE `id` = %d AND `uid` = %d LIMIT 1",
index 87d5e8b13519af86e61e169c720bcf9127b2d0b2..f74877d259292682005ceebbbd468e73f1b0c7c0 100644 (file)
@@ -1,2 +1,19 @@
 
-ALTER TABLE `item` ADD `remote-id` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `contact-id` ;
+|ALTER TABLE `item` ADD `remote-id` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `contact-id` ;
+
+ALTER TABLE `profile` ADD `politic` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `marital` ,
+ADD `religion` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `politic` ;
+
+ALTER TABLE `profile` ADD `sexual` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `marital` ;
+
+
+ALTER TABLE `profile` ADD `music` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `about` ,
+ADD `book` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `music` ,
+ADD `tv` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `book` ,
+ADD `film` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `tv` ,
+ADD `interest` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `film` ,
+ADD `romance` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `interest` ,
+ADD `work` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `romance` ;
+ALTER TABLE `profile` ADD `employer` CHAR( 255 ) NOT NULL AFTER `work` ,
+ADD `school` CHAR( 255 ) NOT NULL AFTER `employer` ;
+ALTER TABLE `profile` ADD `summary` CHAR( 255 ) NOT NULL AFTER `about` ;
index 687432f75de8b1829f1951fee8e9d1adb9a9ab40..251fdae14784d6e78213a502216ccf5700ea2f71 100644 (file)
@@ -1,5 +1,7 @@
 <h1>Edit Profile Details</h1>
 
+<div id="profile-edit-clone-link-wrapper" ><a href="profiles/clone/$profile_id" id="profile-edit-clone-link" title="Create a new profile using these settings">Clone this profile</a></div>
+
 $default
 
 <div id="profile-edit-wrapper" >
index 806d62affc60aa68774c5aaf79cd8acf11aa9c4d..7b08e2269ca8c5cde10c9964a85a1fbf37e5ba6c 100644 (file)
@@ -274,7 +274,10 @@ input#dfrn-url {
 
 
 }
-
+#profile-edit-clone-link-wrapper {
+       margin-left: 50px;
+       margin-bottom: 20px;
+}
 
 #profile-edit-profile-name-label,
 #profile-edit-name-label,