Allow configuration of the display order of profile fields. This is an important piece of a more general profile configuration framework which will eventually be accessible via the admin page.

This commit is contained in:
redmatrix
2016-03-01 14:55:04 -08:00
parent c19a1a6b82
commit 765dd5569b
2 changed files with 83 additions and 9 deletions

View File

@@ -1253,6 +1253,24 @@ function advanced_profile(&$a) {
if($a->profile['name']) { if($a->profile['name']) {
$profile_fields_basic = get_profile_fields_basic();
$profile_fields_advanced = get_profile_fields_advanced();
$advanced = ((feature_enabled($a->profile['profile_uid'],'advanced_profiles')) ? true : false);
if($advanced)
$fields = $profile_fields_advanced;
else
$fields = $profile_fields_basic;
$clean_fields = array();
if($fields) {
foreach($fields as $k => $v) {
$clean_fields[] = trim($k);
}
}
$tpl = get_markup_template('profile_advanced.tpl'); $tpl = get_markup_template('profile_advanced.tpl');
$profile = array(); $profile = array();
@@ -1370,6 +1388,7 @@ function advanced_profile(&$a) {
'$canlike' => (($profile['canlike'])? true : false), '$canlike' => (($profile['canlike'])? true : false),
'$likethis' => t('Like this thing'), '$likethis' => t('Like this thing'),
'$profile' => $profile, '$profile' => $profile,
'$fields' => $clean_fields,
'$editmenu' => profile_edit_menu($a->profile['profile_uid']), '$editmenu' => profile_edit_menu($a->profile['profile_uid']),
'$things' => $things '$things' => $things
)); ));

View File

@@ -31,185 +31,240 @@
<div class="clear"></div> <div class="clear"></div>
</div> </div>
<div class="section-content-wrapper"> <div class="section-content-wrapper">
{{foreach $fields as $f}}
{{if $f == 'name'}}
<dl id="aprofile-fullname" class="aprofile"> <dl id="aprofile-fullname" class="aprofile">
<dt>{{$profile.fullname.0}}</dt> <dt>{{$profile.fullname.0}}</dt>
<dd>{{$profile.fullname.1}}</dd> <dd>{{$profile.fullname.1}}</dd>
</dl> </dl>
{{/if}}
{{if $f == 'gender'}}
{{if $profile.gender}} {{if $profile.gender}}
<dl id="aprofile-gender" class="aprofile"> <dl id="aprofile-gender" class="aprofile">
<dt>{{$profile.gender.0}}</dt> <dt>{{$profile.gender.0}}</dt>
<dd>{{$profile.gender.1}}</dd> <dd>{{$profile.gender.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'birthday'}}
{{if $profile.birthday}} {{if $profile.birthday}}
<dl id="aprofile-birthday" class="aprofile"> <dl id="aprofile-birthday" class="aprofile">
<dt>{{$profile.birthday.0}}</dt> <dt>{{$profile.birthday.0}}</dt>
<dd>{{$profile.birthday.1}}</dd> <dd>{{$profile.birthday.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'age'}}
{{if $profile.age}} {{if $profile.age}}
<dl id="aprofile-age" class="aprofile"> <dl id="aprofile-age" class="aprofile">
<dt>{{$profile.age.0}}</dt> <dt>{{$profile.age.0}}</dt>
<dd>{{$profile.age.1}}</dd> <dd>{{$profile.age.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'marital'}}
{{if $profile.marital}} {{if $profile.marital}}
<dl id="aprofile-marital" class="aprofile"> <dl id="aprofile-marital" class="aprofile">
<dt><span class="heart">&hearts;</span> {{$profile.marital.0}}</dt> <dt><span class="heart">&hearts;</span> {{$profile.marital.0}}</dt>
<dd>{{$profile.marital.1}}{{if $profile.marital.with}} ({{$profile.marital.with}}){{/if}}{{if $profile.howlong}} {{$profile.howlong}}{{/if}}</dd> <dd>{{$profile.marital.1}}{{if $profile.marital.with}} ({{$profile.marital.with}}){{/if}}{{if $profile.howlong}} {{$profile.howlong}}{{/if}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'sexual'}}
{{if $profile.sexual}} {{if $profile.sexual}}
<dl id="aprofile-sexual" class="aprofile"> <dl id="aprofile-sexual" class="aprofile">
<dt>{{$profile.sexual.0}}</dt> <dt>{{$profile.sexual.0}}</dt>
<dd>{{$profile.sexual.1}}</dd> <dd>{{$profile.sexual.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'keywords'}}
{{if $profile.keywords}} {{if $profile.keywords}}
<dl id="aprofile-tags" class="aprofile"> <dl id="aprofile-tags" class="aprofile">
<dt>{{$profile.keywords.0}}</dt> <dt>{{$profile.keywords.0}}</dt>
<dd>{{$profile.keywords.1}}</dd> <dd>{{$profile.keywords.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'homepage'}}
{{if $profile.homepage}} {{if $profile.homepage}}
<dl id="aprofile-homepage" class="aprofile"> <dl id="aprofile-homepage" class="aprofile">
<dt>{{$profile.homepage.0}}</dt> <dt>{{$profile.homepage.0}}</dt>
<dd>{{$profile.homepage.1}}</dd> <dd>{{$profile.homepage.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'hometown'}}
{{if $profile.hometown}} {{if $profile.hometown}}
<dl id="aprofile-hometown" class="aprofile"> <dl id="aprofile-hometown" class="aprofile">
<dt>{{$profile.hometown.0}}</dt> <dt>{{$profile.hometown.0}}</dt>
<dd>{{$profile.hometown.1}}</dd> <dd>{{$profile.hometown.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'politic'}}
{{if $profile.politic}} {{if $profile.politic}}
<dl id="aprofile-politic" class="aprofile"> <dl id="aprofile-politic" class="aprofile">
<dt>{{$profile.politic.0}}</dt> <dt>{{$profile.politic.0}}</dt>
<dd>{{$profile.politic.1}}</dd> <dd>{{$profile.politic.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'religion'}}
{{if $profile.religion}} {{if $profile.religion}}
<dl id="aprofile-religion" class="aprofile"> <dl id="aprofile-religion" class="aprofile">
<dt>{{$profile.religion.0}}</dt> <dt>{{$profile.religion.0}}</dt>
<dd>{{$profile.religion.1}}</dd> <dd>{{$profile.religion.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'about'}}
{{if $profile.about}} {{if $profile.about}}
<dl id="aprofile-about" class="aprofile"> <dl id="aprofile-about" class="aprofile">
<dt>{{$profile.about.0}}</dt> <dt>{{$profile.about.0}}</dt>
<dd>{{$profile.about.1}}</dd> <dd>{{$profile.about.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'interest'}}
{{if $profile.interest}} {{if $profile.interest}}
<dl id="aprofile-interest" class="aprofile"> <dl id="aprofile-interest" class="aprofile">
<dt>{{$profile.interest.0}}</dt> <dt>{{$profile.interest.0}}</dt>
<dd>{{$profile.interest.1}}</dd> <dd>{{$profile.interest.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'likes'}}
{{if $profile.likes}} {{if $profile.likes}}
<dl id="aprofile-likes" class="aprofile"> <dl id="aprofile-likes" class="aprofile">
<dt>{{$profile.likes.0}}</dt> <dt>{{$profile.likes.0}}</dt>
<dd>{{$profile.likes.1}}</dd> <dd>{{$profile.likes.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'dislikes'}}
{{if $profile.dislikes}} {{if $profile.dislikes}}
<dl id="aprofile-dislikes" class="aprofile"> <dl id="aprofile-dislikes" class="aprofile">
<dt>{{$profile.dislikes.0}}</dt> <dt>{{$profile.dislikes.0}}</dt>
<dd>{{$profile.dislikes.1}}</dd> <dd>{{$profile.dislikes.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'contact'}}
{{if $profile.contact}} {{if $profile.contact}}
<dl id="aprofile-contact" class="aprofile"> <dl id="aprofile-contact" class="aprofile">
<dt>{{$profile.contact.0}}</dt> <dt>{{$profile.contact.0}}</dt>
<dd>{{$profile.contact.1}}</dd> <dd>{{$profile.contact.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'channels'}}
{{if $profile.channels}} {{if $profile.channels}}
<dl id="aprofile-channels" class="aprofile"> <dl id="aprofile-channels" class="aprofile">
<dt>{{$profile.channels.0}}</dt> <dt>{{$profile.channels.0}}</dt>
<dd>{{$profile.channels.1}}</dd> <dd>{{$profile.channels.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'music'}}
{{if $profile.music}} {{if $profile.music}}
<dl id="aprofile-music" class="aprofile"> <dl id="aprofile-music" class="aprofile">
<dt>{{$profile.music.0}}</dt> <dt>{{$profile.music.0}}</dt>
<dd>{{$profile.music.1}}</dd> <dd>{{$profile.music.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'book'}}
{{if $profile.book}} {{if $profile.book}}
<dl id="aprofile-book" class="aprofile"> <dl id="aprofile-book" class="aprofile">
<dt>{{$profile.book.0}}</dt> <dt>{{$profile.book.0}}</dt>
<dd>{{$profile.book.1}}</dd> <dd>{{$profile.book.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'tv'}}
{{if $profile.tv}} {{if $profile.tv}}
<dl id="aprofile-tv" class="aprofile"> <dl id="aprofile-tv" class="aprofile">
<dt>{{$profile.tv.0}}</dt> <dt>{{$profile.tv.0}}</dt>
<dd>{{$profile.tv.1}}</dd> <dd>{{$profile.tv.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'film'}}
{{if $profile.film}} {{if $profile.film}}
<dl id="aprofile-film" class="aprofile"> <dl id="aprofile-film" class="aprofile">
<dt>{{$profile.film.0}}</dt> <dt>{{$profile.film.0}}</dt>
<dd>{{$profile.film.1}}</dd> <dd>{{$profile.film.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'romance'}}
{{if $profile.romance}} {{if $profile.romance}}
<dl id="aprofile-romance" class="aprofile"> <dl id="aprofile-romance" class="aprofile">
<dt>{{$profile.romance.0}}</dt> <dt>{{$profile.romance.0}}</dt>
<dd>{{$profile.romance.1}}</dd> <dd>{{$profile.romance.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'work'}}
{{if $profile.work}} {{if $profile.work}}
<dl id="aprofile-work" class="aprofile"> <dl id="aprofile-work" class="aprofile">
<dt>{{$profile.work.0}}</dt> <dt>{{$profile.work.0}}</dt>
<dd>{{$profile.work.1}}</dd> <dd>{{$profile.work.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{if $f == 'education'}}
{{if $profile.education}} {{if $profile.education}}
<dl id="aprofile-education" class="aprofile"> <dl id="aprofile-education" class="aprofile">
<dt>{{$profile.education.0}}</dt> <dt>{{$profile.education.0}}</dt>
<dd>{{$profile.education.1}}</dd> <dd>{{$profile.education.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{foreach $profile.extra_fields as $f}} {{foreach $profile.extra_fields as $fld}}
{{if $profile.$f}} {{if $f == $fld}}
<dl id="aprofile-{{$f}}" class="aprofile"> {{if $profile.$fld}}
<dt>{{$profile.$f.0}}</dt> <dl id="aprofile-{{$fld}}" class="aprofile">
<dd>{{$profile.$f.1}}</dd> <dt>{{$profile.$fld.0}}</dt>
<dd>{{$profile.$fld.1}}</dd>
</dl> </dl>
{{/if}} {{/if}}
{{/if}}
{{/foreach}}
{{/foreach}} {{/foreach}}