]> git.mxchange.org Git - friendica.git/commitdiff
Introducing Frost Mobile
authorZach Prezkuta <fermion@gmx.com>
Tue, 24 Jul 2012 15:16:51 +0000 (09:16 -0600)
committerZach Prezkuta <fermion@gmx.com>
Tue, 24 Jul 2012 15:16:51 +0000 (09:16 -0600)
87 files changed:
view/theme/frost-mobile/TODO [new file with mode: 0644]
view/theme/frost-mobile/admin_aside.tpl [new file with mode: 0644]
view/theme/frost-mobile/admin_site.tpl [new file with mode: 0644]
view/theme/frost-mobile/border.jpg [new file with mode: 0644]
view/theme/frost-mobile/comment_item.tpl [new file with mode: 0755]
view/theme/frost-mobile/contact_head.tpl [new file with mode: 0644]
view/theme/frost-mobile/contact_template.tpl [new file with mode: 0644]
view/theme/frost-mobile/contacts-template.tpl [new file with mode: 0644]
view/theme/frost-mobile/conversation.tpl [new file with mode: 0644]
view/theme/frost-mobile/default.php [new file with mode: 0644]
view/theme/frost-mobile/editicons.png [new file with mode: 0644]
view/theme/frost-mobile/event_head.tpl [new file with mode: 0644]
view/theme/frost-mobile/experimental [new file with mode: 0644]
view/theme/frost-mobile/field_input.tpl [new file with mode: 0644]
view/theme/frost-mobile/field_openid.tpl [new file with mode: 0644]
view/theme/frost-mobile/field_password.tpl [new file with mode: 0644]
view/theme/frost-mobile/file.gif [new file with mode: 0644]
view/theme/frost-mobile/friendika-16.png [new file with mode: 0644]
view/theme/frost-mobile/head.jpg [new file with mode: 0644]
view/theme/frost-mobile/head.tpl [new file with mode: 0644]
view/theme/frost-mobile/images/approve-blue.png [new file with mode: 0644]
view/theme/frost-mobile/images/approve.png [new file with mode: 0644]
view/theme/frost-mobile/images/arrow-left.png [new file with mode: 0644]
view/theme/frost-mobile/images/arrow-right.png [new file with mode: 0644]
view/theme/frost-mobile/images/boldB-serif.png [new file with mode: 0644]
view/theme/frost-mobile/images/camera.png [new file with mode: 0644]
view/theme/frost-mobile/images/code.png [new file with mode: 0644]
view/theme/frost-mobile/images/contacts.png [new file with mode: 0644]
view/theme/frost-mobile/images/disapprove-blue.png [new file with mode: 0644]
view/theme/frost-mobile/images/disapprove.png [new file with mode: 0644]
view/theme/frost-mobile/images/drop-blue.png [new file with mode: 0644]
view/theme/frost-mobile/images/drop-darkred.png [new file with mode: 0644]
view/theme/frost-mobile/images/drop-red.png [new file with mode: 0644]
view/theme/frost-mobile/images/drop.png [new file with mode: 0644]
view/theme/frost-mobile/images/folder-blue.png [new file with mode: 0644]
view/theme/frost-mobile/images/folder.png [new file with mode: 0644]
view/theme/frost-mobile/images/globe.png [new file with mode: 0644]
view/theme/frost-mobile/images/italicI-serif.png [new file with mode: 0644]
view/theme/frost-mobile/images/lock.png [new file with mode: 0644]
view/theme/frost-mobile/images/menu.png [new file with mode: 0644]
view/theme/frost-mobile/images/message.png [new file with mode: 0644]
view/theme/frost-mobile/images/network.png [new file with mode: 0644]
view/theme/frost-mobile/images/notifications.png [new file with mode: 0644]
view/theme/frost-mobile/images/paperclip.png [new file with mode: 0644]
view/theme/frost-mobile/images/pencil-blue.png [new file with mode: 0644]
view/theme/frost-mobile/images/pencil.png [new file with mode: 0644]
view/theme/frost-mobile/images/quote.png [new file with mode: 0644]
view/theme/frost-mobile/images/recycle-blue.png [new file with mode: 0644]
view/theme/frost-mobile/images/recycle.png [new file with mode: 0644]
view/theme/frost-mobile/images/remote-link-blue.png [new file with mode: 0644]
view/theme/frost-mobile/images/remote-link.png [new file with mode: 0644]
view/theme/frost-mobile/images/star-blue.png [new file with mode: 0644]
view/theme/frost-mobile/images/star-yellow.png [new file with mode: 0644]
view/theme/frost-mobile/images/star.png [new file with mode: 0644]
view/theme/frost-mobile/images/tag-blue.png [new file with mode: 0644]
view/theme/frost-mobile/images/tag.png [new file with mode: 0644]
view/theme/frost-mobile/images/underlineU-serif.png [new file with mode: 0644]
view/theme/frost-mobile/images/unlock.png [new file with mode: 0644]
view/theme/frost-mobile/jot-header.tpl [new file with mode: 0644]
view/theme/frost-mobile/jot.tpl [new file with mode: 0644]
view/theme/frost-mobile/js/acl.js [new file with mode: 0644]
view/theme/frost-mobile/js/main.js [new file with mode: 0644]
view/theme/frost-mobile/js/theme.js [new file with mode: 0644]
view/theme/frost-mobile/js/theme.js.old [new file with mode: 0644]
view/theme/frost-mobile/lang_selector.tpl [new file with mode: 0644]
view/theme/frost-mobile/lock.cur [new file with mode: 0644]
view/theme/frost-mobile/login-bg.gif [new file with mode: 0644]
view/theme/frost-mobile/login-style.css [new file with mode: 0644]
view/theme/frost-mobile/login.tpl [new file with mode: 0644]
view/theme/frost-mobile/lostpass.tpl [new file with mode: 0644]
view/theme/frost-mobile/moderated_comment.tpl [new file with mode: 0755]
view/theme/frost-mobile/msg-header.tpl [new file with mode: 0644]
view/theme/frost-mobile/nav.tpl [new file with mode: 0644]
view/theme/frost-mobile/photo_edit.tpl [new file with mode: 0644]
view/theme/frost-mobile/photo_view.tpl [new file with mode: 0644]
view/theme/frost-mobile/photos_upload.tpl [new file with mode: 0644]
view/theme/frost-mobile/profed_head.tpl [new file with mode: 0644]
view/theme/frost-mobile/profile_edit.tpl [new file with mode: 0644]
view/theme/frost-mobile/profile_vcard.tpl [new file with mode: 0644]
view/theme/frost-mobile/prv_message.tpl [new file with mode: 0644]
view/theme/frost-mobile/register.tpl [new file with mode: 0644]
view/theme/frost-mobile/screenshot.jpg [new file with mode: 0644]
view/theme/frost-mobile/settings.tpl [new file with mode: 0644]
view/theme/frost-mobile/style.css [new file with mode: 0644]
view/theme/frost-mobile/theme.php [new file with mode: 0644]
view/theme/frost-mobile/wall_item.tpl [new file with mode: 0644]
view/theme/frost-mobile/wallmsg-header.tpl [new file with mode: 0644]

diff --git a/view/theme/frost-mobile/TODO b/view/theme/frost-mobile/TODO
new file mode 100644 (file)
index 0000000..296370d
--- /dev/null
@@ -0,0 +1,16 @@
+Photo album display?
+
+- The "lock" icon for private items
+       - change it to black?
+       - when clicked, the popup window displays poorly
+
+- Edit photo page: bottom buttons are off-center in Dolphin Mini
+
+- Pager: looks weird when only "prev" is there
+
+- BB code buttons for status updates
+
+- Get "add contact" back on contacts page
+
+- Admin: access to more pages than summary?
+
diff --git a/view/theme/frost-mobile/admin_aside.tpl b/view/theme/frost-mobile/admin_aside.tpl
new file mode 100644 (file)
index 0000000..b17addd
--- /dev/null
@@ -0,0 +1,42 @@
+<script>
+       // update pending count //
+       $(function(){
+
+               $("nav").bind('nav-update',  function(e,data){
+                       var elm = $('#pending-update');
+                       var register = $(data).find('register').text();
+                       if (register=="0") { reigster=""; elm.hide();} else { elm.show(); }
+                       elm.html(register);
+               });
+       });
+</script>
+<h4><a href="$admurl">$admtxt</a></h4>
+<ul class='admin linklist'>
+       <li class='admin button $admin.site.2'><a href='$admin.site.0'>$admin.site.1</a></li>
+       <li class='admin button $admin.users.2'><a href='$admin.users.0'>$admin.users.1</a><span id='pending-update' title='$h_pending'></span></li>
+       <li class='admin button $admin.plugins.2'><a href='$admin.plugins.0'>$admin.plugins.1</a></li>
+       <li class='admin button $admin.themes.2'><a href='$admin.themes.0'>$admin.themes.1</a></li>
+       <li class='admin button $admin.dbsync.2'><a href='$admin.dbsync.0'>$admin.dbsync.1</a></li>
+</ul>
+
+{{ if $admin.update }}
+<ul class='admin linklist'>
+       <li class='admin button $admin.update.2'><a href='$admin.update.0'>$admin.update.1</a></li>
+       <li class='admin button $admin.update.2'><a href='https://kakste.com/profile/inthegit'>Important Changes</a></li>
+</ul>
+{{ endif }}
+
+
+{{ if $admin.plugins_admin }}<h4>$plugadmtxt</h4>{{ endif }}
+<ul class='admin linklist'>
+       {{ for $admin.plugins_admin as $l }}
+       <li class='admin button $l.2'><a href='$l.0'>$l.1</a></li>
+       {{ endfor }}
+</ul>
+       
+       
+<h4>$logtxt</h4>
+<ul class='admin linklist'>
+       <li class='admin button $admin.logs.2'><a href='$admin.logs.0'>$admin.logs.1</a></li>
+</ul>
+
diff --git a/view/theme/frost-mobile/admin_site.tpl b/view/theme/frost-mobile/admin_site.tpl
new file mode 100644 (file)
index 0000000..ff7c9bd
--- /dev/null
@@ -0,0 +1,91 @@
+<!--<script>
+       $(function(){
+               
+               $("#cnftheme").fancybox({
+                       width: 800,
+                       autoDimensions: false,
+                       onStart: function(){
+                               var theme = $("#id_theme :selected").val();
+                               $("#cnftheme").attr('href',"$baseurl/admin/themes/"+theme);
+                       }, 
+                       onComplete: function(){
+                               $("div#fancybox-content form").submit(function(e){
+                                       var url = $(this).attr('action');
+                                       // can't get .serialize() to work...
+                                       var data={};
+                                       $(this).find("input").each(function(){
+                                               data[$(this).attr('name')] = $(this).val();
+                                       });
+                                       $(this).find("select").each(function(){
+                                               data[$(this).attr('name')] = $(this).children(":selected").val();
+                                       });
+                                       console.log(":)", url, data);
+                                       
+                                       $.post(url, data, function(data) {
+                                               if(timer) clearTimeout(timer);
+                                               NavUpdate();
+                                               $.fancybox.close();
+                                       })
+                                       
+                                       return false;
+                               });
+                               
+                       }
+               });
+       });
+</script>-->
+<div id='adminpage'>
+       <h1>$title - $page</h1>
+       
+       <form action="$baseurl/admin/site" method="post">
+    <input type='hidden' name='form_security_token' value='$form_security_token'>
+
+       {{ inc field_input.tpl with $field=$sitename }}{{ endinc }}
+       {{ inc field_textarea.tpl with $field=$banner }}{{ endinc }}
+       {{ inc field_select.tpl with $field=$language }}{{ endinc }}
+       {{ inc field_select.tpl with $field=$theme }}{{ endinc }}
+       {{ inc field_select.tpl with $field=$ssl_policy }}{{ endinc }}
+       
+       <div class="submit"><input type="submit" name="page_site" value="$submit" /></div>
+       
+       <h3>$registration</h3>
+       {{ inc field_input.tpl with $field=$register_text }}{{ endinc }}
+       {{ inc field_select.tpl with $field=$register_policy }}{{ endinc }}
+       
+       {{ inc field_checkbox.tpl with $field=$no_multi_reg }}{{ endinc }}
+       {{ inc field_checkbox.tpl with $field=$no_openid }}{{ endinc }}
+       {{ inc field_checkbox.tpl with $field=$no_regfullname }}{{ endinc }}
+       
+       <div class="submit"><input type="submit" name="page_site" value="$submit" /></div>
+
+       <h3>$upload</h3>
+       {{ inc field_input.tpl with $field=$maximagesize }}{{ endinc }}
+       
+       <h3>$corporate</h3>
+       {{ inc field_input.tpl with $field=$allowed_sites }}{{ endinc }}
+       {{ inc field_input.tpl with $field=$allowed_email }}{{ endinc }}
+       {{ inc field_checkbox.tpl with $field=$block_public }}{{ endinc }}
+       {{ inc field_checkbox.tpl with $field=$force_publish }}{{ endinc }}
+       {{ inc field_checkbox.tpl with $field=$no_community_page }}{{ endinc }}
+       {{ inc field_checkbox.tpl with $field=$ostatus_disabled }}{{ endinc }}
+       {{ inc field_checkbox.tpl with $field=$diaspora_enabled }}{{ endinc }}
+       {{ inc field_checkbox.tpl with $field=$dfrn_only }}{{ endinc }}
+       {{ inc field_input.tpl with $field=$global_directory }}{{ endinc }}
+       
+       <div class="submit"><input type="submit" name="page_site" value="$submit" /></div>
+       
+       <h3>$advanced</h3>
+       {{ inc field_checkbox.tpl with $field=$no_utf }}{{ endinc }}
+       {{ inc field_checkbox.tpl with $field=$verifyssl }}{{ endinc }}
+       {{ inc field_input.tpl with $field=$proxy }}{{ endinc }}
+       {{ inc field_input.tpl with $field=$proxyuser }}{{ endinc }}
+       {{ inc field_input.tpl with $field=$timeout }}{{ endinc }}
+       {{ inc field_input.tpl with $field=$delivery_interval }}{{ endinc }}
+       {{ inc field_input.tpl with $field=$poll_interval }}{{ endinc }}
+       {{ inc field_input.tpl with $field=$maxloadavg }}{{ endinc }}
+       {{ inc field_input.tpl with $field=$abandon_days }}{{ endinc }}
+       
+       <div class="submit"><input type="submit" name="page_site" value="$submit" /></div>
+       
+       </form>
+</div>
diff --git a/view/theme/frost-mobile/border.jpg b/view/theme/frost-mobile/border.jpg
new file mode 100644 (file)
index 0000000..034a1cb
Binary files /dev/null and b/view/theme/frost-mobile/border.jpg differ
diff --git a/view/theme/frost-mobile/comment_item.tpl b/view/theme/frost-mobile/comment_item.tpl
new file mode 100755 (executable)
index 0000000..9a9b8f6
--- /dev/null
@@ -0,0 +1,74 @@
+               <script>
+               $(document).ready( function () {
+                       $(document).mouseup(function(e) {
+                               var container = $("#comment-edit-wrapper-$id");
+                               if( container.has(e.target).length === 0) {
+                                       commentClose(document.getElementById('comment-edit-text-$id'),$id);
+                                       cmtBbClose($id);
+                               }
+                       });
+               });
+               </script>
+
+               <div class="comment-wwedit-wrapper" id="comment-edit-wrapper-$id" style="display: block;" >
+                       <form class="comment-edit-form" id="comment-edit-form-$id" action="item" method="post" onsubmit="post_comment($id); return false;" >
+                               <input type="hidden" name="type" value="$type" />
+                               <input type="hidden" name="profile_uid" value="$profile_uid" />
+                               <input type="hidden" name="parent" value="$parent" />
+                               <input type="hidden" name="return" value="$return_path" />
+                               <input type="hidden" name="jsreload" value="$jsreload" />
+                               <input type="hidden" name="preview" id="comment-preview-inp-$id" value="0" />
+
+                               <div class="comment-edit-photo" id="comment-edit-photo-$id" >
+                                       <a class="comment-edit-photo-link" href="$mylink" title="$mytitle"><img class="my-comment-photo" src="$myphoto" alt="$mytitle" title="$mytitle" /></a>
+                               </div>
+                               <div class="comment-edit-photo-end"></div>
+                               <ul class="comment-edit-bb-$id">
+                                       <li><a class="editicon boldbb shadow"
+                                               style="cursor: pointer;" title="$edbold"
+                                               onclick="insertFormatting('$comment','b', $id);"></a></li>
+                                       <li><a class="editicon italicbb shadow"
+                                               style="cursor: pointer;" title="$editalic"
+                                               onclick="insertFormatting('$comment','i', $id);"></a></li>
+                                       <li><a class="editicon underlinebb shadow"
+                                               style="cursor: pointer;" title="$eduline"
+                                               onclick="insertFormatting('$comment','u', $id);"></a></li>
+                                       <li><a class="editicon quotebb shadow"
+                                               style="cursor: pointer;" title="$edquote"
+                                               onclick="insertFormatting('$comment','quote', $id);"></a></li>
+                                       <li><a class="editicon codebb shadow"
+                                               style="cursor: pointer;" title="$edcode"
+                                               onclick="insertFormatting('$comment','code', $id);"></a></li>
+<!--                                   <li><a class="editicon imagebb shadow"
+                                               style="cursor: pointer;" title="$edimg"
+                                               onclick="insertFormatting('$comment','img', $id);"></a></li>
+                                       <li><a class="editicon urlbb shadow"
+                                               style="cursor: pointer;" title="$edurl"
+                                               onclick="insertFormatting('$comment','url', $id);"></a></li>
+                                       <li><a class="editicon videobb shadow"
+                                               style="cursor: pointer;" title="$edvideo"
+                                               onclick="insertFormatting('$comment','video', $id);"></a></li>-->
+                               </ul>   
+                               <div class="comment-edit-bb-end"></div>
+<!--                           <textarea id="comment-edit-text-$id" class="comment-edit-text-empty" name="body" onFocus="commentOpen(this,$id);cmtBbOpen($id);" onBlur="commentClose(this,$id);cmtBbClose($id);" >$comment</textarea>-->
+                               <textarea id="comment-edit-text-$id" class="comment-edit-text-empty" name="body" onFocus="commentOpen(this,$id);cmtBbOpen($id);" >$comment</textarea>
+                               {{ if $qcomment }}
+                                       <select id="qcomment-select-$id" name="qcomment-$id" class="qcomment" onchange="qCommentInsert(this,$id);" >
+                                       <option value=""></option>
+                               {{ for $qcomment as $qc }}
+                                       <option value="$qc">$qc</option>                                
+                               {{ endfor }}
+                                       </select>
+                               {{ endif }}
+
+                               <div class="comment-edit-text-end"></div>
+                               <div class="comment-edit-submit-wrapper" id="comment-edit-submit-wrapper-$id" style="display: none;" >
+                                       <input type="submit" onclick="post_comment($id); return false;" id="comment-edit-submit-$id" class="comment-edit-submit" name="submit" value="$submit" />
+                                       <!--<span onclick="preview_comment($id);" id="comment-edit-preview-link-$id" class="preview-link fakelink">$preview</span>
+                                       <div id="comment-edit-preview-$id" class="comment-edit-preview" style="display:none;"></div>-->
+                               </div>
+
+                               <div class="comment-edit-end"></div>
+                       </form>
+
+               </div>
diff --git a/view/theme/frost-mobile/contact_head.tpl b/view/theme/frost-mobile/contact_head.tpl
new file mode 100644 (file)
index 0000000..427f541
--- /dev/null
@@ -0,0 +1,30 @@
+<!--<script language="javascript" type="text/javascript"
+          src="$baseurl/library/tinymce/jscripts/tiny_mce/tiny_mce_src.js"></script>
+          <script language="javascript" type="text/javascript">
+
+tinyMCE.init({
+       theme : "advanced",
+       mode : "$editselect",
+       elements: "contact-edit-info",
+       plugins : "bbcode",
+       theme_advanced_buttons1 : "bold,italic,underline,undo,redo,link,unlink,image,forecolor",
+       theme_advanced_buttons2 : "",
+       theme_advanced_buttons3 : "",
+       theme_advanced_toolbar_location : "top",
+       theme_advanced_toolbar_align : "center",
+       theme_advanced_styles : "blockquote,code",
+       gecko_spellcheck : true,
+       entity_encoding : "raw",
+       add_unload_trigger : false,
+       remove_linebreaks : false,
+       force_p_newlines : false,
+       force_br_newlines : true,
+       forced_root_block : '',
+       content_css: "$baseurl/view/custom_tinymce.css"
+
+
+});
+
+
+</script>
+-->
diff --git a/view/theme/frost-mobile/contact_template.tpl b/view/theme/frost-mobile/contact_template.tpl
new file mode 100644 (file)
index 0000000..c27060b
--- /dev/null
@@ -0,0 +1,30 @@
+
+<div class="contact-entry-wrapper" id="contact-entry-wrapper-$contact.id" >
+       <div class="contact-entry-photo-wrapper" >
+               <div class="contact-entry-photo mframe" id="contact-entry-photo-$contact.id"
+               onmouseover="if (typeof t$contact.id != 'undefined') clearTimeout(t$contact.id);" 
+               onmouseout="t$contact.id=setTimeout('closeMenu(\'contact-photo-menu-$contact.id\');',200)" >
+
+<!--                   <a href="$contact.url" title="$contact.img_hover" /><img src="$contact.thumb" $contact.sparkle alt="$contact.name" /></a>-->
+                       <span onclick="openClose('contact-photo-menu-$contact.id');" class="fakelink contact-photo-menu-button" id="contact-photo-menu-button-$contact.id">
+                       <img src="$contact.thumb" $contact.sparkle alt="$contact.name" />
+                       </span>
+
+                       {{ if $contact.photo_menu }}
+<!--                   <span onclick="openClose('contact-photo-menu-$contact.id');" class="fakelink contact-photo-menu-button" id="contact-photo-menu-button-$contact.id">menu</span>-->
+                <div class="contact-photo-menu" id="contact-photo-menu-$contact.id">
+                    <ul>
+                        $contact.photo_menu
+                    </ul>
+                </div>
+                       {{ endif }}
+               </div>
+                       
+       </div>
+       <div class="contact-entry-photo-end" ></div>
+               <div class="contact-entry-name" id="contact-entry-name-$contact.id" >$contact.name</div><br />
+{{ if $contact.alt_text }}<div class="contact-entry-details" id="contact-entry-rel-$contact.id" >$contact.alt_text</div>{{ endif }}
+       <div class="contact-entry-network" id="contact-entry-network-$contact.id" >$contact.network</div>
+
+       <div class="contact-entry-end" ></div>
+</div>
diff --git a/view/theme/frost-mobile/contacts-template.tpl b/view/theme/frost-mobile/contacts-template.tpl
new file mode 100644 (file)
index 0000000..76254c1
--- /dev/null
@@ -0,0 +1,28 @@
+<h1>$header{{ if $total }} ($total){{ endif }}</h1>
+
+{{ if $finding }}<h4>$finding</h4>{{ endif }}
+
+<div id="contacts-search-wrapper">
+<form id="contacts-search-form" action="$cmd" method="get" >
+<span class="contacts-search-desc">$desc</span>
+<input type="text" name="search" id="contacts-search" class="search-input" onfocus="this.select();" value="$search" />
+<input type="submit" name="submit" id="contacts-search-submit" value="$submit" />
+</form>
+</div>
+<div id="contacts-search-end"></div>
+
+$tabs
+
+
+<div id="contacts-display-wrapper">
+{{ for $contacts as $contact }}
+       {{ inc contact_template.tpl }}{{ endinc }}
+{{ endfor }}
+</div>
+<div id="contact-edit-end"></div>
+
+$paginate
+
+
+
+
diff --git a/view/theme/frost-mobile/conversation.tpl b/view/theme/frost-mobile/conversation.tpl
new file mode 100644 (file)
index 0000000..43b4d63
--- /dev/null
@@ -0,0 +1,27 @@
+{{ for $threads as $thread }}
+<div id="tread-wrapper-$thread.id" class="tread-wrapper">
+       {{ for $thread.items as $item }}
+               {{if $item.comment_firstcollapsed}}
+                       <div class="hide-comments-outer">
+                       <span id="hide-comments-total-$thread.id" class="hide-comments-total">$thread.num_comments</span> <span id="hide-comments-$thread.id" class="hide-comments fakelink" onclick="showHideComments($thread.id);">$thread.hide_text</span>
+                       </div>
+                       <div id="collapsed-comments-$thread.id" class="collapsed-comments" style="display: none;">
+               {{endif}}
+               {{if $item.comment_lastcollapsed}}</div>{{endif}}
+               
+               {{ inc $item.template }}{{ endinc }}
+               
+               
+       {{ endfor }}
+</div>
+{{ endfor }}
+
+<div id="conversation-end"></div>
+
+<!--{{ if $dropping }}
+<div id="item-delete-selected" class="fakelink" onclick="deleteCheckedItems();">
+  <div id="item-delete-selected-icon" class="icon drophide" title="$dropping" onmouseover="imgbright(this);" onmouseout="imgdull(this);" ></div>
+  <div id="item-delete-selected-desc" >$dropping</div>
+</div>
+<div id="item-delete-selected-end"></div>-->
+{{ endif }}
diff --git a/view/theme/frost-mobile/default.php b/view/theme/frost-mobile/default.php
new file mode 100644 (file)
index 0000000..c0f5de5
--- /dev/null
@@ -0,0 +1,41 @@
+<!DOCTYPE html >\r
+<html>\r
+<head>\r
+  <title><?php if(x($page,'title')) echo $page['title'] ?></title>\r
+  <script>var baseurl="<?php echo $a->get_baseurl() ?>";</script>\r
+  <?php if(x($page,'htmlhead')) echo $page['htmlhead'] ?>\r
+</head>\r
+<body>\r
+       <?php if( $a->module === 'home' ) { ?>\r
+       <center>\r
+       <div class="login-button">\r
+       <a href="login" class="login-button-link"><img class="login-button-image" src="/images/friendika-1600.png" title="Click to log in"></a>\r
+       </div>\r
+       </center>\r
+       <?php } elseif ( $a->module === 'login' || $a->module === 'register' || $a->module === 'lostpass' ) {\r
+       ?>\r
+\r
+       <div class='section-wrapper'>\r
+       <section><?php if(x($page,'content')) echo $page['content']; ?>\r
+       </section>\r
+       </div>\r
+\r
+       <?php } else {\r
+\r
+       if(x($page,'nav')) echo $page['nav']; ?>\r
+       <div class='main-container'>\r
+               <div class='main-content-container'>\r
+               <aside><?php if(x($page,'aside')) echo $page['aside']; ?></aside>\r
+               <div class='section-wrapper'>\r
+               <section><?php if(x($page,'content')) echo $page['content']; ?>\r
+                       <div id="page-footer"></div>\r
+               </section>\r
+               </div>\r
+               <right_aside><?php if(x($page,'right_aside')) echo $page['right_aside']; ?></right_aside>\r
+               <footer><?php if(x($page,'footer')) echo $page['footer']; ?></footer>\r
+               </div>\r
+       </div>\r
+       <?php } ?>\r
+</body>\r
+</html>\r
+\r
diff --git a/view/theme/frost-mobile/editicons.png b/view/theme/frost-mobile/editicons.png
new file mode 100644 (file)
index 0000000..171a408
Binary files /dev/null and b/view/theme/frost-mobile/editicons.png differ
diff --git a/view/theme/frost-mobile/event_head.tpl b/view/theme/frost-mobile/event_head.tpl
new file mode 100644 (file)
index 0000000..7636a4f
--- /dev/null
@@ -0,0 +1,139 @@
+<link rel='stylesheet' type='text/css' href='$baseurl/library/fullcalendar/fullcalendar.css' />
+<script language="javascript" type="text/javascript"
+          src="$baseurl/library/fullcalendar/fullcalendar.min.js"></script>
+
+<script>
+       function showEvent(eventid) {
+/*             $.get(
+                       '$baseurl/events/?id='+eventid,
+                       function(data){
+                               $.fancybox(data);
+                       }
+               );                      */
+       }
+       
+       $(document).ready(function() {
+               $('#events-calendar').fullCalendar({
+                       events: '$baseurl/events/json/',
+                       header: {
+                               left: 'prev,next today',
+                               center: 'title',
+                               right: 'month,agendaWeek,agendaDay'
+                       },                      
+                       timeFormat: 'H(:mm)',
+                       eventClick: function(calEvent, jsEvent, view) {
+                               showEvent(calEvent.id);
+                       },
+                       
+                       eventRender: function(event, element, view) {
+                               //console.log(view.name);
+                               if (event.item['author-name']==null) return;
+                               switch(view.name){
+                                       case "month":
+                                       element.find(".fc-event-title").html(
+                                               "<img src='{0}' style='height:10px;width:10px'>{1} : {2}".format(
+                                                       event.item['author-avatar'],
+                                                       event.item['author-name'],
+                                                       event.title
+                                       ));
+                                       break;
+                                       case "agendaWeek":
+                                       element.find(".fc-event-title").html(
+                                               "<img src='{0}' style='height:12px; width:12px'>{1}<p>{2}</p><p>{3}</p>".format(
+                                                       event.item['author-avatar'],
+                                                       event.item['author-name'],
+                                                       event.item.desc,
+                                                       event.item.location
+                                       ));
+                                       break;
+                                       case "agendaDay":
+                                       element.find(".fc-event-title").html(
+                                               "<img src='{0}' style='height:24px;width:24px'>{1}<p>{2}</p><p>{3}</p>".format(
+                                                       event.item['author-avatar'],
+                                                       event.item['author-name'],
+                                                       event.item.desc,
+                                                       event.item.location
+                                       ));
+                                       break;
+                               }
+                       }
+                       
+               })
+               
+               // center on date
+               var args=location.href.replace(baseurl,"").split("/");
+               if (args.length>=4) {
+                       $("#events-calendar").fullCalendar('gotoDate',args[2] , args[3]-1);
+               } 
+               
+               // show event popup
+               var hash = location.hash.split("-")
+               if (hash.length==2 && hash[0]=="#link") showEvent(hash[1]);
+               
+       });
+</script>
+
+
+<!--<script language="javascript" type="text/javascript"
+          src="$baseurl/library/tinymce/jscripts/tiny_mce/tiny_mce_src.js"></script>-->
+<script language="javascript" type="text/javascript">
+
+/*
+       tinyMCE.init({
+               theme : "advanced",
+               mode : "textareas",
+               plugins : "bbcode,paste",
+               theme_advanced_buttons1 : "bold,italic,underline,undo,redo,link,unlink,image,forecolor,formatselect,code",
+               theme_advanced_buttons2 : "",
+               theme_advanced_buttons3 : "",
+               theme_advanced_toolbar_location : "top",
+               theme_advanced_toolbar_align : "center",
+               theme_advanced_blockformats : "blockquote,code",
+               gecko_spellcheck : true,
+               paste_text_sticky : true,
+               entity_encoding : "raw",
+               add_unload_trigger : false,
+               remove_linebreaks : false,
+               force_p_newlines : false,
+               force_br_newlines : true,
+               forced_root_block : '',
+               content_css: "$baseurl/view/custom_tinymce.css",
+               theme_advanced_path : false,
+               setup : function(ed) {
+                       ed.onInit.add(function(ed) {
+                               ed.pasteAsPlainText = true;
+                       });
+               }
+
+       });
+*/
+
+       $(document).ready(function() { 
+
+               $('#event-share-checkbox').change(function() {
+
+                       if ($('#event-share-checkbox').is(':checked')) { 
+                               $('#acl-wrapper').show();
+                       }
+                       else {
+                               $('#acl-wrapper').hide();
+                       }
+               }).trigger('change');
+
+
+               $('#contact_allow, #contact_deny, #group_allow, #group_deny').change(function() {
+                       var selstr;
+                       $('#contact_allow option:selected, #contact_deny option:selected, #group_allow option:selected, #group_deny option:selected').each( function() {
+                               selstr = $(this).text();
+                               $('#jot-public').hide();
+                       });
+                       if(selstr == null) {
+                               $('#jot-public').show();
+                       }
+
+               }).trigger('change');
+
+       });
+
+</script>
+
diff --git a/view/theme/frost-mobile/experimental b/view/theme/frost-mobile/experimental
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/view/theme/frost-mobile/field_input.tpl b/view/theme/frost-mobile/field_input.tpl
new file mode 100644 (file)
index 0000000..58e1740
--- /dev/null
@@ -0,0 +1,6 @@
+       
+       <div class='field input' id='wrapper_$field.0'>
+               <label for='id_$field.0'>$field.1</label><br />
+               <input name='$field.0' id='id_$field.0' value="$field.2">
+               <span class='field_help'>$field.3</span>
+       </div>
diff --git a/view/theme/frost-mobile/field_openid.tpl b/view/theme/frost-mobile/field_openid.tpl
new file mode 100644 (file)
index 0000000..8d330a3
--- /dev/null
@@ -0,0 +1,6 @@
+       
+       <div class='field input openid' id='wrapper_$field.0'>
+               <label for='id_$field.0'>$field.1</label><br />
+               <input name='$field.0' id='id_$field.0' value="$field.2">
+               <span class='field_help'>$field.3</span>
+       </div>
diff --git a/view/theme/frost-mobile/field_password.tpl b/view/theme/frost-mobile/field_password.tpl
new file mode 100644 (file)
index 0000000..7a0d3fe
--- /dev/null
@@ -0,0 +1,6 @@
+       
+       <div class='field password' id='wrapper_$field.0'>
+               <label for='id_$field.0'>$field.1</label><br />
+               <input type='password' name='$field.0' id='id_$field.0' value="$field.2">
+               <span class='field_help'>$field.3</span>
+       </div>
diff --git a/view/theme/frost-mobile/file.gif b/view/theme/frost-mobile/file.gif
new file mode 100644 (file)
index 0000000..7885b99
Binary files /dev/null and b/view/theme/frost-mobile/file.gif differ
diff --git a/view/theme/frost-mobile/friendika-16.png b/view/theme/frost-mobile/friendika-16.png
new file mode 100644 (file)
index 0000000..1a742ec
Binary files /dev/null and b/view/theme/frost-mobile/friendika-16.png differ
diff --git a/view/theme/frost-mobile/head.jpg b/view/theme/frost-mobile/head.jpg
new file mode 100644 (file)
index 0000000..6210b76
Binary files /dev/null and b/view/theme/frost-mobile/head.jpg differ
diff --git a/view/theme/frost-mobile/head.tpl b/view/theme/frost-mobile/head.tpl
new file mode 100644 (file)
index 0000000..a5bf0ac
--- /dev/null
@@ -0,0 +1,105 @@
+<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
+<meta content='width=device-width, minimum-scale=1 maximum-scale=1' name='viewport'>
+<meta content='True' name='HandheldFriendly'>
+<meta content='320' name='MobileOptimized'>
+<base href="$baseurl/" />
+<meta name="generator" content="$generator" />
+<!--<link rel="stylesheet" href="$baseurl/library/fancybox/jquery.fancybox-1.3.4.css" type="text/css" media="screen" />
+<link rel="stylesheet" href="$baseurl/library/tiptip/tipTip.css" type="text/css" media="screen" />-->
+<link rel="stylesheet" href="$baseurl/library/jgrowl/jquery.jgrowl.css" type="text/css" media="screen" />
+
+<link rel="stylesheet" type="text/css" href="$stylesheet" media="all" />
+
+<link rel="shortcut icon" href="$baseurl/images/friendica-32.png" />
+<link rel="search"
+         href="$baseurl/opensearch" 
+         type="application/opensearchdescription+xml" 
+         title="Search in Friendica" />
+
+<!--[if IE]>
+<script type="text/javascript" src="https://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
+<![endif]-->
+<script type="text/javascript" src="$baseurl/js/jquery.js" ></script>
+<script type="text/javascript" src="$baseurl/js/jquery.textinputs.js" ></script>
+<script type="text/javascript" src="$baseurl/js/fk.autocomplete.js" ></script>
+<!--<script type="text/javascript" src="$baseurl/library/fancybox/jquery.fancybox-1.3.4.pack.js"></script>
+<script type="text/javascript" src="$baseurl/library/tiptip/jquery.tipTip.minified.js"></script>-->
+<script type="text/javascript" src="$baseurl/library/jgrowl/jquery.jgrowl_minimized.js"></script>
+<!--<script type="text/javascript" src="$baseurl/library/tinymce/jscripts/tiny_mce/tiny_mce_src.js" ></script>-->
+<script type="text/javascript" src="$baseurl/view/theme/frost-mobile/js/acl.js" ></script>
+<script type="text/javascript" src="$baseurl/js/webtoolkit.base64.js" ></script>
+<script type="text/javascript" src="$baseurl/view/theme/frost-mobile/js/main.js" ></script>
+<script type="text/javascript" src="$baseurl/view/theme/frost-mobile/js/theme.js"></script>
+<script>
+
+       var updateInterval = $update_interval;
+       var localUser = {{ if $local_user }}$local_user{{ else }}false{{ endif }};
+
+       function confirmDelete() { return confirm("$delitem"); }
+       function commentOpen(obj,id) {
+               if(obj.value == '$comment') {
+                       obj.value = '';
+                       $("#comment-edit-text-" + id).addClass("comment-edit-text-full");
+                       $("#comment-edit-text-" + id).removeClass("comment-edit-text-empty");
+                       $("#mod-cmnt-wrap-" + id).show();
+                       openMenu("comment-edit-submit-wrapper-" + id);
+               }
+       }
+       function commentClose(obj,id) {
+               if(obj.value == '') {
+                       obj.value = '$comment';
+                       $("#comment-edit-text-" + id).removeClass("comment-edit-text-full");
+                       $("#comment-edit-text-" + id).addClass("comment-edit-text-empty");
+                       $("#mod-cmnt-wrap-" + id).hide();
+                       closeMenu("comment-edit-submit-wrapper-" + id);
+               }
+       }
+
+
+       function commentInsert(obj,id) {
+               var tmpStr = $("#comment-edit-text-" + id).val();
+               if(tmpStr == '$comment') {
+                       tmpStr = '';
+                       $("#comment-edit-text-" + id).addClass("comment-edit-text-full");
+                       $("#comment-edit-text-" + id).removeClass("comment-edit-text-empty");
+                       openMenu("comment-edit-submit-wrapper-" + id);
+               }
+               var ins = $(obj).html();
+               ins = ins.replace('&lt;','<');
+               ins = ins.replace('&gt;','>');
+               ins = ins.replace('&amp;','&');
+               ins = ins.replace('&quot;','"');
+               $("#comment-edit-text-" + id).val(tmpStr + ins);
+       }
+
+       function qCommentInsert(obj,id) {
+               var tmpStr = $("#comment-edit-text-" + id).val();
+               if(tmpStr == '$comment') {
+                       tmpStr = '';
+                       $("#comment-edit-text-" + id).addClass("comment-edit-text-full");
+                       $("#comment-edit-text-" + id).removeClass("comment-edit-text-empty");
+                       openMenu("comment-edit-submit-wrapper-" + id);
+               }
+               var ins = $(obj).val();
+               ins = ins.replace('&lt;','<');
+               ins = ins.replace('&gt;','>');
+               ins = ins.replace('&amp;','&');
+               ins = ins.replace('&quot;','"');
+               $("#comment-edit-text-" + id).val(tmpStr + ins);
+               $(obj).val('');
+       }
+
+       function showHideComments(id) {
+               if( $('#collapsed-comments-' + id).is(':visible')) {
+                       $('#collapsed-comments-' + id).hide();
+                       $('#hide-comments-' + id).html('$showmore');
+               }
+               else {
+                       $('#collapsed-comments-' + id).show();
+                       $('#hide-comments-' + id).html('$showfewer');
+               }
+       }
+
+
+</script>
+
diff --git a/view/theme/frost-mobile/images/approve-blue.png b/view/theme/frost-mobile/images/approve-blue.png
new file mode 100644 (file)
index 0000000..a13668a
Binary files /dev/null and b/view/theme/frost-mobile/images/approve-blue.png differ
diff --git a/view/theme/frost-mobile/images/approve.png b/view/theme/frost-mobile/images/approve.png
new file mode 100644 (file)
index 0000000..473c646
Binary files /dev/null and b/view/theme/frost-mobile/images/approve.png differ
diff --git a/view/theme/frost-mobile/images/arrow-left.png b/view/theme/frost-mobile/images/arrow-left.png
new file mode 100644 (file)
index 0000000..a312cfa
Binary files /dev/null and b/view/theme/frost-mobile/images/arrow-left.png differ
diff --git a/view/theme/frost-mobile/images/arrow-right.png b/view/theme/frost-mobile/images/arrow-right.png
new file mode 100644 (file)
index 0000000..2be9bd7
Binary files /dev/null and b/view/theme/frost-mobile/images/arrow-right.png differ
diff --git a/view/theme/frost-mobile/images/boldB-serif.png b/view/theme/frost-mobile/images/boldB-serif.png
new file mode 100644 (file)
index 0000000..78ce59a
Binary files /dev/null and b/view/theme/frost-mobile/images/boldB-serif.png differ
diff --git a/view/theme/frost-mobile/images/camera.png b/view/theme/frost-mobile/images/camera.png
new file mode 100644 (file)
index 0000000..aa5935b
Binary files /dev/null and b/view/theme/frost-mobile/images/camera.png differ
diff --git a/view/theme/frost-mobile/images/code.png b/view/theme/frost-mobile/images/code.png
new file mode 100644 (file)
index 0000000..d490cea
Binary files /dev/null and b/view/theme/frost-mobile/images/code.png differ
diff --git a/view/theme/frost-mobile/images/contacts.png b/view/theme/frost-mobile/images/contacts.png
new file mode 100644 (file)
index 0000000..e870470
Binary files /dev/null and b/view/theme/frost-mobile/images/contacts.png differ
diff --git a/view/theme/frost-mobile/images/disapprove-blue.png b/view/theme/frost-mobile/images/disapprove-blue.png
new file mode 100644 (file)
index 0000000..ebbc7e4
Binary files /dev/null and b/view/theme/frost-mobile/images/disapprove-blue.png differ
diff --git a/view/theme/frost-mobile/images/disapprove.png b/view/theme/frost-mobile/images/disapprove.png
new file mode 100644 (file)
index 0000000..fa58d02
Binary files /dev/null and b/view/theme/frost-mobile/images/disapprove.png differ
diff --git a/view/theme/frost-mobile/images/drop-blue.png b/view/theme/frost-mobile/images/drop-blue.png
new file mode 100644 (file)
index 0000000..a8b6c53
Binary files /dev/null and b/view/theme/frost-mobile/images/drop-blue.png differ
diff --git a/view/theme/frost-mobile/images/drop-darkred.png b/view/theme/frost-mobile/images/drop-darkred.png
new file mode 100644 (file)
index 0000000..9657d11
Binary files /dev/null and b/view/theme/frost-mobile/images/drop-darkred.png differ
diff --git a/view/theme/frost-mobile/images/drop-red.png b/view/theme/frost-mobile/images/drop-red.png
new file mode 100644 (file)
index 0000000..91b0260
Binary files /dev/null and b/view/theme/frost-mobile/images/drop-red.png differ
diff --git a/view/theme/frost-mobile/images/drop.png b/view/theme/frost-mobile/images/drop.png
new file mode 100644 (file)
index 0000000..af38adf
Binary files /dev/null and b/view/theme/frost-mobile/images/drop.png differ
diff --git a/view/theme/frost-mobile/images/folder-blue.png b/view/theme/frost-mobile/images/folder-blue.png
new file mode 100644 (file)
index 0000000..6af9bbe
Binary files /dev/null and b/view/theme/frost-mobile/images/folder-blue.png differ
diff --git a/view/theme/frost-mobile/images/folder.png b/view/theme/frost-mobile/images/folder.png
new file mode 100644 (file)
index 0000000..86dd210
Binary files /dev/null and b/view/theme/frost-mobile/images/folder.png differ
diff --git a/view/theme/frost-mobile/images/globe.png b/view/theme/frost-mobile/images/globe.png
new file mode 100644 (file)
index 0000000..f84632b
Binary files /dev/null and b/view/theme/frost-mobile/images/globe.png differ
diff --git a/view/theme/frost-mobile/images/italicI-serif.png b/view/theme/frost-mobile/images/italicI-serif.png
new file mode 100644 (file)
index 0000000..86fa40f
Binary files /dev/null and b/view/theme/frost-mobile/images/italicI-serif.png differ
diff --git a/view/theme/frost-mobile/images/lock.png b/view/theme/frost-mobile/images/lock.png
new file mode 100644 (file)
index 0000000..b8b8cd2
Binary files /dev/null and b/view/theme/frost-mobile/images/lock.png differ
diff --git a/view/theme/frost-mobile/images/menu.png b/view/theme/frost-mobile/images/menu.png
new file mode 100644 (file)
index 0000000..44d5285
Binary files /dev/null and b/view/theme/frost-mobile/images/menu.png differ
diff --git a/view/theme/frost-mobile/images/message.png b/view/theme/frost-mobile/images/message.png
new file mode 100644 (file)
index 0000000..8f735ae
Binary files /dev/null and b/view/theme/frost-mobile/images/message.png differ
diff --git a/view/theme/frost-mobile/images/network.png b/view/theme/frost-mobile/images/network.png
new file mode 100644 (file)
index 0000000..943e325
Binary files /dev/null and b/view/theme/frost-mobile/images/network.png differ
diff --git a/view/theme/frost-mobile/images/notifications.png b/view/theme/frost-mobile/images/notifications.png
new file mode 100644 (file)
index 0000000..27bacc6
Binary files /dev/null and b/view/theme/frost-mobile/images/notifications.png differ
diff --git a/view/theme/frost-mobile/images/paperclip.png b/view/theme/frost-mobile/images/paperclip.png
new file mode 100644 (file)
index 0000000..3a2ee26
Binary files /dev/null and b/view/theme/frost-mobile/images/paperclip.png differ
diff --git a/view/theme/frost-mobile/images/pencil-blue.png b/view/theme/frost-mobile/images/pencil-blue.png
new file mode 100644 (file)
index 0000000..f51ddd4
Binary files /dev/null and b/view/theme/frost-mobile/images/pencil-blue.png differ
diff --git a/view/theme/frost-mobile/images/pencil.png b/view/theme/frost-mobile/images/pencil.png
new file mode 100644 (file)
index 0000000..8078d30
Binary files /dev/null and b/view/theme/frost-mobile/images/pencil.png differ
diff --git a/view/theme/frost-mobile/images/quote.png b/view/theme/frost-mobile/images/quote.png
new file mode 100644 (file)
index 0000000..93127c5
Binary files /dev/null and b/view/theme/frost-mobile/images/quote.png differ
diff --git a/view/theme/frost-mobile/images/recycle-blue.png b/view/theme/frost-mobile/images/recycle-blue.png
new file mode 100644 (file)
index 0000000..4129f05
Binary files /dev/null and b/view/theme/frost-mobile/images/recycle-blue.png differ
diff --git a/view/theme/frost-mobile/images/recycle.png b/view/theme/frost-mobile/images/recycle.png
new file mode 100644 (file)
index 0000000..e5d8e11
Binary files /dev/null and b/view/theme/frost-mobile/images/recycle.png differ
diff --git a/view/theme/frost-mobile/images/remote-link-blue.png b/view/theme/frost-mobile/images/remote-link-blue.png
new file mode 100644 (file)
index 0000000..de8d21d
Binary files /dev/null and b/view/theme/frost-mobile/images/remote-link-blue.png differ
diff --git a/view/theme/frost-mobile/images/remote-link.png b/view/theme/frost-mobile/images/remote-link.png
new file mode 100644 (file)
index 0000000..1f65741
Binary files /dev/null and b/view/theme/frost-mobile/images/remote-link.png differ
diff --git a/view/theme/frost-mobile/images/star-blue.png b/view/theme/frost-mobile/images/star-blue.png
new file mode 100644 (file)
index 0000000..f8783fc
Binary files /dev/null and b/view/theme/frost-mobile/images/star-blue.png differ
diff --git a/view/theme/frost-mobile/images/star-yellow.png b/view/theme/frost-mobile/images/star-yellow.png
new file mode 100644 (file)
index 0000000..cc2b884
Binary files /dev/null and b/view/theme/frost-mobile/images/star-yellow.png differ
diff --git a/view/theme/frost-mobile/images/star.png b/view/theme/frost-mobile/images/star.png
new file mode 100644 (file)
index 0000000..f8a61a4
Binary files /dev/null and b/view/theme/frost-mobile/images/star.png differ
diff --git a/view/theme/frost-mobile/images/tag-blue.png b/view/theme/frost-mobile/images/tag-blue.png
new file mode 100644 (file)
index 0000000..6e5cec8
Binary files /dev/null and b/view/theme/frost-mobile/images/tag-blue.png differ
diff --git a/view/theme/frost-mobile/images/tag.png b/view/theme/frost-mobile/images/tag.png
new file mode 100644 (file)
index 0000000..9c644b8
Binary files /dev/null and b/view/theme/frost-mobile/images/tag.png differ
diff --git a/view/theme/frost-mobile/images/underlineU-serif.png b/view/theme/frost-mobile/images/underlineU-serif.png
new file mode 100644 (file)
index 0000000..745ca2c
Binary files /dev/null and b/view/theme/frost-mobile/images/underlineU-serif.png differ
diff --git a/view/theme/frost-mobile/images/unlock.png b/view/theme/frost-mobile/images/unlock.png
new file mode 100644 (file)
index 0000000..81d9740
Binary files /dev/null and b/view/theme/frost-mobile/images/unlock.png differ
diff --git a/view/theme/frost-mobile/jot-header.tpl b/view/theme/frost-mobile/jot-header.tpl
new file mode 100644 (file)
index 0000000..b1762f1
--- /dev/null
@@ -0,0 +1,212 @@
+
+<script type="text/javascript" src="$baseurl/js/ajaxupload.js" ></script>
+
+<script>
+       var ispublic = '$ispublic';
+
+       $(document).ready(function() {
+               
+               /* enable tinymce on focus and click */
+               $("#profile-jot-text").focus(enableOnUser);
+               $("#profile-jot-text").click(enableOnUser);
+
+               var uploader = new window.AjaxUpload(
+                       'wall-image-upload',
+                       { action: 'wall_upload/$nickname',
+                               name: 'userfile',
+                               onSubmit: function(file,ext) { $('#profile-rotator').show(); },
+                               onComplete: function(file,response) {
+                                       addeditortext(response);
+                                       $('#profile-rotator').hide();
+                               }                                
+                       }
+               );
+               var file_uploader = new window.AjaxUpload(
+                       'wall-file-upload',
+                       { action: 'wall_attach/$nickname',
+                               name: 'userfile',
+                               onSubmit: function(file,ext) { $('#profile-rotator').show(); },
+                               onComplete: function(file,response) {
+                                       addeditortext(response);
+                                       $('#profile-rotator').hide();
+                               }                                
+                       }
+               );
+
+
+       });
+
+/*     function deleteCheckedItems() {
+               var checkedstr = '';
+
+               $('.item-select').each( function() {
+                       if($(this).is(':checked')) {
+                               if(checkedstr.length != 0) {
+                                       checkedstr = checkedstr + ',' + $(this).val();
+                               }
+                               else {
+                                       checkedstr = $(this).val();
+                               }
+                       }       
+               });
+               $.post('item', { dropitems: checkedstr }, function(data) {
+                       window.location.reload();
+               });
+       }*/
+
+       function jotGetLink() {
+               reply = prompt("$linkurl");
+               if(reply && reply.length) {
+                       reply = bin2hex(reply);
+                       $('#profile-rotator').show();
+                       $.get('parse_url?binurl=' + reply, function(data) {
+                               addeditortext(data);
+                               $('#profile-rotator').hide();
+                       });
+               }
+       }
+
+       function jotVideoURL() {
+               reply = prompt("$vidurl");
+               if(reply && reply.length) {
+                       addeditortext('[video]' + reply + '[/video]');
+               }
+       }
+
+       function jotAudioURL() {
+               reply = prompt("$audurl");
+               if(reply && reply.length) {
+                       addeditortext('[audio]' + reply + '[/audio]');
+               }
+       }
+
+
+       function jotGetLocation() {
+               reply = prompt("$whereareu", $('#jot-location').val());
+               if(reply && reply.length) {
+                       $('#jot-location').val(reply);
+               }
+       }
+
+       function jotShare(id) {
+               if ($('#jot-popup').length != 0) $('#jot-popup').show();
+
+               $('#like-rotator-' + id).show();
+               $.get('share/' + id, function(data) {
+                       if (!editor) $("#profile-jot-text").val("");
+                       initEditor(function(){
+                               addeditortext(data);
+                               $('#like-rotator-' + id).hide();
+                               $(window).scrollTop(0);
+                       });
+
+               });
+       }
+
+/*     function linkdropper(event) {
+               var linkFound = event.dataTransfer.types.contains("text/uri-list");
+               if(linkFound)
+                       event.preventDefault();
+       }
+
+       function linkdrop(event) {
+               var reply = event.dataTransfer.getData("text/uri-list");
+               event.target.textContent = reply;
+               event.preventDefault();
+               if(reply && reply.length) {
+                       reply = bin2hex(reply);
+                       $('#profile-rotator').show();
+                       $.get('parse_url?binurl=' + reply, function(data) {
+                               if (!editor) $("#profile-jot-text").val("");
+                               initEditor(function(){
+                                       addeditortext(data);
+                                       $('#profile-rotator').hide();
+                               });
+                       });
+               }
+       }*/
+
+       function itemTag(id) {
+               reply = prompt("$term");
+               if(reply && reply.length) {
+                       reply = reply.replace('#','');
+                       if(reply.length) {
+
+                               commentBusy = true;
+                               $('body').css('cursor', 'wait');
+
+                               $.get('tagger/' + id + '?term=' + reply);
+                               if(timer) clearTimeout(timer);
+                               timer = setTimeout(NavUpdate,3000);
+                               liking = 1;
+                       }
+               }
+       }
+
+       function itemFiler(id) {
+               
+               $.get('filer/', function(data){
+
+                       var promptText = $('#id_term_label', data).text();
+
+                       reply = prompt(promptText);
+                       if(reply && reply.length) {
+                               commentBusy = true;
+                               $('body').css('cursor', 'wait');
+                               $.get('filer/' + id + '?term=' + reply, NavUpdate);
+/*                             if(timer) clearTimeout(timer);
+                               timer = setTimeout(NavUpdate,3000);*/
+                               liking = 1;
+/*                             $.fancybox.close();*/
+                       }
+               });
+
+/*             var bordercolor = $("input").css("border-color");
+               
+               $.get('filer/', function(data){
+                       $.fancybox(data);
+                       $("#id_term").keypress(function(){
+                               $(this).css("border-color",bordercolor);
+                       })
+                       $("#select_term").change(function(){
+                               $("#id_term").css("border-color",bordercolor);
+                       })
+                       
+                       $("#filer_save").click(function(e){
+                               e.preventDefault();
+                               reply = $("#id_term").val();
+                               if(reply && reply.length) {
+                                       commentBusy = true;
+                                       $('body').css('cursor', 'wait');
+                                       $.get('filer/' + id + '?term=' + reply);
+                                       if(timer) clearTimeout(timer);
+                                       timer = setTimeout(NavUpdate,3000);
+                                       liking = 1;
+                                       $.fancybox.close();
+                               } else {
+                                       $("#id_term").css("border-color","#FF0000");
+                               }
+                               return false;
+                       });
+               });
+*/             
+       }
+
+       function jotClearLocation() {
+               $('#jot-coord').val('');
+               $('#profile-nolocation-wrapper').hide();
+       }
+
+       function addeditortext(data) {
+               if(plaintext == 'none') {
+                       var currentText = $("#profile-jot-text").val();
+                       $("#profile-jot-text").val(currentText + data);
+               }
+/*             else
+                       tinyMCE.execCommand('mceInsertRawHTML',false,data);*/
+       }       
+
+       $geotag
+
+</script>
+
diff --git a/view/theme/frost-mobile/jot.tpl b/view/theme/frost-mobile/jot.tpl
new file mode 100644 (file)
index 0000000..e39453e
--- /dev/null
@@ -0,0 +1,85 @@
+
+<div id="profile-jot-wrapper" >
+       <div id="profile-jot-banner-wrapper">
+               <div id="profile-jot-desc" >&nbsp;</div>
+               <div id="character-counter" class="grey"></div>
+       </div>
+       <div id="profile-jot-banner-end"></div>
+
+       <form id="profile-jot-form" action="$action" method="post" >
+               <input type="hidden" name="type" value="$ptyp" />
+               <input type="hidden" name="profile_uid" value="$profile_uid" />
+               <input type="hidden" name="return" value="$return_path" />
+               <input type="hidden" name="location" id="jot-location" value="$defloc" />
+               <input type="hidden" name="coord" id="jot-coord" value="" />
+               <input type="hidden" name="post_id" value="$post_id" />
+               <input type="hidden" name="preview" id="jot-preview" value="0" />
+               <div id="jot-title-wrap"><input name="title" id="jot-title" type="text" placeholder="$placeholdertitle" value="$title" class="jothidden" style="display:none"></div>
+               <div id="jot-category-wrap"><input name="category" id="jot-category" type="text" placeholder="$placeholdercategory" value="$category" class="jothidden" style="display:none" /></div>
+               <div id="jot-text-wrap">
+               <!--<img id="profile-jot-text-loading" src="images/rotator.gif" alt="$wait" title="$wait" style="display: none;" />-->
+               <textarea rows="5" cols="64" class="profile-jot-text" id="profile-jot-text" name="body" >{{ if $content }}$content{{ else }}$share{{ endif }}</textarea>
+               </div>
+
+<div id="profile-jot-submit-wrapper" class="jothidden">
+       <input type="submit" id="profile-jot-submit" name="submit" value="$share" />
+
+       <div id="profile-upload-wrapper" style="display: $visitor;" >
+               <div id="wall-image-upload-div" ><a href="#" onclick="return false;" id="wall-image-upload" class="icon camera" title="$upload"></a></div>
+       </div> 
+       <div id="profile-attach-wrapper" style="display: $visitor;" >
+               <div id="wall-file-upload-div" ><a href="#" onclick="return false;" id="wall-file-upload" class="icon attach" title="$attach"></a></div>
+       </div> 
+
+       <div id="profile-link-wrapper" style="display: $visitor;" ondragenter="linkdropper(event);" ondragover="linkdropper(event);" ondrop="linkdrop(event);" >
+               <a id="profile-link" class="icon link" title="$weblink" ondragenter="return linkdropper(event);" ondragover="return linkdropper(event);" ondrop="linkdrop(event);" onclick="jotGetLink(); return false;"></a>
+       </div> 
+       <div id="profile-video-wrapper" style="display: $visitor;" >
+               <a id="profile-video" class="icon video" title="$video" onclick="jotVideoURL();return false;"></a>
+       </div> 
+       <div id="profile-audio-wrapper" style="display: $visitor;" >
+               <a id="profile-audio" class="icon audio" title="$audio" onclick="jotAudioURL();return false;"></a>
+       </div> 
+       <div id="profile-location-wrapper" style="display: $visitor;" >
+               <a id="profile-location" class="icon globe" title="$setloc" onclick="jotGetLocation();return false;"></a>
+       </div> 
+       <div id="profile-nolocation-wrapper" style="display: none;" >
+               <a id="profile-nolocation" class="icon noglobe" title="$noloc" onclick="jotClearLocation();return false;"></a>
+       </div> 
+
+       <div id="profile-jot-perms" class="profile-jot-perms" style="display: $pvisit;" >
+               <a href="#profile-jot-acl-wrapper" id="jot-perms-icon" class="icon $lockstate"  title="$permset" ></a>$bang
+       </div>
+
+       <span onclick="preview_post();" id="jot-preview-link" class="fakelink">$preview</span>
+
+       <div id="profile-jot-perms-end"></div>
+
+
+       <div id="profile-jot-plugin-wrapper">
+       $jotplugins
+       </div>
+
+       <div id="profile-rotator-wrapper" style="display: $visitor;" >
+               <img id="profile-rotator" src="images/rotator.gif" alt="$wait" title="$wait" style="display: none;" />
+       </div> 
+       
+       <div id="jot-preview-content" style="display:none;"></div>
+
+       <div style="display: none;">
+               <div id="profile-jot-acl-wrapper">
+                       $acl
+                       <hr style="clear:both"/>
+                       <div id="profile-jot-email-label">$emailcc</div><input type="text" name="emailcc" id="profile-jot-email" title="$emtitle" />
+                       <div id="profile-jot-email-end"></div>
+                       $jotnets
+               </div>
+       </div>
+
+
+</div>
+
+<div id="profile-jot-end"></div>
+</form>
+</div>
+               {{ if $content }}<script>initEditor();</script>{{ endif }}
diff --git a/view/theme/frost-mobile/js/acl.js b/view/theme/frost-mobile/js/acl.js
new file mode 100644 (file)
index 0000000..a2fb062
--- /dev/null
@@ -0,0 +1,258 @@
+function ACL(backend_url, preset){
+       that = this;
+       
+       that.url = backend_url;
+       
+       that.kp_timer = null;
+       
+       if (preset==undefined) preset = [];
+       that.allow_cid = (preset[0] || []);
+       that.allow_gid = (preset[1] || []);
+       that.deny_cid  = (preset[2] || []);
+       that.deny_gid  = (preset[3] || []);
+       that.group_uids = [];
+       that.nw = 2; //items per row. should be calulated from #acl-list.width
+       
+       that.list_content = $("#acl-list-content");
+       that.item_tpl = unescape($(".acl-list-item[rel=acl-template]").html());
+       that.showall = $("#acl-showall");
+
+       if (preset.length==0) that.showall.addClass("selected");
+       
+       /*events*/
+       that.showall.click(that.on_showall);
+       $(".acl-button-show").live('click', that.on_button_show);
+       $(".acl-button-hide").live('click', that.on_button_hide);
+       $("#acl-search").keypress(that.on_search);
+       $("#acl-wrapper").parents("form").submit(that.on_submit);
+       
+       /* startup! */
+       that.get(0,100);
+}
+
+ACL.prototype.on_submit = function(){
+       aclfileds = $("#acl-fields").html("");
+       $(that.allow_gid).each(function(i,v){
+               aclfileds.append("<input type='hidden' name='group_allow[]' value='"+v+"'>");
+       });
+       $(that.allow_cid).each(function(i,v){
+               aclfileds.append("<input type='hidden' name='contact_allow[]' value='"+v+"'>");
+       });
+       $(that.deny_gid).each(function(i,v){
+               aclfileds.append("<input type='hidden' name='group_deny[]' value='"+v+"'>");
+       });
+       $(that.deny_cid).each(function(i,v){
+               aclfileds.append("<input type='hidden' name='contact_deny[]' value='"+v+"'>");
+       });     
+}
+
+ACL.prototype.search = function(){
+       var srcstr = $("#acl-search").val();
+       that.list_content.html("");
+       that.get(0,100, srcstr);
+}
+
+ACL.prototype.on_search = function(event){
+       if (that.kp_timer) clearTimeout(that.kp_timer);
+       that.kp_timer = setTimeout( that.search, 1000);
+}
+
+ACL.prototype.on_showall = function(event){
+       event.preventDefault()
+       event.stopPropagation();
+       
+       if (that.showall.hasClass("selected")){
+               return false;
+       }
+       that.showall.addClass("selected");
+       
+       that.allow_cid = [];
+       that.allow_gid = [];
+       that.deny_cid  = [];
+       that.deny_gid  = [];
+       
+       that.update_view();
+       
+       return false;
+}
+
+ACL.prototype.on_button_show = function(event){
+       event.preventDefault()
+       event.stopImmediatePropagation()
+       event.stopPropagation();
+
+       /*that.showall.removeClass("selected");
+       $(this).siblings(".acl-button-hide").removeClass("selected");
+       $(this).toggleClass("selected");*/
+
+       that.set_allow($(this).parent().attr('id'));
+
+       return false;
+}
+ACL.prototype.on_button_hide = function(event){
+       event.preventDefault()
+       event.stopImmediatePropagation()
+       event.stopPropagation();
+
+       /*that.showall.removeClass("selected");
+       $(this).siblings(".acl-button-show").removeClass("selected");
+       $(this).toggleClass("selected");*/
+
+       that.set_deny($(this).parent().attr('id'));
+
+       return false;
+}
+
+ACL.prototype.set_allow = function(itemid){
+       type = itemid[0];
+       id       = parseInt(itemid.substr(1));
+       switch(type){
+               case "g":
+                       if (that.allow_gid.indexOf(id)<0){
+                               that.allow_gid.push(id)
+                       }else {
+                               that.allow_gid.remove(id);
+                       }
+                       if (that.deny_gid.indexOf(id)>=0) that.deny_gid.remove(id);
+                       break;
+               case "c":
+                       if (that.allow_cid.indexOf(id)<0){
+                               that.allow_cid.push(id)
+                       } else {
+                               that.allow_cid.remove(id);
+                       }
+                       if (that.deny_cid.indexOf(id)>=0) that.deny_cid.remove(id);                     
+                       break;
+       }
+       that.update_view();
+}
+
+ACL.prototype.set_deny = function(itemid){
+       type = itemid[0];
+       id       = parseInt(itemid.substr(1));
+       switch(type){
+               case "g":
+                       if (that.deny_gid.indexOf(id)<0){
+                               that.deny_gid.push(id)
+                       } else {
+                               that.deny_gid.remove(id);
+                       }
+                       if (that.allow_gid.indexOf(id)>=0) that.allow_gid.remove(id);
+                       break;
+               case "c":
+                       if (that.deny_cid.indexOf(id)<0){
+                               that.deny_cid.push(id)
+                       } else {
+                               that.deny_cid.remove(id);
+                       }
+                       if (that.allow_cid.indexOf(id)>=0) that.allow_cid.remove(id);
+                       break;
+       }
+       that.update_view();
+}
+
+ACL.prototype.update_view = function(){
+       if (that.allow_gid.length==0 && that.allow_cid.length==0 &&
+               that.deny_gid.length==0 && that.deny_cid.length==0){
+                       that.showall.addClass("selected");
+                       /* jot acl */
+                               $('#jot-perms-icon').removeClass('lock').addClass('unlock');
+                               $('#jot-public').show();
+                               $('.profile-jot-net input').attr('disabled', false);                    
+                               if(typeof editor != 'undefined' && editor != false) {
+                                       $('#profile-jot-desc').html(ispublic);
+                               }
+                       
+       } else {
+                       that.showall.removeClass("selected");
+                       /* jot acl */
+                               $('#jot-perms-icon').removeClass('unlock').addClass('lock');
+                               $('#jot-public').hide();
+                               $('.profile-jot-net input').attr('disabled', 'disabled');                       
+                               $('#profile-jot-desc').html('&nbsp;');
+       }
+       $("#acl-list-content .acl-list-item").each(function(){
+               $(this).removeClass("groupshow grouphide");
+       });
+       
+       $("#acl-list-content .acl-list-item").each(function(){
+               itemid = $(this).attr('id');
+               type = itemid[0];
+               id       = parseInt(itemid.substr(1));
+               
+               btshow = $(this).children(".acl-button-show").removeClass("selected");
+               bthide = $(this).children(".acl-button-hide").removeClass("selected");  
+               
+               switch(type){
+                       case "g":
+                               var uclass = "";
+                               if (that.allow_gid.indexOf(id)>=0){
+                                       btshow.addClass("selected");
+                                       bthide.removeClass("selected");
+                                       uclass="groupshow";
+                               }
+                               if (that.deny_gid.indexOf(id)>=0){
+                                       btshow.removeClass("selected");
+                                       bthide.addClass("selected");
+                                       uclass="grouphide";
+                               }
+                               
+                               $(that.group_uids[id]).each(function(i,v) {
+                                       if(uclass == "grouphide")
+                                               $("#c"+v).removeClass("groupshow");
+                                       if(uclass != "") {
+                                               var cls = $("#c"+v).attr('class');
+                                               if( cls == undefined)
+                                                       return true;
+                                               var hiding = cls.indexOf('grouphide');
+                                               if(hiding == -1)
+                                                       $("#c"+v).addClass(uclass);
+                                       }
+                               });
+                               
+                               break;
+                       case "c":
+                               if (that.allow_cid.indexOf(id)>=0){
+                                       btshow.addClass("selected");
+                                       bthide.removeClass("selected");
+                               }
+                               if (that.deny_cid.indexOf(id)>=0){
+                                       btshow.removeClass("selected");
+                                       bthide.addClass("selected");
+                               }                       
+               }
+               
+       });
+       
+}
+
+
+ACL.prototype.get = function(start,count, search){
+       var postdata = {
+               start:start,
+               count:count,
+               search:search,
+       }
+       
+       $.ajax({
+               type:'POST',
+               url: that.url,
+               data: postdata,
+               dataType: 'json',
+               success:that.populate
+       });
+}
+
+ACL.prototype.populate = function(data){
+/*     var height = Math.ceil(data.tot / that.nw) * 42;
+       that.list_content.height(height);*/
+       $(data.items).each(function(){
+               html = "<div class='acl-list-item {4} {5}' title='{6}' id='{2}{3}'>"+that.item_tpl+"</div>";
+               html = html.format( this.photo, this.name, this.type, this.id, '', this.network, this.link );
+               if (this.uids!=undefined) that.group_uids[this.id] = this.uids;
+               //console.log(html);
+               that.list_content.append(html);
+       });
+       that.update_view();
+}
+
diff --git a/view/theme/frost-mobile/js/main.js b/view/theme/frost-mobile/js/main.js
new file mode 100644 (file)
index 0000000..a32d38e
--- /dev/null
@@ -0,0 +1,663 @@
+
+  function openClose(theID) {
+    if(document.getElementById(theID).style.display == "block") { 
+      document.getElementById(theID).style.display = "none" 
+    }
+    else { 
+      document.getElementById(theID).style.display = "block" 
+    } 
+  }
+
+  function openMenu(theID) {
+      document.getElementById(theID).style.display = "block" 
+  }
+
+  function closeMenu(theID) {
+      document.getElementById(theID).style.display = "none" 
+  }
+
+
+
+       var src = null;
+       var prev = null;
+       var livetime = null;
+       var msie = false;
+       var stopped = false;
+       var totStopped = false;
+       var timer = null;
+       var pr = 0;
+       var liking = 0;
+       var in_progress = false;
+       var langSelect = false;
+       var commentBusy = false;
+       var last_popup_menu = null;
+       var last_popup_button = null;
+
+       $(function() {
+               $.ajaxSetup({cache: false});
+
+               msie = $.browser.msie ;
+               
+               /* setup tooltips *//*
+               $("a,.tt").each(function(){
+                       var e = $(this);
+                       var pos="bottom";
+                       if (e.hasClass("tttop")) pos="top";
+                       if (e.hasClass("ttbottom")) pos="bottom";
+                       if (e.hasClass("ttleft")) pos="left";
+                       if (e.hasClass("ttright")) pos="right";
+                       e.tipTip({defaultPosition: pos, edgeOffset: 8});
+               });*/
+               
+               
+               
+               /* setup onoff widgets */
+               $(".onoff input").each(function(){
+                       val = $(this).val();
+                       id = $(this).attr("id");
+                       $("#"+id+"_onoff ."+ (val==0?"on":"off")).addClass("hidden");
+                       
+               });
+               $(".onoff > a").click(function(event){
+                       event.preventDefault(); 
+                       var input = $(this).siblings("input");
+                       var val = 1-input.val();
+                       var id = input.attr("id");
+                       $("#"+id+"_onoff ."+ (val==0?"on":"off")).addClass("hidden");
+                       $("#"+id+"_onoff ."+ (val==1?"on":"off")).removeClass("hidden");
+                       input.val(val);
+                       //console.log(id);
+               });
+               
+               /* setup field_richtext */
+               /*setupFieldRichtext();*/
+
+               /* popup menus */
+               function close_last_popup_menu(e) {
+
+                       if( last_popup_menu ) {
+                               if( '#' + last_popup_menu.attr('id') !== $(e.target).attr('rel')) {
+                                       last_popup_menu.hide();
+                                       if (last_popup_menu.attr('id') == "nav-notifications-menu" ) $('section').show();
+                                       last_popup_button.removeClass("selected");
+                                       last_popup_menu = null;
+                                       last_popup_button = null;
+                               }
+                       }
+               }
+               $('img[rel^=#]').click(function(e){
+
+                       close_last_popup_menu(e);
+                       menu = $( $(this).attr('rel') );
+                       e.preventDefault();
+                       e.stopPropagation();
+
+                       if (menu.attr('popup')=="false") return false;
+
+//                     $(this).parent().toggleClass("selected");
+//                     menu.toggle();
+
+                       if (menu.css("display") == "none") {
+                               $(this).parent().addClass("selected");
+                               menu.show();
+                               if (menu.attr('id') == "nav-notifications-menu" ) $('section').hide();
+                               last_popup_menu = menu;
+                               last_popup_button = $(this).parent();
+                       } else {
+                               $(this).parent().removeClass("selected");
+                               menu.hide();
+                               if (menu.attr('id') == "nav-notifications-menu" ) $('section').show();
+                               last_popup_menu = null;
+                               last_popup_button = null;
+                       }
+                       return false;
+               });
+               $('html').click(function(e) {
+                       close_last_popup_menu(e);
+               });
+               
+               // fancyboxes
+               /*$("a.popupbox").fancybox({
+                       'transitionIn' : 'elastic',
+                       'transitionOut' : 'elastic'
+               });*/
+               
+
+               /* notifications template */
+               var notifications_tpl= unescape($("#nav-notifications-template[rel=template]").html());
+               var notifications_all = unescape($('<div>').append( $("#nav-notifications-see-all").clone() ).html()); //outerHtml hack
+               var notifications_mark = unescape($('<div>').append( $("#nav-notifications-mark-all").clone() ).html()); //outerHtml hack
+               var notifications_empty = unescape($("#nav-notifications-menu").html());
+               
+               /* nav update event  */
+               $('nav').bind('nav-update', function(e,data){;
+                       var invalid = $(data).find('invalid').text();
+                       if(invalid == 1) { window.location.href=window.location.href }
+
+                       var net = $(data).find('net').text();
+                       if(net == 0) { net = ''; $('#net-update').removeClass('show') } else { $('#net-update').addClass('show') }
+                       $('#net-update').html(net);
+
+                       var home = $(data).find('home').text();
+                       if(home == 0) { home = '';  $('#home-update').removeClass('show') } else { $('#home-update').addClass('show') }
+                       $('#home-update').html(home);
+                       
+                       var intro = $(data).find('intro').text();
+                       if(intro == 0) { intro = '';  $('#intro-update').removeClass('show') } else { $('#intro-update').addClass('show') }
+                       $('#intro-update').html(intro);
+
+                       var mail = $(data).find('mail').text();
+                       if(mail == 0) { mail = '';  $('#mail-update').removeClass('show') } else { $('#mail-update').addClass('show') }
+                       $('#mail-update').html(mail);
+                       
+                       var intro = $(data).find('intro').text();
+                       if(intro == 0) { intro = '';  $('#intro-update-li').removeClass('show') } else { $('#intro-update-li').addClass('show') }
+                       $('#intro-update-li').html(intro);
+
+                       var mail = $(data).find('mail').text();
+                       if(mail == 0) { mail = '';  $('#mail-update-li').removeClass('show') } else { $('#mail-update-li').addClass('show') }
+                       $('#mail-update-li').html(mail);
+
+                       var eNotif = $(data).find('notif')
+                       
+                       if (eNotif.children("note").length==0){
+                               $("#nav-notifications-menu").html(notifications_empty);
+                       } else {
+                               nnm = $("#nav-notifications-menu");
+                               nnm.html(notifications_all + notifications_mark);
+                               //nnm.attr('popup','true');
+                               eNotif.children("note").each(function(){
+                                       e = $(this);
+                                       text = e.text().format("<span class='contactname'>"+e.attr('name')+"</span>");
+                                       html = notifications_tpl.format(e.attr('href'),e.attr('photo'), text, e.attr('date'), e.attr('seen'));
+                                       nnm.append(html);
+                               });
+                       }
+                       notif = eNotif.attr('count');
+                       if (notif>0){
+                               $("#nav-notifications-linkmenu").addClass("on");
+                       } else {
+                               $("#nav-notifications-linkmenu").removeClass("on");
+                       }
+                       if(notif == 0) { notif = ''; $('#notify-update').removeClass('show') } else { $('#notify-update').addClass('show') }
+                       $('#notify-update').html(notif);
+                       
+                       var eSysmsg = $(data).find('sysmsgs');
+                       eSysmsg.children("notice").each(function(){
+                               text = $(this).text();
+                               $.jGrowl(text, { sticky: true, theme: 'notice', life: 1000 });
+                       });
+                       eSysmsg.children("info").each(function(){
+                               text = $(this).text();
+                               $.jGrowl(text, { sticky: false, theme: 'info', life: 1000 });
+                       });
+                       
+               });
+               
+               
+               NavUpdate(); 
+               // Allow folks to stop the ajax page updates with the pause/break key
+/*             $(document).keydown(function(event) {
+                       if(event.keyCode == '8') {
+                               var target = event.target || event.srcElement;
+                               if (!/input|textarea/i.test(target.nodeName)) {
+                                       return false;
+                               }
+                       }
+                       if(event.keyCode == '19' || (event.ctrlKey && event.which == '32')) {
+                               event.preventDefault();
+                               if(stopped == false) {
+                                       stopped = true;
+                                       if (event.ctrlKey) {
+                                               totStopped = true;
+                                       }
+                                       $('#pause').html('<img src="images/pause.gif" alt="pause" style="border: 1px solid black;" />');
+                               } else {
+                                       unpause();
+                               }
+                       } else {
+                               if (!totStopped) {
+                                       unpause();
+                               }
+                       }
+               });*/
+               
+               
+       });
+
+       function NavUpdate() {
+
+               if(! stopped) {
+                       var pingCmd = 'ping' + ((localUser != 0) ? '?f=&uid=' + localUser : '');
+                       $.get(pingCmd,function(data) {
+                               $(data).find('result').each(function() {
+                                       // send nav-update event
+                                       $('nav').trigger('nav-update', this);
+                                       
+                                       
+                                       // start live update
+
+                                       
+
+                                       if($('#live-network').length)   { src = 'network'; liveUpdate(); }
+                                       if($('#live-profile').length)   { src = 'profile'; liveUpdate(); }
+                                       if($('#live-community').length) { src = 'community'; liveUpdate(); }
+                                       if($('#live-notes').length)     { src = 'notes'; liveUpdate(); }
+                                       if($('#live-display').length) {
+                                               if(liking) {
+                                                       liking = 0;
+                                                       window.location.href=window.location.href 
+                                               }
+                                       }
+                                       if($('#live-photos').length) {
+                                               if(liking) {
+                                                       liking = 0;
+                                                       window.location.href=window.location.href 
+                                               }
+                                       }
+
+                                       
+                                       
+                                       
+                               });
+                       }) ;
+               }
+               timer = setTimeout(NavUpdate,updateInterval);
+       }
+
+       function liveUpdate() {
+               if((src == null) || (stopped) || (! profile_uid)) { $('.like-rotator').hide(); return; }
+               if(($('.comment-edit-text-full').length) || (in_progress)) {
+                       if(livetime) {
+                               clearTimeout(livetime);
+                       }
+                       livetime = setTimeout(liveUpdate, 10000);
+                       return;
+               }
+               if(livetime != null)
+                       livetime = null;
+
+               prev = 'live-' + src;
+
+               in_progress = true;
+               var udargs = ((netargs.length) ? '/' + netargs : '');
+               var update_url = 'update_' + src + udargs + '&p=' + profile_uid + '&page=' + profile_page + '&msie=' + ((msie) ? 1 : 0);
+
+               $.get(update_url,function(data) {
+                       in_progress = false;
+                       //                      $('.collapsed-comments',data).each(function() {
+                       //      var ident = $(this).attr('id');
+                       //      var is_hidden = $('#' + ident).is(':hidden');
+                       //      if($('#' + ident).length) {
+                       //              $('#' + ident).replaceWith($(this));
+                       //              if(is_hidden)
+                       //                      $('#' + ident).hide();
+                       //      }
+                       //});
+
+                       // add a new thread
+
+                       $('.tread-wrapper',data).each(function() {
+                               var ident = $(this).attr('id');
+
+                               if($('#' + ident).length == 0 && profile_page == 1) {
+                                       $('img',this).each(function() {
+                                               $(this).attr('src',$(this).attr('dst'));
+                                       });
+                                       $('#' + prev).after($(this));
+                               }
+                               else {
+                                       $('img',this).each(function() {
+                                               $(this).attr('src',$(this).attr('dst'));
+                                       });
+                                       $('#' + ident).replaceWith($(this));
+                               }
+                               prev = ident;
+                       });
+
+                       // reset vars for inserting individual items
+
+                       /*prev = 'live-' + src;
+
+                       $('.wall-item-outside-wrapper',data).each(function() {
+                               var ident = $(this).attr('id');
+
+                               if($('#' + ident).length == 0 && prev != 'live-' + src) {
+                                               $('img',this).each(function() {
+                                                       $(this).attr('src',$(this).attr('dst'));
+                                               });
+                                               $('#' + prev).after($(this));
+                               }
+                               else { 
+                                       $('#' + ident + ' ' + '.wall-item-ago').replaceWith($(this).find('.wall-item-ago')); 
+                                       if($('#' + ident + ' ' + '.comment-edit-text-empty').length)
+                                               $('#' + ident + ' ' + '.wall-item-comment-wrapper').replaceWith($(this).find('.wall-item-comment-wrapper'));
+                                       $('#' + ident + ' ' + '.hide-comments-total').replaceWith($(this).find('.hide-comments-total'));
+                                       $('#' + ident + ' ' + '.wall-item-like').replaceWith($(this).find('.wall-item-like'));
+                                       $('#' + ident + ' ' + '.wall-item-dislike').replaceWith($(this).find('.wall-item-dislike'));
+                                       $('#' + ident + ' ' + '.my-comment-photo').each(function() {
+                                               $(this).attr('src',$(this).attr('dst'));
+                                       });
+                               }
+                               prev = ident; 
+                       });*/
+                       
+                       $('.like-rotator').hide();
+                       if(commentBusy) {
+                               commentBusy = false;
+                               $('body').css('cursor', 'auto');
+                       }
+                       /* autocomplete @nicknames */
+                       $(".comment-edit-form  textarea").contact_autocomplete(baseurl+"/acl");
+               });
+       }
+
+       function imgbright(node) {
+               $(node).removeClass("drophide").addClass("drop");
+       }
+
+       function imgdull(node) {
+               $(node).removeClass("drop").addClass("drophide");
+       }
+
+       // Since our ajax calls are asynchronous, we will give a few 
+       // seconds for the first ajax call (setting like/dislike), then 
+       // run the updater to pick up any changes and display on the page.
+       // The updater will turn any rotators off when it's done. 
+       // This function will have returned long before any of these
+       // events have completed and therefore there won't be any
+       // visible feedback that anything changed without all this
+       // trickery. This still could cause confusion if the "like" ajax call
+       // is delayed and NavUpdate runs before it completes.
+
+       function dolike(ident,verb) {
+               unpause();
+               $('#like-rotator-' + ident.toString()).show();
+               $.get('like/' + ident.toString() + '?verb=' + verb, NavUpdate );
+//             if(timer) clearTimeout(timer);
+//             timer = setTimeout(NavUpdate,3000);
+               liking = 1;
+       }
+
+       function dostar(ident) {
+               ident = ident.toString();
+               //$('#like-rotator-' + ident).show();
+               $.get('starred/' + ident, function(data) {
+                       if(data.match(/1/)) {
+                               $('#starred-' + ident).addClass('starred');
+                               $('#starred-' + ident).removeClass('unstarred');
+                               $('#star-' + ident).addClass('hidden');
+                               $('#unstar-' + ident).removeClass('hidden');
+                       }
+                       else {                  
+                               $('#starred-' + ident).addClass('unstarred');
+                               $('#starred-' + ident).removeClass('starred');
+                               $('#star-' + ident).removeClass('hidden');
+                               $('#unstar-' + ident).addClass('hidden');
+                       }
+                       //$('#like-rotator-' + ident).hide();   
+               });
+       }
+
+       function getPosition(e) {
+               var cursor = {x:0, y:0};
+               if ( e.pageX || e.pageY  ) {
+                       cursor.x = e.pageX;
+                       cursor.y = e.pageY;
+               }
+               else {
+                       if( e.clientX || e.clientY ) {
+                               cursor.x = e.clientX + (document.documentElement.scrollLeft || document.body.scrollLeft) - document.documentElement.clientLeft;
+                               cursor.y = e.clientY + (document.documentElement.scrollTop  || document.body.scrollTop)  - document.documentElement.clientTop;
+                       }
+                       else {
+                               if( e.x || e.y ) {
+                                       cursor.x = e.x;
+                                       cursor.y = e.y;
+                               }
+                       }
+               }
+               return cursor;
+       }
+
+       var lockvisible = false;
+
+       function lockview(event,id) {
+               event = event || window.event;
+               cursor = getPosition(event);
+               if(lockvisible) {
+                       lockviewhide();
+               }
+               else {
+                       lockvisible = true;
+                       $.get('lockview/' + id, function(data) {
+                               $('#panel').html(data);
+                               $('#panel').css({ 'left': cursor.x + 5 , 'top': cursor.y + 5});
+                               $('#panel').show();
+                       });
+               }
+       }
+
+       function lockviewhide() {
+               lockvisible = false;
+               $('#panel').hide();
+       }
+
+       function post_comment(id) {
+               unpause();
+               commentBusy = true;
+               $('body').css('cursor', 'wait');
+               $("#comment-preview-inp-" + id).val("0");
+               $.post(  
+             "item",  
+             $("#comment-edit-form-" + id).serialize(),
+                       function(data) {
+                               if(data.success) {
+                                       $("#comment-edit-wrapper-" + id).hide();
+                                       $("#comment-edit-text-" + id).val('');
+                               var tarea = document.getElementById("comment-edit-text-" + id);
+                                       if(tarea)
+                                               commentClose(tarea,id);
+                                       if(timer) clearTimeout(timer);
+                                       timer = setTimeout(NavUpdate,10);
+                               }
+                               if(data.reload) {
+                                       window.location.href=data.reload;
+                               }
+                       },
+                       "json"  
+         );  
+         return false;  
+       }
+
+
+       function preview_comment(id) {
+               $("#comment-preview-inp-" + id).val("1");
+               $("#comment-edit-preview-" + id).show();
+               $.post(  
+             "item",  
+             $("#comment-edit-form-" + id).serialize(),
+                       function(data) {
+                               if(data.preview) {
+                                               
+                                       $("#comment-edit-preview-" + id).html(data.preview);
+                                       $("#comment-edit-preview-" + id + " a").click(function() { return false; });
+                               }
+                       },
+                       "json"  
+         );  
+         return true;  
+       }
+
+
+
+       function preview_post() {
+               $("#jot-preview").val("1");
+               $("#jot-preview-content").show();
+               tinyMCE.triggerSave();
+               $.post(  
+                       "item",  
+                       $("#profile-jot-form").serialize(),
+                       function(data) {
+                               if(data.preview) {                      
+                                       $("#jot-preview-content").html(data.preview);
+                                       $("#jot-preview-content" + " a").click(function() { return false; });
+                               }
+                       },
+                       "json"  
+               );  
+               $("#jot-preview").val("0");
+               return true;  
+       }
+
+
+       function unpause() {
+               // unpause auto reloads if they are currently stopped
+               totStopped = false;
+               stopped = false;
+           $('#pause').html('');
+       }
+               
+
+    function bin2hex(s){  
+        // Converts the binary representation of data to hex    
+        //   
+        // version: 812.316  
+        // discuss at: http://phpjs.org/functions/bin2hex  
+        // +   original by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)  
+        // +   bugfixed by: Onno Marsman  
+        // +   bugfixed by: Linuxworld  
+        // *     example 1: bin2hex('Kev');  
+        // *     returns 1: '4b6576'  
+        // *     example 2: bin2hex(String.fromCharCode(0x00));  
+        // *     returns 2: '00'  
+        var v,i, f = 0, a = [];  
+        s += '';  
+        f = s.length;  
+          
+        for (i = 0; i<f; i++) {  
+            a[i] = s.charCodeAt(i).toString(16).replace(/^([\da-f])$/,"0$1");  
+        }  
+          
+        return a.join('');  
+    }  
+
+       function groupChangeMember(gid, cid, sec_token) {
+               $('body .fakelink').css('cursor', 'wait');
+               $.get('group/' + gid + '/' + cid + "?t=" + sec_token, function(data) {
+                               $('#group-update-wrapper').html(data);
+                               $('body .fakelink').css('cursor', 'auto');                              
+               });
+       }
+
+       function profChangeMember(gid,cid) {
+               $('body .fakelink').css('cursor', 'wait');
+               $.get('profperm/' + gid + '/' + cid, function(data) {
+                               $('#prof-update-wrapper').html(data);
+                               $('body .fakelink').css('cursor', 'auto');                              
+               });
+       }
+
+       function contactgroupChangeMember(gid,cid) {
+               $('body').css('cursor', 'wait');
+               $.get('contactgroup/' + gid + '/' + cid, function(data) {
+                               $('body').css('cursor', 'auto');
+               });
+       }
+
+
+function checkboxhighlight(box) {
+  if($(box).is(':checked')) {
+       $(box).addClass('checkeditem');
+  }
+  else {
+       $(box).removeClass('checkeditem');
+  }
+}
+
+function notifyMarkAll() {
+       $.get('notify/mark/all', function(data) {
+               if(timer) clearTimeout(timer);
+               timer = setTimeout(NavUpdate,1000);
+       });
+}
+
+
+// code from http://www.tinymce.com/wiki.php/How-to_implement_a_custom_file_browser
+function fcFileBrowser (field_name, url, type, win) {
+    /* TODO: If you work with sessions in PHP and your client doesn't accept cookies you might need to carry
+       the session name and session ID in the request string (can look like this: "?PHPSESSID=88p0n70s9dsknra96qhuk6etm5").
+       These lines of code extract the necessary parameters and add them back to the filebrowser URL again. */
+
+
+    var cmsURL = baseurl+"/fbrowser/"+type+"/";
+
+    tinyMCE.activeEditor.windowManager.open({
+        file : cmsURL,
+        title : 'File Browser',
+        width : 420,  // Your dimensions may differ - toy around with them!
+        height : 400,
+        resizable : "yes",
+        inline : "yes",  // This parameter only has an effect if you use the inlinepopups plugin!
+        close_previous : "no"
+    }, {
+        window : win,
+        input : field_name
+    });
+    return false;
+  }
+
+function setupFieldRichtext(){
+       tinyMCE.init({
+               theme : "advanced",
+               mode : "specific_textareas",
+               editor_selector: "fieldRichtext",
+               plugins : "bbcode,paste, inlinepopups",
+               theme_advanced_buttons1 : "bold,italic,underline,undo,redo,link,unlink,image,forecolor,formatselect,code",
+               theme_advanced_buttons2 : "",
+               theme_advanced_buttons3 : "",
+               theme_advanced_toolbar_location : "top",
+               theme_advanced_toolbar_align : "center",
+               theme_advanced_blockformats : "blockquote,code",
+               paste_text_sticky : true,
+               entity_encoding : "raw",
+               add_unload_trigger : false,
+               remove_linebreaks : false,
+               force_p_newlines : false,
+               force_br_newlines : true,
+               forced_root_block : '',
+               convert_urls: false,
+               content_css: baseurl+"/view/custom_tinymce.css",
+               theme_advanced_path : false,
+               file_browser_callback : "fcFileBrowser",
+       });
+}
+
+
+/** 
+ * sprintf in javascript 
+ *     "{0} and {1}".format('zero','uno'); 
+ **/
+String.prototype.format = function() {
+    var formatted = this;
+    for (var i = 0; i < arguments.length; i++) {
+        var regexp = new RegExp('\\{'+i+'\\}', 'gi');
+        formatted = formatted.replace(regexp, arguments[i]);
+    }
+    return formatted;
+};
+// Array Remove
+Array.prototype.remove = function(item) {
+  to=undefined; from=this.indexOf(item);
+  var rest = this.slice((to || from) + 1 || this.length);
+  this.length = from < 0 ? this.length + from : from;
+  return this.push.apply(this, rest);
+};
+
+function previewTheme(elm) {
+       theme = $(elm).val();
+       $.getJSON('pretheme?f=&theme=' + theme,function(data) {
+                       $('#theme-preview').html('<div id="theme-desc">' + data.desc + '</div><div id="theme-version">' + data.version + '</div><div id="theme-credits">' + data.credits + '</div><a href="' + data.img + '"><img src="' + data.img + '" width="320" height="240" alt="' + theme + '" /></a>');
+       });
+
+}
diff --git a/view/theme/frost-mobile/js/theme.js b/view/theme/frost-mobile/js/theme.js
new file mode 100644 (file)
index 0000000..d3298d3
--- /dev/null
@@ -0,0 +1,224 @@
+$(document).ready(function() {
+
+/*$('html').click(function() { $("#nav-notifications-menu" ).hide(); });*/
+
+       $('.group-edit-icon').hover(
+               function() {
+                       $(this).addClass('icon'); $(this).removeClass('iconspacer');},
+               function() {
+                       $(this).removeClass('icon'); $(this).addClass('iconspacer');}
+       );
+
+       $('.sidebar-group-element').hover(
+               function() {
+                       id = $(this).attr('id');
+                       $('#edit-' + id).addClass('icon'); $('#edit-' + id).removeClass('iconspacer');},
+
+               function() {
+                       id = $(this).attr('id');
+                       $('#edit-' + id).removeClass('icon');$('#edit-' + id).addClass('iconspacer');}
+       );
+
+
+       $('.savedsearchdrop').hover(
+               function() {
+                       $(this).addClass('drop'); $(this).addClass('icon'); $(this).removeClass('iconspacer');},
+               function() {
+                       $(this).removeClass('drop'); $(this).removeClass('icon'); $(this).addClass('iconspacer');}
+       );
+
+       $('.savedsearchterm').hover(
+               function() {
+                       id = $(this).attr('id');
+                       $('#drop-' + id).addClass('icon');      $('#drop-' + id).addClass('drophide'); $('#drop-' + id).removeClass('iconspacer');},
+
+               function() {
+                       id = $(this).attr('id');
+                       $('#drop-' + id).removeClass('icon');$('#drop-' + id).removeClass('drophide'); $('#drop-' + id).addClass('iconspacer');}
+       );
+
+       $(".popupbox").click(function () {
+               var parent = $( $(this).attr('href') ).parent();
+               if (parent.css('display') == 'none') {
+                       parent.show();
+               } else {
+                       parent.hide();
+               }
+               return false;
+       });
+
+});
+
+
+function insertFormatting(comment,BBcode,id) {
+       
+               var tmpStr = $("#comment-edit-text-" + id).val();
+               if(tmpStr == comment) {
+                       tmpStr = "";
+                       $("#comment-edit-text-" + id).addClass("comment-edit-text-full");
+                       $("#comment-edit-text-" + id).removeClass("comment-edit-text-empty");
+                       openMenu("comment-edit-submit-wrapper-" + id);
+                       $("#comment-edit-text-" + id).val(tmpStr);
+               }
+
+       textarea = document.getElementById("comment-edit-text-" +id);
+       if (document.selection) {
+               textarea.focus();
+               selected = document.selection.createRange();
+               if (BBcode == "url"){
+                       selected.text = "["+BBcode+"]" + "http://" +  selected.text + "[/"+BBcode+"]";
+                       } else                  
+               selected.text = "["+BBcode+"]" + selected.text + "[/"+BBcode+"]";
+       } else if (textarea.selectionStart || textarea.selectionStart == "0") {
+               var start = textarea.selectionStart;
+               var end = textarea.selectionEnd;
+               if (BBcode == "url"){
+                       textarea.value = textarea.value.substring(0, start) + "["+BBcode+"]" + "http://" + textarea.value.substring(start, end) + "[/"+BBcode+"]" + textarea.value.substring(end, textarea.value.length);
+                       } else
+               textarea.value = textarea.value.substring(0, start) + "["+BBcode+"]" + textarea.value.substring(start, end) + "[/"+BBcode+"]" + textarea.value.substring(end, textarea.value.length);
+       }
+       return true;
+}
+
+function cmtBbOpen(id) {
+       $(".comment-edit-bb-" + id).show();
+}
+function cmtBbClose(id) {
+       $(".comment-edit-bb-" + id).hide();
+}
+
+
+
+
+// TinyMCE stuff
+// Needs to be in "jot-header.tpl" if the "$editselect" variable is used
+
+var editor=false;
+var textlen = 0;
+var plaintext = 'none';//'$editselect';
+
+function initEditor(cb){
+       if (editor==false){
+//             $("#profile-jot-text-loading").show();
+               if(plaintext == 'none') {
+//                     $("#profile-jot-text-loading").hide();
+                       $("#profile-jot-text").css({ 'height': 200, 'color': '#000' });
+                       $("#profile-jot-text").contact_autocomplete(baseurl+"/acl");
+                       editor = true;
+/*                     $("a#jot-perms-icon").fancybox({
+                               'transitionIn' : 'none',
+                               'transitionOut' : 'none'
+                       });*/
+                       $("a#jot-perms-icon, a#settings-default-perms-menu").click(function () {
+                               var parent = $("#profile-jot-acl-wrapper").parent();
+                               if (parent.css('display') == 'none') {
+                                       parent.show();
+                               } else {
+                                       parent.hide();
+                               }
+//                             $("#profile-jot-acl-wrapper").parent().toggle();
+                               return false;
+                       });
+                       $(".jothidden").show();
+                       if (typeof cb!="undefined") cb();
+                       return;
+               }       
+/*             tinyMCE.init({
+                       theme : "advanced",
+                       mode : "specific_textareas",
+                       editor_selector: $editselect,
+                       auto_focus: "profile-jot-text",
+                       plugins : "bbcode,paste,autoresize, inlinepopups",
+                       theme_advanced_buttons1 : "bold,italic,underline,undo,redo,link,unlink,image,forecolor,formatselect,code",
+                       theme_advanced_buttons2 : "",
+                       theme_advanced_buttons3 : "",
+                       theme_advanced_toolbar_location : "top",
+                       theme_advanced_toolbar_align : "center",
+                       theme_advanced_blockformats : "blockquote,code",
+                       gecko_spellcheck : true,
+                       paste_text_sticky : true,
+                       entity_encoding : "raw",
+                       add_unload_trigger : false,
+                       remove_linebreaks : false,
+                       force_p_newlines : false,
+                       force_br_newlines : true,
+                       forced_root_block : '',
+                       convert_urls: false,
+                       content_css: "$baseurl/view/custom_tinymce.css",
+                       theme_advanced_path : false,
+                       file_browser_callback : "fcFileBrowser",
+                       setup : function(ed) {
+                               cPopup = null;
+                               ed.onKeyDown.add(function(ed,e) {
+                                       if(cPopup !== null)
+                                               cPopup.onkey(e);
+                               });
+
+                               ed.onKeyUp.add(function(ed, e) {
+                                       var txt = tinyMCE.activeEditor.getContent();
+                                       match = txt.match(/@([^ \n]+)$/);
+                                       if(match!==null) {
+                                               if(cPopup === null) {
+                                                       cPopup = new ACPopup(this,baseurl+"/acl");
+                                               }
+                                               if(cPopup.ready && match[1]!==cPopup.searchText) cPopup.search(match[1]);
+                                               if(! cPopup.ready) cPopup = null;
+                                       }
+                                       else {
+                                               if(cPopup !== null) { cPopup.close(); cPopup = null; }
+                                       }
+
+                                       textlen = txt.length;
+                                       if(textlen != 0 && $('#jot-perms-icon').is('.unlock')) {
+                                               $('#profile-jot-desc').html(ispublic);
+                                       }
+                                       else {
+                                               $('#profile-jot-desc').html('&nbsp;');
+                                       }        
+
+                                //Character count
+
+                                       if(textlen <= 140) {
+                                               $('#character-counter').removeClass('red');
+                                               $('#character-counter').removeClass('orange');
+                                               $('#character-counter').addClass('grey');
+                                       }
+                                       if((textlen > 140) && (textlen <= 420)) {
+                                               $('#character-counter').removeClass('grey');
+                                               $('#character-counter').removeClass('red');
+                                               $('#character-counter').addClass('orange');
+                                       }
+                                       if(textlen > 420) {
+                                               $('#character-counter').removeClass('grey');
+                                               $('#character-counter').removeClass('orange');
+                                               $('#character-counter').addClass('red');
+                                       }
+                                       $('#character-counter').text(textlen);
+                               });
+
+                               ed.onInit.add(function(ed) {
+                                       ed.pasteAsPlainText = true;
+                                       $("#profile-jot-text-loading").hide();
+                                       $(".jothidden").show();
+                                       if (typeof cb!="undefined") cb();
+                               });
+
+                       }
+               });
+               editor = true;
+               // setup acl popup
+               $("a#jot-perms-icon").fancybox({
+                       'transitionIn' : 'elastic',
+                       'transitionOut' : 'elastic'
+               }); */
+       } else {
+               if (typeof cb!="undefined") cb();
+       }
+}
+
+function enableOnUser(){
+       if (editor) return;
+       $(this).val("");
+       initEditor();
+}
+
diff --git a/view/theme/frost-mobile/js/theme.js.old b/view/theme/frost-mobile/js/theme.js.old
new file mode 100644 (file)
index 0000000..03ee676
--- /dev/null
@@ -0,0 +1,121 @@
+$(document).ready(function() {
+
+    $.ajaxSetup({ 
+        cache: false 
+    });
+
+
+       $('.system-menu-link').click(function() {
+               handleNavMenu('#system-menu-list');
+               return false;
+       });
+
+       $('.contacts-menu-link').click(function() {
+               handleNavMenu('#contacts-menu-list');
+               return false;
+       });
+
+       $('.network-menu-link').click(function() {
+               handleNavMenu('#network-menu-list');
+               return false;
+       });
+
+/*     $('.nav-load-page-link').click(function() {
+               getPageContent( $(this).attr('href') );
+               hideNavMenu( '#' + $(this).closest('ul').attr('id') );
+               return false;
+       });*/
+
+/*     $('#nav-network-link').click(function() {
+               getPageContent('/network', '#network-menu-list');
+               return false;
+       });
+
+       $('#nav-home-link').click(function() {
+
+               var username = $('#site-location').text();
+               username = username.substring(0, username.indexOf('@'));
+
+               getPageContent('/profile/' + username, '#network-menu-list');
+
+               return false;
+       });
+
+       $('#nav-community-link').click(function() {
+               getPageContent('/community', '#network-menu-list');
+               return false;
+       });
+
+       $('#nav-messages-link').click(function() {
+               getPageContent('/message');
+               return false;
+       });
+
+       $('#nav-contacts-link').click(function() {
+               getPageContent('/contacts', '#contacts-menu-list');
+               return false;
+       });*/
+
+});
+
+$(document).mouseup(function (clickPos) {
+
+       var sysMenu = $("#system-menu-list");
+       var sysMenuLink = $(".system-menu-link");
+       var contactsMenu = $("#contacts-menu-list");
+       var contactsMenuLink = $(".contacts-menu-link");
+       var networkMenu = $("#network-menu-list");
+       var networkMenuLink = $(".network-menu-link");
+
+       if( !sysMenu.is(clickPos.target) && !sysMenuLink.is(clickPos.target) && sysMenu.has(clickPos.target).length === 0) {
+               hideNavMenu("#system-menu-list");
+       }
+       if( !contactsMenu.is(clickPos.target) && !contactsMenuLink.is(clickPos.target) && contactsMenu.has(clickPos.target).length === 0) {
+               hideNavMenu("#contacts-menu-list");
+       }
+       if( !networkMenu.is(clickPos.target) && !networkMenuLink.is(clickPos.target) && networkMenu.has(clickPos.target).length === 0) {
+               hideNavMenu("#network-menu-list");
+       }
+});
+
+
+function getPageContent(url) {
+
+       var pos = $('.main-container').position();
+
+       $('.main-container').css('margin-left', pos.left);      
+       $('.main-content-container').hide(0, function () {
+               $('.main-content-loading').show(0);
+       });
+
+       $.get(url, function(html) {
+               console.log($('.main-content-container').html());
+               $('.main-content-container').html( $('.main-content-container', html).html() );
+               console.log($('.main-content-container').html());
+               $('.main-content-loading').hide(function() {
+                       $('.main-content-container').fadeIn(800,function() {
+                               $('.main-container').css('margin-left', 'auto'); // This sucks -- if the CSS specification changes, this will be wrong
+                       });
+               });
+       });
+}
+
+function handleNavMenu(menuID) {
+       if( $(menuID).hasClass('menu-visible') ) {
+               hideNavMenu(menuID);
+       }
+       else {
+               showNavMenu(menuID);
+       }
+}
+
+function showNavMenu(menuID) {
+       $(menuID).show();
+       $(menuID).addClass('menu-visible');
+}
+
+function hideNavMenu(menuID) {
+       $(menuID).hide();
+       $(menuID).removeClass('menu-visible');
+}
+
diff --git a/view/theme/frost-mobile/lang_selector.tpl b/view/theme/frost-mobile/lang_selector.tpl
new file mode 100644 (file)
index 0000000..e777a0a
--- /dev/null
@@ -0,0 +1,10 @@
+<div id="lang-select-icon" class="icon s22 language" title="$title" onclick="openClose('language-selector');" ></div>
+<div id="language-selector" style="display: none;" >
+       <form action="#" method="post" >
+               <select name="system_language" onchange="this.form.submit();" >
+                       {{ for $langs.0 as $v=>$l }}
+                               <option value="$v" {{if $v==$langs.1}}selected="selected"{{endif}}>$l</option>
+                       {{ endfor }}
+               </select>
+       </form>
+</div>
diff --git a/view/theme/frost-mobile/lock.cur b/view/theme/frost-mobile/lock.cur
new file mode 100644 (file)
index 0000000..892c5e8
Binary files /dev/null and b/view/theme/frost-mobile/lock.cur differ
diff --git a/view/theme/frost-mobile/login-bg.gif b/view/theme/frost-mobile/login-bg.gif
new file mode 100644 (file)
index 0000000..cde836c
Binary files /dev/null and b/view/theme/frost-mobile/login-bg.gif differ
diff --git a/view/theme/frost-mobile/login-style.css b/view/theme/frost-mobile/login-style.css
new file mode 100644 (file)
index 0000000..5283c58
--- /dev/null
@@ -0,0 +1,131 @@
+html {
+       width: 100%;
+}
+
+body {
+       font-family: helvetica,arial,freesans,clean,sans-serif;
+       font-size: 16px;
+       background-color: #ffffff;
+       color: #505050;/* ZP Change*/
+       margin: 0px;
+}
+
+a, a:visited, a:link { color: #3465a4; text-decoration: none; }
+a:hover {text-decoration: underline; }
+
+img { border :0px; }
+
+.login-button {
+       margin-top: 90px;
+       margin-left: auto;
+       margin-right: auto;
+       
+}
+
+img.login-button-image {
+       max-width: 300px;
+}
+
+.section-wrapper {
+       position: relative;
+       width: 300px;
+       margin-left: auto;
+       margin-right: auto;
+}
+
+.login-form {
+       margin-top: 40px;
+}
+
+.field {
+       position: relative;
+       margin-bottom: 15px;
+}
+
+.field label {
+       margin-left: 25px;
+       font-weight: 700;
+}
+
+.field input {
+       font-size: 18px;
+       width: 200px;
+       margin-left: 50px;
+}
+
+#login_openid {
+       margin-top: 50px;
+}
+
+#login_openid input {
+       background: url(login-bg.gif) no-repeat;
+       background-position: 0 50%;
+       width: 182px;
+       padding-left: 18px;
+}
+
+#login-footer {
+       margin-top: 10px;
+       text-align: center;
+}
+
+.login-extra-links, .agreement {
+       font-size: 14px;
+}
+
+#login-submit-button, #register-submit-button, #lostpass-submit-button {
+       font-size: 20px;
+       padding: 0.5em 1em;
+}
+
+#register-link {
+       margin-right: 100px;
+}
+
+.register-form {
+       margin-top: 15px;
+}
+
+.register-form h2, .lostpass-form h2 {
+       text-align: center;
+}
+
+.error-message {
+       width: 270px;
+       color: #FF0000;
+       font-size: 1.1em;
+       text-align: justify;
+       border: 1px solid #FF8888;
+       background-color: #FFEEEE;
+       padding: 10px;
+       margin-left: auto;
+       margin-right: auto;
+}
+
+.register-explain-wrapper {
+       width: 290px;
+       text-align: justify;
+       font-size: 14px;
+       margin-left: 5px;
+}
+
+#register-footer {
+       margin-top: 60px;
+       text-align: center;
+}
+
+.lostpass-form {
+       margin-top: 100px;
+}
+
+#lostpass-desc {
+       width: 290px;
+       margin-left: 5px;
+       margin-bottom: 30px;
+       text-align: justify;
+       font-size: 14px;
+}
+
+#login-submit-wrapper {
+       text-align: center;
+}
diff --git a/view/theme/frost-mobile/login.tpl b/view/theme/frost-mobile/login.tpl
new file mode 100644 (file)
index 0000000..39bb578
--- /dev/null
@@ -0,0 +1,43 @@
+
+<div class="login-form">
+<form action="$dest_url" method="post" >
+       <input type="hidden" name="auth-params" value="login" />
+
+       <div id="login_standard">
+       {{ inc field_input.tpl with $field=$lname }}{{ endinc }}
+       {{ inc field_password.tpl with $field=$lpassword }}{{ endinc }}
+       </div>
+       
+       {{ if $openid }}
+                       <div id="login_openid">
+                       {{ inc field_openid.tpl with $field=$lopenid }}{{ endinc }}
+                       </div>
+       {{ endif }}
+
+       <br />
+       <div id='login-footer'>
+       <div class="login-extra-links">
+       By signing in you agree to the latest <a href="tos.html" title="$tostitle" id="terms-of-service-link" >$toslink</a> and <a href="privacy.html" title="$privacytitle" id="privacy-link" >$privacylink</a>
+       </div>
+
+       <br />
+       <div id="login-submit-wrapper" >
+               <input type="submit" name="submit" id="login-submit-button" value="$login" />
+       </div>
+
+       <br /><br />
+       <div class="login-extra-links">
+               {{ if $register }}<a href="register" title="$register.title" id="register-link">$register.desc</a>{{ endif }}
+        <a href="lostpass" title="$lostpass" id="lost-password-link" >$lostlink</a>
+       </div>
+       </div>
+       
+       {{ for $hiddens as $k=>$v }}
+               <input type="hidden" name="$k" value="$v" />
+       {{ endfor }}
+       
+       
+</form>
+</div>
+
+<script type="text/javascript"> $(document).ready(function() { $("#id_$lname.0").focus();} );</script>
diff --git a/view/theme/frost-mobile/lostpass.tpl b/view/theme/frost-mobile/lostpass.tpl
new file mode 100644 (file)
index 0000000..583e3db
--- /dev/null
@@ -0,0 +1,21 @@
+<div class="lostpass-form">
+<h2>$title</h2>
+<br /><br /><br />
+
+<form action="lostpass" method="post" >
+<div id="login-name-wrapper" class="field input">
+        <label for="login-name" id="label-login-name">$name</label><br />
+        <input type="text" maxlength="60" name="login-name" id="login-name" value="" />
+</div>
+<div id="login-extra-end"></div>
+<p id="lostpass-desc">
+$desc
+</p>
+<br />
+
+<div id="login-submit-wrapper" >
+        <input type="submit" name="submit" id="lostpass-submit-button" value="$submit" />
+</div>
+<div id="login-submit-end"></div>
+</form>
+</div>
diff --git a/view/theme/frost-mobile/moderated_comment.tpl b/view/theme/frost-mobile/moderated_comment.tpl
new file mode 100755 (executable)
index 0000000..b0451c8
--- /dev/null
@@ -0,0 +1,61 @@
+               <div class="comment-wwedit-wrapper" id="comment-edit-wrapper-$id" style="display: block;">
+                       <form class="comment-edit-form" id="comment-edit-form-$id" action="item" method="post" onsubmit="post_comment($id); return false;">
+                               <input type="hidden" name="type" value="$type" />
+                               <input type="hidden" name="profile_uid" value="$profile_uid" />
+                               <input type="hidden" name="parent" value="$parent" />
+                               <input type="hidden" name="return" value="$return_path" />
+                               <input type="hidden" name="jsreload" value="$jsreload" />
+                               <input type="hidden" name="preview" id="comment-preview-inp-$id" value="0" />
+
+                               <div class="comment-edit-photo" id="comment-edit-photo-$id" >
+                                       <a class="comment-edit-photo-link" href="$mylink" title="$mytitle"><img class="my-comment-photo" src="$myphoto" alt="$mytitle" title="$mytitle" /></a>
+                               </div>
+                               <div class="comment-edit-photo-end"></div>
+                               <div id="mod-cmnt-wrap-$id" class="mod-cmnt-wrap" style="display:none">
+                                       <div id="mod-cmnt-name-lbl-$id" class="mod-cmnt-name-lbl">$lbl_modname</div>
+                                       <input type="text" id="mod-cmnt-name-$id" class="mod-cmnt-name" name="mod-cmnt-name" value="$modname" />
+                                       <div id="mod-cmnt-email-lbl-$id" class="mod-cmnt-email-lbl">$lbl_modemail</div>
+                                       <input type="text" id="mod-cmnt-email-$id" class="mod-cmnt-email" name="mod-cmnt-email" value="$modemail" />
+                                       <div id="mod-cmnt-url-lbl-$id" class="mod-cmnt-url-lbl">$lbl_modurl</div>
+                                       <input type="text" id="mod-cmnt-url-$id" class="mod-cmnt-url" name="mod-cmnt-url" value="$modurl" />
+                               </div>
+                               <ul class="comment-edit-bb-$id">
+                                       <li><a class="editicon boldbb shadow"
+                                               style="cursor: pointer;" title="$edbold"
+                                               onclick="insertFormatting('$comment','b', $id);"></a></li>
+                                       <li><a class="editicon italicbb shadow"
+                                               style="cursor: pointer;" title="$editalic"
+                                               onclick="insertFormatting('$comment','i', $id);"></a></li>
+                                       <li><a class="editicon underlinebb shadow"
+                                               style="cursor: pointer;" title="$eduline"
+                                               onclick="insertFormatting('$comment','u', $id);"></a></li>
+                                       <li><a class="editicon quotebb shadow"
+                                               style="cursor: pointer;" title="$edquote"
+                                               onclick="insertFormatting('$comment','quote', $id);"></a></li>
+                                       <li><a class="editicon codebb shadow"
+                                               style="cursor: pointer;" title="$edcode"
+                                               onclick="insertFormatting('$comment','code', $id);"></a></li>
+                                       <li><a class="editicon imagebb shadow"
+                                               style="cursor: pointer;" title="$edimg"
+                                               onclick="insertFormatting('$comment','img', $id);"></a></li>
+                                       <li><a class="editicon urlbb shadow"
+                                               style="cursor: pointer;" title="$edurl"
+                                               onclick="insertFormatting('$comment','url', $id);"></a></li>
+                                       <li><a class="editicon videobb shadow"
+                                               style="cursor: pointer;" title="$edvideo"
+                                               onclick="insertFormatting('$comment','video', $id);"></a></li>
+                               </ul>   
+                               <div class="comment-edit-bb-end"></div>
+                               <textarea id="comment-edit-text-$id" class="comment-edit-text-empty" name="body" onFocus="commentOpen(this,$id);cmtBbOpen($id);" onBlur="commentClose(this,$id);" >$comment</textarea>                  
+
+                               <div class="comment-edit-text-end"></div>
+                               <div class="comment-edit-submit-wrapper" id="comment-edit-submit-wrapper-$id" style="display: none;" >
+                                       <input type="submit" onclick="post_comment($id); return false;" id="comment-edit-submit-$id" class="comment-edit-submit" name="submit" value="$submit" />
+                                       <span onclick="preview_comment($id);" id="comment-edit-preview-link-$id" class="fakelink">$preview</span>
+                                       <div id="comment-edit-preview-$id" class="comment-edit-preview" style="display:none;"></div>
+                               </div>
+
+                               <div class="comment-edit-end"></div>
+                       </form>
+
+               </div>
diff --git a/view/theme/frost-mobile/msg-header.tpl b/view/theme/frost-mobile/msg-header.tpl
new file mode 100644 (file)
index 0000000..003c869
--- /dev/null
@@ -0,0 +1,97 @@
+
+<script language="javascript" type="text/javascript" src="$baseurl/library/tinymce/jscripts/tiny_mce/tiny_mce_src.js"></script>
+<script language="javascript" type="text/javascript">
+/*
+var plaintext = '$editselect';
+
+if(plaintext != 'none') {
+       tinyMCE.init({
+               theme : "advanced",
+               mode : "specific_textareas",
+               editor_selector: /(profile-jot-text|prvmail-text)/,
+               plugins : "bbcode,paste",
+               theme_advanced_buttons1 : "bold,italic,underline,undo,redo,link,unlink,image,forecolor",
+               theme_advanced_buttons2 : "",
+               theme_advanced_buttons3 : "",
+               theme_advanced_toolbar_location : "top",
+               theme_advanced_toolbar_align : "center",
+               theme_advanced_blockformats : "blockquote,code",
+               gecko_spellcheck : true,
+               paste_text_sticky : true,
+               entity_encoding : "raw",
+               add_unload_trigger : false,
+               remove_linebreaks : false,
+               force_p_newlines : false,
+               force_br_newlines : true,
+               forced_root_block : '',
+               convert_urls: false,
+               content_css: "$baseurl/view/custom_tinymce.css",
+                    //Character count
+               theme_advanced_path : false,
+               setup : function(ed) {
+                       ed.onInit.add(function(ed) {
+                               ed.pasteAsPlainText = true;
+                               var editorId = ed.editorId;
+                               var textarea = $('#'+editorId);
+                               if (typeof(textarea.attr('tabindex')) != "undefined") {
+                                       $('#'+editorId+'_ifr').attr('tabindex', textarea.attr('tabindex'));
+                                       textarea.attr('tabindex', null);
+                               }
+                       });
+               }
+       });
+}
+else*/
+       $("#prvmail-text").contact_autocomplete(baseurl+"/acl");
+
+
+</script>
+<script type="text/javascript" src="js/ajaxupload.js" ></script>
+<script>
+       $(document).ready(function() {
+               var uploader = new window.AjaxUpload(
+                       'prvmail-upload',
+                       { action: 'wall_upload/$nickname',
+                               name: 'userfile',
+                               onSubmit: function(file,ext) { $('#profile-rotator').show(); },
+                               onComplete: function(file,response) {
+                                       tinyMCE.execCommand('mceInsertRawHTML',false,response);
+                                       $('#profile-rotator').hide();
+                               }                                
+                       }
+               );
+
+       });
+
+       function jotGetLink() {
+               reply = prompt("$linkurl");
+               if(reply && reply.length) {
+                       $('#profile-rotator').show();
+                       $.get('parse_url?url=' + reply, function(data) {
+                               tinyMCE.execCommand('mceInsertRawHTML',false,data);
+                               $('#profile-rotator').hide();
+                       });
+               }
+       }
+
+       function linkdropper(event) {
+               var linkFound = event.dataTransfer.types.contains("text/uri-list");
+               if(linkFound)
+                       event.preventDefault();
+       }
+
+       function linkdrop(event) {
+               var reply = event.dataTransfer.getData("text/uri-list");
+               event.target.textContent = reply;
+               event.preventDefault();
+               if(reply && reply.length) {
+                       $('#profile-rotator').show();
+                       $.get('parse_url?url=' + reply, function(data) {
+                               tinyMCE.execCommand('mceInsertRawHTML',false,data);
+                               $('#profile-rotator').hide();
+                       });
+               }
+       }
+
+</script>
+
diff --git a/view/theme/frost-mobile/nav.tpl b/view/theme/frost-mobile/nav.tpl
new file mode 100644 (file)
index 0000000..8b5fd89
--- /dev/null
@@ -0,0 +1,131 @@
+<nav>
+<!--   $langselector -->
+
+<!--   <div id="site-location">$sitelocation</div> -->
+
+       {{ if $nav.login }}<a id="nav-login-link" class="nav-login-link $nav.login.2" href="$nav.login.0" title="$nav.login.3" >$nav.login.1</a> {{ endif }}
+
+       <span id="nav-link-wrapper" >
+
+<!--   <a id="system-menu-link" class="nav-link" href="#system-menu" title="Menu">Menu</a>-->
+       <div class="nav-button-container">
+<!--   <a class="system-menu-link nav-link" href="#system-menu" title="Menu">-->
+       <img rel="#system-menu-list" class="nav-link" src="/view/theme/frost-mobile/images/menu.png">
+<!--   </a>-->
+       <ul id="system-menu-list" class="nav-menu-list">
+               {{ if $nav.settings }}
+               <li><a id="nav-settings-link" class="$nav.settings.2 nav-load-page-link" href="$nav.settings.0" title="$nav.settings.3">$nav.settings.1</a></li>
+               {{ endif }}
+
+               {{ if $nav.profiles }}
+               <li><a id="nav-profiles-link" class="$nav.profiles.2 nav-load-page-link" href="$nav.profiles.0" title="$nav.profiles.3" >$nav.profiles.1</a></li>
+               {{ endif }}
+
+               {{ if $nav.admin }}
+               <li><a id="nav-admin-link" class="$nav.admin.2 nav-load-page-link" href="$nav.admin.0" title="$nav.admin.3" >$nav.admin.1</a></li>
+               {{ endif }}
+
+               <li><a id="nav-search-link" class="$nav.search.2 nav-load-page-link" href="$nav.search.0" title="$nav.search.3" >$nav.search.1</a></li>
+
+               {{ if $nav.apps }}
+               <li><a id="nav-apps-link" class="$nav.apps.2 nav-load-page-link" href="$nav.apps.0" title="$nav.apps.3" >$nav.apps.1</a></li>
+               {{ endif }}
+
+               {{ if $nav.help }}
+               <li><a id="nav-help-link" class="$nav.help.2 nav-load-page-link" target="friendika-help" href="$nav.help.0" title="$nav.help.3" >$nav.help.1</a></li>
+               {{ endif }}
+               
+               {{ if $nav.logout }}
+               <li><a id="nav-logout-link" class="$nav.logout.2" href="$nav.logout.0" title="$nav.logout.3" >$nav.logout.1</a></li>
+               {{ endif }}
+       </ul>
+       </div>
+
+       {{ if $nav.notifications }}
+<!--   <a id="nav-notifications-linkmenu" class="nav-link" href="$nav.notifications.0" rel="#nav-notifications-menu" title="$nav.notifications.1">$nav.notifications.1</a>-->
+       <div class="nav-button-container">
+<!--   <a id="nav-notifications-linkmenu" class="nav-link" href="$nav.notifications.0" rel="#nav-notifications-menu" title="$nav.notifications.1">-->
+       <img rel="#nav-notifications-menu" class="nav-link" src="/view/theme/frost-mobile/images/notifications.png">
+<!--   </a>-->
+       <span id="notify-update" class="nav-ajax-left"></span>
+       <ul id="nav-notifications-menu" class="notifications-menu-popup">
+               <li id="nav-notifications-see-all"><a href="$nav.notifications.all.0">$nav.notifications.all.1</a></li>
+               <li id="nav-notifications-mark-all"><a href="#" onclick="notifyMarkAll(); return false;">$nav.notifications.mark.1</a></li>
+               <li class="empty">$emptynotifications</li>
+       </ul>
+       </div>
+       {{ endif }}             
+
+<!--   <a id="contacts-menu-link" class="nav-link" href="#contacts-menu" title="Contacts">Contacts</a>-->
+       <div class="nav-button-container">
+<!--   <a class="contacts-menu-link nav-link" href="#contacts-menu" title="Contacts">-->
+       <img rel="#contacts-menu-list"  class="nav-link" src="/view/theme/frost-mobile/images/contacts.png">
+       <!--</a>-->
+       {{ if $nav.introductions }}
+       <span id="intro-update" class="nav-ajax-left"></span>
+       {{ endif }}
+       <ul id="contacts-menu-list" class="nav-menu-list">
+               {{ if $nav.contacts }}
+               <li><a id="nav-contacts-link" class="$nav.contacts.2 nav-load-page-link" href="$nav.contacts.0" title="$nav.contacts.3" >$nav.contacts.1</a><li>
+               {{ endif }}
+
+               <li><a id="nav-directory-link" class="$nav.directory.2 nav-load-page-link" href="$nav.directory.0" title="$nav.directory.3" >$nav.directory.1</a><li>
+
+               {{ if $nav.introductions }}
+               <li>
+               <a id="nav-notify-link" class="$nav.introductions.2 $sel.introductions nav-load-page-link" href="$nav.introductions.0" title="$nav.introductions.3" >$nav.introductions.1</a>
+               </li>
+               {{ endif }}
+       </ul>
+       </div>
+
+       {{ if $nav.messages }}
+<!--   <a id="nav-messages-link" class="nav-link $nav.messages.2 $sel.messages nav-load-page-link" href="$nav.messages.0" title="$nav.messages.3" >$nav.messages.1</a>-->
+       <div class="nav-button-container">
+       <a id="nav-messages-link" class="$nav.messages.2 $sel.messages nav-load-page-link" href="$nav.messages.0" title="$nav.messages.3" >
+       <img src="/view/theme/frost-mobile/images/message.png" class="nav-link">
+       </a>
+       <span id="mail-update" class="nav-ajax-left"></span>
+       </div>
+       {{ endif }}
+
+<!--   <a id="network-menu-link" class="nav-link" href="#network-menu" title="Network">Network</a>-->
+       <div class="nav-button-container">
+<!--   <a class="network-menu-link nav-link" href="#network-menu" title="Network">-->
+       <img rel="#network-menu-list" class="nav-link" src="/view/theme/frost-mobile/images/network.png">
+<!--   </a>-->
+       {{ if $nav.network }}
+       <span id="net-update" class="nav-ajax-left"></span>
+       {{ endif }}
+       <ul id="network-menu-list" class="nav-menu-list">
+               {{ if $nav.network }}
+               <li>
+               <a id="nav-network-link" class="$nav.network.2 $sel.network nav-load-page-link" href="$nav.network.0" title="$nav.network.3" >$nav.network.1</a>
+               </li>
+               <!--<span id="net-update" class="nav-ajax-left"></span>-->
+               {{ endif }}
+
+               {{ if $nav.home }}
+               <li><a id="nav-home-link" class="$nav.home.2 $sel.home nav-load-page-link" href="$nav.home.0" title="$nav.home.3" >$nav.home.1</a></li>
+               <!--<span id="home-update" class="nav-ajax-left"></span>-->
+               {{ endif }}
+
+               {{ if $nav.community }}
+               <li>
+               <a id="nav-community-link" class="$nav.community.2 $sel.community nav-load-page-link" href="$nav.community.0" title="$nav.community.3" >$nav.community.1</a>
+               </li>
+               {{ endif }}
+       </ul>
+       </div>
+
+       {{ if $nav.register }}<a id="nav-register-link" class="nav-commlink $nav.register.2 $sel.register" href="$nav.register.0" title="$nav.register.3" >$nav.register.1</a>{{ endif }}
+               
+       {{ if $nav.manage }}<a id="nav-manage-link" class="nav-link $nav.manage.2 $sel.manage" href="$nav.manage.0" title="$nav.manage.3">$nav.manage.1</a>{{ endif }}
+       </span>
+       <span id="nav-end"></span>
+       <span id="banner">$banner</span>
+</nav>
+
+<ul id="nav-notifications-template" style="display:none;" rel="template">
+       <li class="{4}"><a href="{0}"><img src="{1}" height="24" width="24" alt="" />{2} <span class="notif-when">{3}</span></a></li>
+</ul>
diff --git a/view/theme/frost-mobile/photo_edit.tpl b/view/theme/frost-mobile/photo_edit.tpl
new file mode 100644 (file)
index 0000000..5631b2e
--- /dev/null
@@ -0,0 +1,53 @@
+
+<form action="photos/$nickname/$resource_id" method="post" id="photo_edit_form" >
+
+       <input type="hidden" name="item_id" value="$item_id" />
+
+       <label id="photo-edit-albumname-label" for="photo-edit-albumname">$newalbum</label>
+       <input id="photo-edit-albumname" type="text" size="32" name="albname" value="$album" />
+
+       <div id="photo-edit-albumname-end"></div>
+
+       <label id="photo-edit-caption-label" for="photo-edit-caption">$capt_label</label>
+       <input id="photo-edit-caption" type="text" size="32" name="desc" value="$caption" />
+
+       <div id="photo-edit-caption-end"></div>
+
+       <label id="photo-edit-tags-label" for="photo-edit-newtag" >$tag_label</label>
+       <input name="newtag" id="photo-edit-newtag" size="32" title="$help_tags" type="text" />
+
+       <div id="photo-edit-tags-end"></div>
+       <div id="photo-edit-rotate-wrapper">
+               <div class="photo-edit-rotate-label">
+                       $rotatecw
+               </div>
+               <input class="photo-edit-rotate" type="radio" name="rotate" value="1" /><br />
+
+               <div class="photo-edit-rotate-label">
+                       $rotateccw
+               </div>
+               <input class="photo-edit-rotate" type="radio" name="rotate" value="2" />
+       </div>
+       <div id="photo-edit-rotate-end"></div>
+
+       <div id="photo-edit-perms" class="photo-edit-perms" >
+               <a href="#photo-edit-perms-select" id="photo-edit-perms-menu" class="popupbox button" title="$permissions"/>
+                       <span id="jot-perms-icon" class="icon $lockstate photo-perms-icon" ></span><div class="photo-jot-perms-text">$permissions</div>
+               </a>
+               <div id="photo-edit-perms-menu-end"></div>
+               
+               <div style="display: none;">
+                       <div id="photo-edit-perms-select" >
+                               $aclselect
+                       </div>
+               </div>
+       </div>
+       <div id="photo-edit-perms-end"></div>
+
+       <input id="photo-edit-submit-button" type="submit" name="submit" value="$submit" />
+       <input id="photo-edit-delete-button" type="submit" name="delete" value="$delete" onclick="return confirmDelete()"; />
+
+       <div id="photo-edit-end"></div>
+</form>
+
+
diff --git a/view/theme/frost-mobile/photo_view.tpl b/view/theme/frost-mobile/photo_view.tpl
new file mode 100644 (file)
index 0000000..92e1154
--- /dev/null
@@ -0,0 +1,42 @@
+<div id="live-display"></div>
+<h3><a href="$album.0">$album.1</a></h3>
+
+<div id="photo-edit-link-wrap">
+{{ if $tools }}
+<a id="photo-edit-link" href="$tools.edit.0">$tools.edit.1</a>
+|
+<a id="photo-toprofile-link" href="$tools.profile.0">$tools.profile.1</a>
+{{ endif }}
+{{ if $lock }} | <img src="images/lock_icon.gif" class="lockview" alt="$lock" onclick="lockview(event,'photo/$id');" /> {{ endif }}
+</div>
+
+<div id="photo-nav">
+       {{ if $prevlink }}<div id="photo-prev-link"><a href="$prevlink.0"><img src="view/theme/frost-mobile/images/arrow-left.png"></a></div>{{ endif }}
+       {{ if $nextlink }}<div id="photo-next-link"><a href="$nextlink.0"><img src="view/theme/frost-mobile/images/arrow-right.png"></a></div>{{ endif }}
+</div>
+<div id="photo-photo"><a href="$photo.href" title="$photo.title"><img src="$photo.src" /></a></div>
+<div id="photo-photo-end"></div>
+<div id="photo-caption">$desc</div>
+{{ if $tags }}
+<div id="in-this-photo-text">$tags.0</div>
+<div id="in-this-photo">$tags.1</div>
+{{ endif }}
+{{ if $tags.2 }}<div id="tag-remove"><a href="$tags.2">$tags.3</a></div>{{ endif }}
+
+{{ if $edit }}
+$edit
+{{ else }}
+
+{{ if $likebuttons }}
+<div id="photo-like-div">
+       $likebuttons
+       $like
+       $dislike        
+</div>
+{{ endif }}
+
+$comments
+
+$paginate
+{{ endif }}
+
diff --git a/view/theme/frost-mobile/photos_upload.tpl b/view/theme/frost-mobile/photos_upload.tpl
new file mode 100644 (file)
index 0000000..4b8bd90
--- /dev/null
@@ -0,0 +1,50 @@
+<h3>$pagename</h3>
+
+<div id="photos-usage-message">$usage</div>
+
+<form action="photos/$nickname" enctype="multipart/form-data" method="post" name="photos-upload-form" id="photos-upload-form" >
+       <div id="photos-upload-new-wrapper" >
+               <div id="photos-upload-newalbum-div">
+                       <label id="photos-upload-newalbum-text" for="photos-upload-newalbum" >$newalbum</label>
+               </div>
+               <input id="photos-upload-newalbum" type="text" name="newalbum" />
+       </div>
+       <div id="photos-upload-new-end"></div>
+       <div id="photos-upload-exist-wrapper">
+               <div id="photos-upload-existing-album-text">$existalbumtext</div>
+               $albumselect
+       </div>
+       <div id="photos-upload-exist-end"></div>
+
+
+       <div id="photos-upload-noshare-div" class="photos-upload-noshare-div" >
+               <input id="photos-upload-noshare" type="checkbox" name="not_visible" value="1" checked />
+               <div id="photos-upload-noshare-label">
+               <label id="photos-upload-noshare-text" for="photos-upload-noshare" >$nosharetext</label>
+               </div>
+       </div>
+
+       <div id="photos-upload-perms" class="photos-upload-perms" >
+               <a href="#photos-upload-permissions-wrapper" id="photos-upload-perms-menu" class="popupbox button" />
+               <span id="jot-perms-icon" class="icon $lockstate  photo-perms-icon" ></span><div class="photo-jot-perms-text">$permissions</div>
+               </a>
+       <div id="photos-upload-perms-end"></div>
+
+       <div style="display: none;">
+               <div id="photos-upload-permissions-wrapper">
+                       $aclselect
+               </div>
+       </div>
+
+       <div id="photos-upload-spacer"></div>
+
+       $uploader
+
+       $default
+
+       <div class="photos-upload-end" ></div>
+</form>
+
+<script>
+       $("#photos-upload-album-select").removeAttr('size');
+</script>
diff --git a/view/theme/frost-mobile/profed_head.tpl b/view/theme/frost-mobile/profed_head.tpl
new file mode 100644 (file)
index 0000000..6ae8585
--- /dev/null
@@ -0,0 +1,36 @@
+<!--<script language="javascript" type="text/javascript"
+          src="$baseurl/library/tinymce/jscripts/tiny_mce/tiny_mce_src.js"></script>
+          <script language="javascript" type="text/javascript">
+
+
+tinyMCE.init({
+       theme : "advanced",
+       mode : "$editselect",
+       plugins : "bbcode,paste",
+       theme_advanced_buttons1 : "bold,italic,underline,undo,redo,link,unlink,image,forecolor,formatselect,code",
+       theme_advanced_buttons2 : "",
+       theme_advanced_buttons3 : "",
+       theme_advanced_toolbar_location : "top",
+       theme_advanced_toolbar_align : "center",
+       theme_advanced_blockformats : "blockquote,code",
+       gecko_spellcheck : true,
+       paste_text_sticky : true,
+       entity_encoding : "raw",
+       add_unload_trigger : false,
+       remove_linebreaks : false,
+       force_p_newlines : false,
+       force_br_newlines : true,
+       forced_root_block : '',
+       content_css: "$baseurl/view/custom_tinymce.css",
+       theme_advanced_path : false,
+       setup : function(ed) {
+               ed.onInit.add(function(ed) {
+            ed.pasteAsPlainText = true;
+        });
+    }
+
+});
+
+
+</script>
+-->
diff --git a/view/theme/frost-mobile/profile_edit.tpl b/view/theme/frost-mobile/profile_edit.tpl
new file mode 100644 (file)
index 0000000..198dddb
--- /dev/null
@@ -0,0 +1,322 @@
+$default
+
+<h1>$banner</h1>
+
+<div id="profile-edit-links">
+<ul>
+<li><a href="profile/$profile_id/view?tab=profile" id="profile-edit-view-link" title="$viewprof">$viewprof</a></li>
+<li><a href="$profile_clone_link" id="profile-edit-clone-link" title="$cr_prof">$cl_prof</a></li>
+<li></li>
+<li><a href="$profile_drop_link" id="profile-edit-drop-link" title="$del_prof" $disabled >$del_prof</a></li>
+
+</ul>
+</div>
+
+<div id="profile-edit-links-end"></div>
+
+
+<div id="profile-edit-wrapper" >
+<form id="profile-edit-form" name="form1" action="profiles/$profile_id" method="post" >
+<input type='hidden' name='form_security_token' value='$form_security_token'>
+
+<div id="profile-edit-profile-name-wrapper" >
+<label id="profile-edit-profile-name-label" for="profile-edit-profile-name" >$lbl_profname </label>
+<input type="text" size="28" name="profile_name" id="profile-edit-profile-name" value="$profile_name" /><div class="required">*</div>
+</div>
+<div id="profile-edit-profile-name-end"></div>
+
+<div id="profile-edit-name-wrapper" >
+<label id="profile-edit-name-label" for="profile-edit-name" >$lbl_fullname </label>
+<input type="text" size="28" name="name" id="profile-edit-name" value="$name" />
+</div>
+<div id="profile-edit-name-end"></div>
+
+<div id="profile-edit-pdesc-wrapper" >
+<label id="profile-edit-pdesc-label" for="profile-edit-pdesc" >$lbl_title </label>
+<input type="text" size="28" name="pdesc" id="profile-edit-pdesc" value="$pdesc" />
+</div>
+<div id="profile-edit-pdesc-end"></div>
+
+
+<div id="profile-edit-gender-wrapper" >
+<label id="profile-edit-gender-label" for="gender-select" >$lbl_gender </label>
+$gender
+</div>
+<div id="profile-edit-gender-end"></div>
+
+<div id="profile-edit-dob-wrapper" >
+<label id="profile-edit-dob-label" for="dob-select" >$lbl_bd </label>
+<div id="profile-edit-dob" >
+$dob $age
+</div>
+</div>
+<div id="profile-edit-dob-end"></div>
+
+$hide_friends
+
+<div class="profile-edit-submit-wrapper" >
+<input type="submit" name="submit" class="profile-edit-submit-button" value="$submit" />
+</div>
+<div class="profile-edit-submit-end"></div>
+
+
+<div id="profile-edit-address-wrapper" >
+<label id="profile-edit-address-label" for="profile-edit-address" >$lbl_address </label>
+<input type="text" size="28" name="address" id="profile-edit-address" value="$address" />
+</div>
+<div id="profile-edit-address-end"></div>
+
+<div id="profile-edit-locality-wrapper" >
+<label id="profile-edit-locality-label" for="profile-edit-locality" >$lbl_city </label>
+<input type="text" size="28" name="locality" id="profile-edit-locality" value="$locality" />
+</div>
+<div id="profile-edit-locality-end"></div>
+
+
+<div id="profile-edit-postal-code-wrapper" >
+<label id="profile-edit-postal-code-label" for="profile-edit-postal-code" >$lbl_zip </label>
+<input type="text" size="28" name="postal_code" id="profile-edit-postal-code" value="$postal_code" />
+</div>
+<div id="profile-edit-postal-code-end"></div>
+
+<div id="profile-edit-country-name-wrapper" >
+<label id="profile-edit-country-name-label" for="profile-edit-country-name" >$lbl_country </label>
+<select name="country_name" id="profile-edit-country-name" onChange="Fill_States('$region');">
+<option selected="selected" >$country_name</option>
+<option>temp</option>
+</select>
+</div>
+<div id="profile-edit-country-name-end"></div>
+
+<div id="profile-edit-region-wrapper" >
+<label id="profile-edit-region-label" for="profile-edit-region" >$lbl_region </label>
+<select name="region" id="profile-edit-region" onChange="Update_Globals();" >
+<option selected="selected" >$region</option>
+<option>temp</option>
+</select>
+</div>
+<div id="profile-edit-region-end"></div>
+
+<div id="profile-edit-hometown-wrapper" >
+<label id="profile-edit-hometown-label" for="profile-edit-hometown" >$lbl_hometown </label>
+<input type="text" size="28" name="hometown" id="profile-edit-hometown" value="$hometown" />
+</div>
+<div id="profile-edit-hometown-end"></div>
+
+<div class="profile-edit-submit-wrapper" >
+<input type="submit" name="submit" class="profile-edit-submit-button" value="$submit" />
+</div>
+<div class="profile-edit-submit-end"></div>
+
+<div id="profile-edit-marital-wrapper" >
+<label id="profile-edit-marital-label" for="profile-edit-marital" >$lbl_marital </label>
+$marital
+</div>
+<label id="profile-edit-with-label" for="profile-edit-with" > $lbl_with </label>
+<input type="text" size="28" name="with" id="profile-edit-with" title="$lbl_ex1" value="$with" />
+<label id="profile-edit-howlong-label" for="profile-edit-howlong" > $lbl_howlong </label>
+<input type="text" size="28" name="howlong" id="profile-edit-howlong" title="$lbl_howlong" value="$howlong" />
+
+<div id="profile-edit-marital-end"></div>
+
+<div id="profile-edit-sexual-wrapper" >
+<label id="profile-edit-sexual-label" for="sexual-select" >$lbl_sexual </label>
+$sexual
+</div>
+<div id="profile-edit-sexual-end"></div>
+
+
+
+<div id="profile-edit-homepage-wrapper" >
+<label id="profile-edit-homepage-label" for="profile-edit-homepage" >$lbl_homepage </label>
+<input type="text" size="28" name="homepage" id="profile-edit-homepage" value="$homepage" />
+</div>
+<div id="profile-edit-homepage-end"></div>
+
+<div id="profile-edit-politic-wrapper" >
+<label id="profile-edit-politic-label" for="profile-edit-politic" >$lbl_politic </label>
+<input type="text" size="28" name="politic" id="profile-edit-politic" value="$politic" />
+</div>
+<div id="profile-edit-politic-end"></div>
+
+<div id="profile-edit-religion-wrapper" >
+<label id="profile-edit-religion-label" for="profile-edit-religion" >$lbl_religion </label>
+<input type="text" size="28" name="religion" id="profile-edit-religion" value="$religion" />
+</div>
+<div id="profile-edit-religion-end"></div>
+
+<div id="profile-edit-pubkeywords-wrapper" >
+<label id="profile-edit-pubkeywords-label" for="profile-edit-pubkeywords" >$lbl_pubkey </label>
+<input type="text" size="28" name="pub_keywords" id="profile-edit-pubkeywords" title="$lbl_ex2" value="$pub_keywords" />
+</div><div id="profile-edit-pubkeywords-desc">$lbl_pubdsc</div>
+<div id="profile-edit-pubkeywords-end"></div>
+
+<div id="profile-edit-prvkeywords-wrapper" >
+<label id="profile-edit-prvkeywords-label" for="profile-edit-prvkeywords" >$lbl_prvkey </label>
+<input type="text" size="28" name="prv_keywords" id="profile-edit-prvkeywords" title="$lbl_ex2" value="$prv_keywords" />
+</div><div id="profile-edit-prvkeywords-desc">$lbl_prvdsc</div>
+<div id="profile-edit-prvkeywords-end"></div>
+
+
+<div class="profile-edit-submit-wrapper" >
+<input type="submit" name="submit" class="profile-edit-submit-button" value="$submit" />
+</div>
+<div class="profile-edit-submit-end"></div>
+
+<div id="about-jot-wrapper" class="profile-jot-box">
+<p id="about-jot-desc" >
+$lbl_about
+</p>
+
+<textarea rows="10" cols="30" id="profile-about-text" class="profile-edit-textarea" name="about" >$about</textarea>
+
+</div>
+<div id="about-jot-end"></div>
+
+
+<div id="interest-jot-wrapper" class="profile-jot-box" >
+<p id="interest-jot-desc" >
+$lbl_hobbies
+</p>
+
+<textarea rows="10" cols="30" id="interest-jot-text" class="profile-edit-textarea" name="interest" >$interest</textarea>
+
+</div>
+<div id="interest-jot-end"></div>
+
+
+<div id="likes-jot-wrapper" class="profile-jot-box" >
+<p id="likes-jot-desc" >
+$lbl_likes
+</p>
+
+<textarea rows="10" cols="30" id="likes-jot-text" class="profile-edit-textarea" name="likes" >$likes</textarea>
+
+</div>
+<div id="likes-jot-end"></div>
+
+
+<div id="dislikes-jot-wrapper" class="profile-jot-box" >
+<p id="dislikes-jot-desc" >
+$lbl_dislikes
+</p>
+
+<textarea rows="10" cols="30" id="dislikes-jot-text" class="profile-edit-textarea" name="dislikes" >$dislikes</textarea>
+
+</div>
+<div id="dislikes-jot-end"></div>
+
+
+<div id="contact-jot-wrapper" class="profile-jot-box" >
+<p id="contact-jot-desc" >
+$lbl_social
+</p>
+
+<textarea rows="10" cols="30" id="contact-jot-text" class="profile-edit-textarea" name="contact" >$contact</textarea>
+
+</div>
+<div id="contact-jot-end"></div>
+
+
+<div class="profile-edit-submit-wrapper" >
+<input type="submit" name="submit" class="profile-edit-submit-button" value="$submit" />
+</div>
+<div class="profile-edit-submit-end"></div>
+
+
+<div id="music-jot-wrapper" class="profile-jot-box" >
+<p id="music-jot-desc" >
+$lbl_music
+</p>
+
+<textarea rows="10" cols="30" id="music-jot-text" class="profile-edit-textarea" name="music" >$music</textarea>
+
+</div>
+<div id="music-jot-end"></div>
+
+<div id="book-jot-wrapper" class="profile-jot-box" >
+<p id="book-jot-desc" >
+$lbl_book
+</p>
+
+<textarea rows="10" cols="30" id="book-jot-text" class="profile-edit-textarea" name="book" >$book</textarea>
+
+</div>
+<div id="book-jot-end"></div>
+
+
+
+<div id="tv-jot-wrapper" class="profile-jot-box" >
+<p id="tv-jot-desc" >
+$lbl_tv 
+</p>
+
+<textarea rows="10" cols="30" id="tv-jot-text" class="profile-edit-textarea" name="tv" >$tv</textarea>
+
+</div>
+<div id="tv-jot-end"></div>
+
+
+
+<div id="film-jot-wrapper" class="profile-jot-box" >
+<p id="film-jot-desc" >
+$lbl_film
+</p>
+
+<textarea rows="10" cols="30" id="film-jot-text" class="profile-edit-textarea" name="film" >$film</textarea>
+
+</div>
+<div id="film-jot-end"></div>
+
+
+<div class="profile-edit-submit-wrapper" >
+<input type="submit" name="submit" class="profile-edit-submit-button" value="$submit" />
+</div>
+<div class="profile-edit-submit-end"></div>
+
+
+<div id="romance-jot-wrapper" class="profile-jot-box" >
+<p id="romance-jot-desc" >
+$lbl_love
+</p>
+
+<textarea rows="10" cols="30" id="romance-jot-text" class="profile-edit-textarea" name="romance" >$romance</textarea>
+
+</div>
+<div id="romance-jot-end"></div>
+
+
+
+<div id="work-jot-wrapper" class="profile-jot-box" >
+<p id="work-jot-desc" >
+$lbl_work
+</p>
+
+<textarea rows="10" cols="30" id="work-jot-text" class="profile-edit-textarea" name="work" >$work</textarea>
+
+</div>
+<div id="work-jot-end"></div>
+
+
+
+<div id="education-jot-wrapper" class="profile-jot-box" >
+<p id="education-jot-desc" >
+$lbl_school 
+</p>
+
+<textarea rows="10" cols="30" id="education-jot-text" class="profile-edit-textarea" name="education" >$education</textarea>
+
+</div>
+<div id="education-jot-end"></div>
+
+
+
+<div class="profile-edit-submit-wrapper" >
+<input type="submit" name="submit" class="profile-edit-submit-button" value="$submit" />
+</div>
+<div class="profile-edit-submit-end"></div>
+
+
+</form>
+</div>
+<script type="text/javascript">Fill_Country('$country_name');Fill_States('$region');</script>
diff --git a/view/theme/frost-mobile/profile_vcard.tpl b/view/theme/frost-mobile/profile_vcard.tpl
new file mode 100644 (file)
index 0000000..bcb5bae
--- /dev/null
@@ -0,0 +1,51 @@
+<div class="vcard">
+
+       <div class="fn label">$profile.name</div>
+       
+                               
+       
+       {{ if $pdesc }}<div class="title">$profile.pdesc</div>{{ endif }}
+       <div id="profile-photo-wrapper"><img class="photo" width="175" height="175" src="$profile.photo?rev=$profile.picdate" alt="$profile.name"></div>
+
+
+
+       {{ if $location }}
+               <dl class="location"><dt class="location-label">$location</dt> 
+               <dd class="adr">
+                       {{ if $profile.address }}<div class="street-address">$profile.address</div>{{ endif }}
+                       <span class="city-state-zip">
+                               <span class="locality">$profile.locality</span>{{ if $profile.locality }}, {{ endif }}
+                               <span class="region">$profile.region</span>
+                               <span class="postal-code">$profile.postal-code</span>
+                       </span>
+                       {{ if $profile.country-name }}<span class="country-name">$profile.country-name</span>{{ endif }}
+               </dd>
+               </dl>
+       {{ endif }}
+
+       {{ if $gender }}<dl class="mf"><dt class="gender-label">$gender</dt> <dd class="x-gender">$profile.gender</dd></dl>{{ endif }}
+       
+       {{ if $profile.pubkey }}<div class="key" style="display:none;">$profile.pubkey</div>{{ endif }}
+
+       {{ if $marital }}<dl class="marital"><dt class="marital-label"><span class="heart">&hearts;</span>$marital</dt><dd class="marital-text">$profile.marital</dd></dl>{{ endif }}
+
+       {{ if $homepage }}<dl class="homepage"><dt class="homepage-label">$homepage</dt><dd class="homepage-url"><a href="$profile.homepage" target="external-link">$profile.homepage</a></dd></dl>{{ endif }}
+
+       {{ inc diaspora_vcard.tpl }}{{ endinc }}
+
+       <div id="profile-vcard-break"></div>    
+       <div id="profile-extra-links">
+               <ul>
+                       {{ if $connect }}
+                               <li><a id="dfrn-request-link" href="dfrn_request/$profile.nickname">$connect</a></li>
+                       {{ endif }}
+                       {{ if $wallmessage }}
+                               <li><a id="wallmessage-link" href="wallmessage/$profile.nickname">$wallmessage</a></li>
+                       {{ endif }}
+               </ul>
+       </div>
+</div>
+
+$contact_block
+
+
diff --git a/view/theme/frost-mobile/prv_message.tpl b/view/theme/frost-mobile/prv_message.tpl
new file mode 100644 (file)
index 0000000..9a20c6c
--- /dev/null
@@ -0,0 +1,39 @@
+
+<h3>$header</h3>
+
+<div id="prvmail-wrapper" >
+<form id="prvmail-form" action="message" method="post" >
+
+$parent
+
+<div id="prvmail-to-label">$to</div>
+
+{{ if $showinputs }}
+<input type="text" id="recip" name="messageto" value="$prefill" maxlength="255" size="64" tabindex="10" />
+<input type="hidden" id="recip-complete" name="messageto" value="$preid">
+{{ else }}
+$select
+{{ endif }}
+
+<div id="prvmail-subject-label">$subject</div>
+<input type="text" size="28" maxlength="255" id="prvmail-subject" name="subject" value="$subjtxt" $readonly tabindex="11" />
+
+<div id="prvmail-message-label">$yourmessage</div>
+<textarea rows="8" cols="32" class="prvmail-text" id="prvmail-text" name="body" tabindex="12">$text</textarea>
+
+
+<div id="prvmail-submit-wrapper" >
+       <input type="submit" id="prvmail-submit" name="submit" value="Submit" tabindex="13" />
+       <div id="prvmail-upload-wrapper" >
+               <div id="prvmail-upload" class="icon border camera" title="$upload" ></div>
+       </div> 
+       <div id="prvmail-link-wrapper" >
+               <div id="prvmail-link" class="icon border link" title="$insert" onclick="jotGetLink();" ></div>
+       </div> 
+       <div id="prvmail-rotator-wrapper" >
+               <img id="prvmail-rotator" src="images/rotator.gif" alt="$wait" title="$wait" style="display: none;" />
+       </div> 
+</div>
+<div id="prvmail-end"></div>
+</form>
+</div>
diff --git a/view/theme/frost-mobile/register.tpl b/view/theme/frost-mobile/register.tpl
new file mode 100644 (file)
index 0000000..506e3b1
--- /dev/null
@@ -0,0 +1,78 @@
+<div class='register-form'>
+<h2>$regtitle</h2>
+<br />
+
+<form action="register" method="post" id="register-form">
+
+       <input type="hidden" name="photo" value="$photo" />
+
+       $registertext
+
+       <p id="register-realpeople">$realpeople</p>
+
+       <br />
+       <div id="register-openid-wrapper"  class="field input" >
+                       $oidhtml
+       </div>
+       <div id="register-openid-end" ></div>
+
+       <div class="register-explain-wrapper">
+       <p id="register-fill-desc">$fillwith $fillext</p>
+       </div>
+
+       <br /><br />
+
+{{ if $invitations }}
+
+       <p id="register-invite-desc">$invite_desc</p>
+       <div id="register-invite-wrapper" >
+               <label for="register-invite" id="label-register-invite" >$invite_label</label>
+               <input type="text" maxlength="60" size="32" name="invite_id" id="register-invite" value="$invite_id" >
+       </div>
+       <div id="register-name-end" ></div>
+
+{{ endif }}
+
+
+       <div id="register-name-wrapper" class="field input" >
+               <label for="register-name" id="label-register-name" >$namelabel</label><br />
+               <input type="text" maxlength="60" size="32" name="username" id="register-name" value="$username" >
+       </div>
+       <div id="register-name-end" ></div>
+
+
+       <div id="register-email-wrapper"  class="field input" >
+               <label for="register-email" id="label-register-email" >$addrlabel</label><br />
+               <input type="text" maxlength="60" size="32" name="email" id="register-email" value="$email" >
+       </div>
+       <div id="register-email-end" ></div>
+
+       <div id="register-nickname-wrapper" class="field input" >
+               <label for="register-nickname" id="label-register-nickname" >$nicklabel</label><br />
+               <input type="text" maxlength="60" size="32" name="nickname" id="register-nickname" value="$nickname" >
+       </div>
+       <div id="register-nickname-end" ></div>
+
+       <div class="register-explain-wrapper">
+       <p id="register-nickname-desc" >$nickdesc</p>
+       </div>
+
+       $publish
+
+       <div id="register-footer">
+       <div class="agreement">
+       By clicking '$regbutt' you are agreeing to the latest <a href="tos.html" title="$tostitle" id="terms-of-service-link" >$toslink</a> and <a href="privacy.html" title="$privacytitle" id="privacy-link" >$privacylink</a>
+       </div>
+       <br />
+
+       <div id="register-submit-wrapper">
+               <input type="submit" name="submit" id="register-submit-button" value="$regbutt" />
+       </div>
+       <div id="register-submit-end" ></div>
+       </div>
+</form>
+<br /><br /><br />
+
+$license
+
+</div>
diff --git a/view/theme/frost-mobile/screenshot.jpg b/view/theme/frost-mobile/screenshot.jpg
new file mode 100644 (file)
index 0000000..1b18c3a
Binary files /dev/null and b/view/theme/frost-mobile/screenshot.jpg differ
diff --git a/view/theme/frost-mobile/settings.tpl b/view/theme/frost-mobile/settings.tpl
new file mode 100644 (file)
index 0000000..5a40b96
--- /dev/null
@@ -0,0 +1,144 @@
+<h1>$ptitle</h1>
+
+$nickname_block
+
+<form action="settings" id="settings-form" method="post" autocomplete="off" >
+<input type='hidden' name='form_security_token' value='$form_security_token'>
+
+<h3 class="settings-heading">$h_pass</h3>
+
+{{inc field_password.tpl with $field=$password1 }}{{endinc}}
+{{inc field_password.tpl with $field=$password2 }}{{endinc}}
+
+{{ if $oid_enable }}
+{{inc field_input.tpl with $field=$openid }}{{endinc}}
+{{ endif }}
+
+<div class="settings-submit-wrapper" >
+<input type="submit" name="submit" class="settings-submit" value="$submit" />
+</div>
+
+
+<h3 class="settings-heading">$h_basic</h3>
+
+{{inc field_input.tpl with $field=$username }}{{endinc}}
+{{inc field_input.tpl with $field=$email }}{{endinc}}
+{{inc field_custom.tpl with $field=$timezone }}{{endinc}}
+{{inc field_input.tpl with $field=$defloc }}{{endinc}}
+{{inc field_checkbox.tpl with $field=$allowloc }}{{endinc}}
+
+
+<div class="settings-submit-wrapper" >
+<input type="submit" name="submit" class="settings-submit" value="$submit" />
+</div>
+
+
+<h3 class="settings-heading">$h_prv</h3>
+
+
+<input type="hidden" name="visibility" value="$visibility" />
+
+{{inc field_input.tpl with $field=$maxreq }}{{endinc}}
+
+$profile_in_dir
+
+$profile_in_net_dir
+
+$hide_friends
+
+$hide_wall
+
+$blockwall
+
+$blocktags
+
+$suggestme
+
+$unkmail
+
+
+{{inc field_input.tpl with $field=$cntunkmail }}{{endinc}}
+
+{{inc field_input.tpl with $field=$expire.days }}{{endinc}}
+
+
+<div class="field input">
+       <span class="field_help"><a href="#advanced-expire-popup" id="advanced-expire" class='popupbox' title="$expire.advanced">$expire.label</a></span>
+       <div style="display: none;">
+               <div id="advanced-expire-popup" style="width:auto;height:auto;overflow:auto;">
+                       <h3>$expire.advanced</h3>
+                       {{ inc field_yesno.tpl with $field=$expire.items }}{{endinc}}
+                       {{ inc field_yesno.tpl with $field=$expire.notes }}{{endinc}}
+                       {{ inc field_yesno.tpl with $field=$expire.starred }}{{endinc}}
+                       {{ inc field_yesno.tpl with $field=$expire.network_only }}{{endinc}}
+               </div>
+       </div>
+
+</div>
+
+
+<div id="settings-default-perms" class="settings-default-perms" >
+       <a href="#settings-jot-acl-wrapper" id="settings-default-perms-menu" class='popupbox'>$permissions $permdesc</a>
+       <div id="settings-default-perms-menu-end"></div>
+
+<!--   <div id="settings-default-perms-select" style="display: none; margin-bottom: 20px" >-->
+       
+       <div style="display: none;">
+               <div id="settings-jot-acl-wrapper" style="width:auto;height:auto;overflow:auto;margin-bottom: 20px">
+                       $aclselect
+               </div>
+       </div>
+
+<!--   </div>-->
+</div>
+<br/>
+<div id="settings-default-perms-end"></div>
+
+$group_select
+
+
+<div class="settings-submit-wrapper" >
+<input type="submit" name="submit" class="settings-submit" value="$submit" />
+</div>
+
+
+
+<h3 class="settings-heading">$h_not</h3>
+<div id="settings-notifications">
+
+<div id="settings-activity-desc">$activity_options</div>
+
+{{inc field_checkbox.tpl with $field=$post_newfriend }}{{endinc}}
+{{inc field_checkbox.tpl with $field=$post_joingroup }}{{endinc}}
+{{inc field_checkbox.tpl with $field=$post_profilechange }}{{endinc}}
+
+
+<div id="settings-notify-desc">$lbl_not</div>
+
+<div class="group">
+{{inc field_intcheckbox.tpl with $field=$notify1 }}{{endinc}}
+{{inc field_intcheckbox.tpl with $field=$notify2 }}{{endinc}}
+{{inc field_intcheckbox.tpl with $field=$notify3 }}{{endinc}}
+{{inc field_intcheckbox.tpl with $field=$notify4 }}{{endinc}}
+{{inc field_intcheckbox.tpl with $field=$notify5 }}{{endinc}}
+{{inc field_intcheckbox.tpl with $field=$notify6 }}{{endinc}}
+{{inc field_intcheckbox.tpl with $field=$notify7 }}{{endinc}}
+</div>
+
+</div>
+
+<div class="settings-submit-wrapper" >
+<input type="submit" name="submit" class="settings-submit" value="$submit" />
+</div>
+
+
+<h3 class="settings-heading">$h_advn</h3>
+<div id="settings-pagetype-desc">$h_descadvn</div>
+
+$pagetype
+
+<div class="settings-submit-wrapper" >
+<input type="submit" name="submit" class="settings-submit" value="$submit" />
+</div>
+
+
diff --git a/view/theme/frost-mobile/style.css b/view/theme/frost-mobile/style.css
new file mode 100644 (file)
index 0000000..13bc6c3
--- /dev/null
@@ -0,0 +1,3847 @@
+/**
+ * duepuntozero Frindika style
+ * Fabio Comuni <fabrix.xm@gmail.com>
+ *
+ * Heavily modified for Frost Mobile
+ * Zach P
+ */
+
+
+/* generals */
+html {
+       width: 320px;
+       margin-left: auto;
+       margin-right: auto;
+}
+
+body {
+       font-family: helvetica,arial,freesans,clean,sans-serif;
+       font-size: 16px;
+/*     line-height: 24px;*/
+       background-color: #ffffff;
+       background-image: url(head.jpg);
+       background-repeat: repeat-x;
+       color: #505050;
+       margin: 0px;
+}
+
+div.container {
+       display: block;
+/*     width: 100%;*/
+       margin-top: 0px;
+       margin-bottom: 0px;
+       margin-left: auto;
+       margin-right: auto;
+}
+
+a, a:visited, a:link { color: #3465a4; text-decoration: none; }
+a:hover {text-decoration: underline; }
+
+input {
+       border: 1px solid #666666;
+       -moz-border-radius: 3px;
+       -webkit-border-radius: 3px;
+       border-radius: 3px;     
+       padding: 3px;
+}
+
+img { border :0px; }
+
+#id_openid_url, .openid input {
+   background: url(login-bg.gif) no-repeat;
+   background-position: 0 50%;
+   padding-left: 18px;
+   width: 252px;
+   margin-left: 20px;
+}
+.openid:hover {
+
+}
+
+/*#id_openid_url {
+       width: 384px;
+}*/
+
+code {
+       font-family: Courier, monospace;
+       white-space: pre;
+       display: block;
+       overflow: auto;
+       border: 1px solid #444;
+       background: #EEE;
+       color: #444;
+       padding: 10px;
+       margin-top: 20px; 
+}
+
+blockquote {
+       background-color: #f4f8f9;
+       border-left: 4px solid #dae4ee;
+       padding: 0.4em;
+}
+
+.icollapse-wrapper, .ccollapse-wrapper {
+       border: 1px solid #CCC;
+       padding: 5px;
+}
+
+.hide-comments-outer {
+       margin-left: 0px;
+       font-weight: 700;
+       opacity: 0.6;
+}
+.hide-comments {
+       margin-left: 5px;
+}
+
+#panel {
+       background-color: ivory;
+       position: absolute;
+       z-index: 2;
+       width: 30%;
+       padding: 25px;
+       border: 1px solid #444;
+}
+
+.heart {
+       color: #FF0000;
+       font-size: 100%;
+       margin-right: 5px;
+}
+
+
+
+/* nav */
+nav {
+       height: 94px;
+/*     width: 100%;*/
+       width: 320px;
+       display: block;
+       margin-top: 0px;
+       margin-bottom: 0px;
+       margin-left: auto;
+       margin-right: auto;
+}
+nav #site-location {
+       color: #888a85;
+       font-size: 0.8em;
+       position: absolute;
+}
+
+.error-message {
+       color: #FF0000;
+       font-size: 1.1em;
+       border: 1px solid #FF8888;
+       background-color: #FFEEEE;
+       padding: 10px;
+}
+
+.info-message {
+       color: #204a87;
+       font-size: 1.1em;
+       border: 1px solid #3465a4;
+       background-color: #d7e3f1;
+       padding: 10px;
+}
+
+
+nav #banner {
+/*     display: block;*/
+       display: none;
+       margin-top: 14px;
+       position: absolute;
+}
+nav #banner #logo-text a {
+       display: none;
+       font-size: 40px;
+       font-weight: bold;
+       margin-left: 3px;
+       color: #000000;
+
+}
+nav #banner #logo-text a:hover { text-decoration: none; }
+
+
+/* ZP REMOVE? nav-commlink */
+.nav-commlink, .nav-login-link {
+       display: block;
+       height: 15px;
+       margin-top: 67px;
+       margin-right: 2px;
+       /*padding: 6px 10px;*/
+       padding: 6px 3px;
+       float: left;
+       bottom: 140px;
+       border: 1px solid #babdb6;
+       border-bottom: 0px;
+       background-color: #aec0d3;
+       color: #565854;         
+       -moz-border-radius: 3px 3px 0px 0px;
+       -webkit-border-radius: 3px 3px 0px 0px;
+       border-radius: 3px 3px 0px 0px; 
+}
+
+.nav-commlink.selected {
+       background-color: #ffffff;
+       border-bottom: 1px solid #ffffff;
+       color: #000000 !important;
+       margin-top: 64px;
+       padding-top: 6px;
+       padding-bottom: 8px;
+}
+
+.nav-ajax-left.show {
+       position: absolute;
+       font-size: 0.8em;
+       top: 22px;
+       right: 2px;
+       padding: 1px 2px;
+       border-radius: 4px;
+       -moz-border-radius: 4px;
+       -webkit-border-radius: 4px;
+       background-color: gold !important;
+}
+
+
+
+nav #nav-link-wrapper .nav-link {
+       /*border-right: 1px solid #babdb6;*/
+}
+
+nav .nav-link {
+       margin-top: 24px;
+       margin-bottom: 0.2em;
+       margin-right: 1em;
+       margin-left: 1em;
+       background-color: transparent !important;
+}
+
+.nav-button-container {
+       float: right;
+       position: relative;
+}
+
+.nav-button-container .nav-ajax-left {
+}
+
+.nav-menu-list {
+       text-align: center;
+       text-size: 18px;
+       line-height: 24px;
+
+       border-left: 1px solid #aaa;/*#444444;*/
+       border-right: 1px solid #aaa;
+       border-top: 1px solid #aaa;
+       border-bottom: 1px solid #aaa;
+
+       background: #FFFFFF;
+
+       display: none;
+       list-style: none;
+
+       width: 8em;
+       position: absolute;
+       margin: 0px;
+/*     right: -33px;*/
+       padding: 1em 0px;
+
+       -moz-box-shadow: 3px 3px 5px #555;
+       -webkit-box-shadow: 3px 3px 5px #555;
+       box-shadow: 3px 3px 5px #555;
+
+       z-index: 10000;
+}
+
+#network-menu-list {
+       left: 3px;
+}
+
+#contacts-menu-list {
+       right: -30px;
+}
+
+#system-menu-list {
+       right: 3px;
+}
+
+
+div.main-container {
+/*     width: 100%;*/
+       margin: 0px auto;
+       display: block;
+       position: relative;
+}
+
+/*div.main-content-loading {
+       position: absolute;
+       top: 200px;
+       left: 50%;
+       display: none;
+}*/
+
+
+/* aside */
+aside {
+/*     display: block;*/
+       display: none;
+       min-height: 112px;
+
+       width: 250px;
+
+       padding: 1em;
+       margin: 1em 0px 0px 0px;
+
+       position: absolute;
+
+/*     float:left;*/
+}
+
+#dfrn-request-link {
+       display: block;
+       color: #FFFFFF;
+       -webkit-border-radius: 5px ;
+       -moz-border-radius: 5px;
+       border-radius: 5px;
+       padding: 5px;
+       font-weight: bold;
+       background: #3465a4 url('friendika-16.png') no-repeat 95% center;
+}
+#wallmessage-link {
+       display: block;
+       color: #FFFFFF;
+       -webkit-border-radius: 5px ;
+       -moz-border-radius: 5px;
+       border-radius: 5px;
+       padding: 5px;
+       font-weight: bold;
+       background-color: #3465a4;
+}
+
+/* section */
+div.section-wrapper {
+/*     width: 100%;*/
+       width: 320px;
+
+       margin-left: auto;
+       margin-right: auto;
+
+       /*padding-right:2em;*/
+
+       display: block;
+
+       background-color: #ffffff;
+       background-image: url(border.jpg);
+       background-position: top right;
+       background-repeat: no-repeat;
+}
+
+section {
+       margin: 0px 0px 0px 0px;
+
+       padding-left: 5px;
+       padding-right: 5px;
+       padding-top: 1em;
+       padding-bottom: 3em;
+
+       background-image: url(border.jpg);
+       background-position: top left;
+       background-repeat: no-repeat;
+
+       min-height: 112px;
+       border-top: 1px solid #babdb6;  
+}
+
+.tabs {
+       /*background-image: url(head.jpg);
+       background-repeat: repeat-x;    
+       background-position: 0px -20px;*/
+       border-bottom: 1px solid #babdb6;
+       padding:0px;
+}
+.tabs li { margin: 0px 0px 20px 0px; padding-left: 1em; list-style: none; }
+.tabs a {
+       padding: 0.2em 2em;
+       border: 1px solid #aaa;
+       border-radius: 8px;
+       -moz-border-radius: 8px;
+       -webkit-border-radius: 8px;
+}
+.tab {
+       /*display:block;*/
+       /*float:left;*/
+       padding-left: 1em;
+       padding-right: 0.4em;
+       padding-top: 0.4em;
+       padding-bottom: 0.4em;
+       /*margin-right: 1em;*/
+       margin-right: 3px ;
+}
+.tab.active {
+       font-weight: bold;
+       
+}
+#events-tab {
+       display: none;
+}
+
+
+/* footer */
+footer {
+    display: none;
+
+}
+
+.birthday-today, .event-today {
+       font-weight: bold;
+}
+
+.preview {
+       background: #FFFFC8;
+}
+
+#theme-preview {
+       margin: 15px 0 15px 150px;
+}
+
+/* from default */
+#jot-perms-icon, 
+#profile-location,
+#profile-nolocation,
+#profile-youtube, 
+#profile-video, 
+#profile-audio,
+#profile-link,
+#profile-title, 
+#wall-image-upload,
+#wall-file-upload,
+#profile-upload-wrapper,
+#wall-image-upload-div,
+#wall-file-upload-div,
+.hover, .focus {
+       cursor: pointer;
+}
+
+#jot-perms-icon {
+       float: left;
+}
+
+#jot-title, #jot-category {
+       border: 0px;
+       margin: 0px;
+       height: 20px;
+       width: 270px;
+       margin-bottom: 5px;
+       font-weight: bold;
+       border: 1px solid #ffffff;
+}
+
+#jot-title::-webkit-input-placeholder{font-weight: normal;}
+#jot-category::-webkit-input-placeholder{font-weight: normal;}
+#jot-title:-moz-placeholder{font-weight: normal;}
+#jot-category:-moz-placeholder{font-weight: normal;}
+               
+       
+#jot-title:hover,
+#jot-title:focus,
+#jot-category:hover,
+#jot-category:focus {
+       border: 1px solid #cccccc; 
+}
+
+.jothidden { display:none; }
+
+
+.fakelink, .fakelink:visited, .fakelink:link {
+       color: #3465a4;
+       text-decoration: none;
+       cursor: pointer;
+       margin-top: 15px;
+       margin-bottom: 15px;
+}
+.lockview {
+       cursor: pointer;
+}
+
+#group-sidebar {
+       margin-bottom: 10px;
+}
+
+.group-selected, .nets-selected, .fileas-selected, .categories-selected {
+       padding: 3px;
+       -moz-border-radius: 3px;
+       -webkit-border-radius: 3px;
+       border-radius: 3px;     
+       border: 1px solid #CCCCCC;
+       background: #F8F8F8;
+       font-weight: bold;
+}
+
+.settings-widget .selected {
+       padding: 3px;
+       -moz-border-radius: 3px;
+       -webkit-border-radius: 3px;
+       border-radius: 3px;     
+       border: 1px solid #CCCCCC;
+       background: #F8F8F8;
+       font-weight: bold;
+}
+
+.fakelink:hover {
+       color: #3465a4;
+       text-decoration: underline;
+       cursor: pointer;
+}
+.smalltext {
+       font-size: 0.7em;
+}
+#sysmsg {
+       /*width: 600px;*/
+       margin-bottom: 10px;
+}
+
+#register-fill-ext {
+       margin-bottom: 25px;
+}
+
+#label-register-name, #label-register-email, #label-register-nickname, #label-register-openid {
+       float: left;
+       width: 350px;
+       margin-top: 10px;
+}
+
+#register-name, #register-email, #register-nickname {
+       float: left;
+       margin-top: 10px;
+       width: 150px;
+}
+
+#register-openid {
+       float: left;
+       margin-top: 10px;
+       width: 130px;
+}
+
+#register-name-end, #register-email-end, #register-nickname-end, #register-submit-end, #register-openid-end {
+       clear: both;
+}
+
+#register-nickname-desc {
+       margin-top: 30px;
+       width: 650px;
+}
+#register-sitename {
+       float: left;
+       margin-top: 10px;
+}
+
+#register-submit-button {
+       margin-top: 10px;
+}
+
+
+#login_standard {
+       width: 210px;
+       float: left;
+}
+#login_openid {
+       width: 210px;
+       margin-left: 250px;
+}
+
+#login_standard input,
+#login_openid input {
+       width: 180px;
+}
+
+#login-extra-links {
+       clear: both;
+}
+
+#register-link, #lost-password-link {
+       float: left;
+       font-size: 80%;
+       margin-right: 15px;
+}
+
+#login-name-end, #login-password-end, #login-extra-end, #login-submit-end {
+       height: 50px;
+}
+
+#login-submit-button {
+/*     margin-top: 10px; */
+       margin-left: 200px;
+}
+
+
+input#dfrn-url {
+       float: left;
+       background: url(friendika-16.png) no-repeat;
+       background-position: 2px center;
+       font-size: 17px;
+       padding-left: 21px;
+       height: 21px;
+       background-color: #FFFFFF;
+       color: #000000;
+       margin-bottom: 20px;
+}
+
+#dfrn-url-label {
+       float: left;
+       width: 250px;
+}
+
+#dfrn-request-url-end {
+       clear: both;
+}
+
+#knowyouyes, #knowyouno {
+       float: left;
+}
+
+#dfrn-request-knowyou-yes-wrapper, #dfrn-request-knowyou-no-wrapper {
+
+       float: none;
+}
+#dfrn-request-knowyou-yes-label, #dfrn-request-knowyou-no-label {
+       float: left;
+       width: 75px;
+       margin-left: 50px;
+       margin-bottom: 7px;
+}
+#dfrn-request-knowyou-break, #dfrn-request-knowyou-end {
+       clear: both;
+
+}
+
+#dfrn-request-message-wrapper {
+       margin-bottom: 50px;
+}
+#dfrn-request-submit-wrapper {
+       clear: both;
+       margin-left: 50px;
+}
+
+#dfrn-request-info-wrapper {
+       margin-left: 50px;
+}
+
+
+
+#cropimage-wrapper, #cropimage-preview-wrapper {
+       float: left;
+       padding: 30px;
+}
+
+#crop-image-form {
+       margin-top: 30px;
+       clear: both;
+}
+
+.intro-wrapper {
+       margin-top: 20px;
+}
+
+.intro-fullname {
+       font-size: 1.1em;
+       font-weight: bold;
+
+}
+.intro-desc {
+       margin-bottom: 20px;
+       font-weight: bold;
+}
+
+.intro-note {
+       padding: 10px;
+}
+
+.intro-end {
+       padding: 30px;
+}
+
+.intro-form {
+       float: left;
+}
+.intro-approve-form {
+       clear: both;
+}
+.intro-approve-as-friend-end {
+       clear: both;
+}
+.intro-submit-approve, .intro-submit-ignore {
+       margin-right: 20px;
+}
+.intro-submit-approve {
+       margin-top: 15px;
+}
+
+.intro-approve-as-friend-label, .intro-approve-as-fan-label {
+       float: left;
+       width: 100px;
+       margin-left: 20px;
+}
+.intro-approve-as-friend, .intro-approve-as-fan {
+       float: left;
+}
+.intro-form-end {
+       clear: both;
+}
+.intro-approve-as-friend-desc {
+       margin-top: 15px;
+}
+.intro-approve-as-end {
+       clear: both;
+       margin-bottom: 10px;
+}
+
+.intro-end {
+       clear: both;
+       margin-bottom: 30px;
+}
+.aprofile dt {
+       font-weight: bold;
+}
+#page-profile .title {
+       font-weight: bold;
+}
+#profile-vcard-break {
+       clear: both;
+}
+#profile-extra-links {
+       clear: both;
+       margin-top: 10px;
+}
+
+#profile-extra-links ul {
+       list-style-type: none;
+       padding: 0px;
+}
+
+
+#profile-extra-links li {
+       margin-top: 5px;
+}
+
+#profile-edit-links ul {
+       list-style-type: none;
+}
+
+#profile-edit-links li {
+       margin-top: 10px;
+}
+.profile-edit-side-div {
+       float: right;
+}
+.profile-edit-side-link {
+       opacity: 0.3;
+       filter:alpha(opacity=30);
+}
+.profile-edit-side-link:hover {
+       opacity: 1.0;
+       filter:alpha(opacity=100);
+}
+
+.view-contact-wrapper {
+       margin-top: 20px;
+       float: left;
+       margin-left: 20px;
+       width: 180px;
+}
+
+.contact-wrapper {
+       float: left;
+       width: 150px;
+       height: 150px;
+       overflow: auto;
+}
+
+#view-contact-end {
+       clear: both;
+}
+
+
+#viewcontacts {
+       margin-top: 15px;
+}
+#profile-edit-default-desc {
+       color: #FF0000;
+       border: 1px solid #FF8888;
+       background-color: #FFEEEE;
+       padding: 7px;
+}
+
+#profile-edit-clone-link-wrapper {
+       float: left;
+       margin-left: 50px;
+       margin-bottom: 20px;
+       width: 300px;
+}
+
+
+#profile-edit-links-end {
+       clear: both;
+       margin-bottom: 15px;
+}
+
+.profile-listing-photo {
+       border: none;
+}
+
+.profile-edit-submit-wrapper {
+       margin-top: 20px;
+       margin-bottom: 20px;
+}
+
+#profile-photo-link-select-wrapper {
+       margin-top: 2em;
+}
+
+#profile-photo-submit-wrapper {
+       margin-top: 10px;
+}
+
+#profile-photo-wrapper img {
+       width:175px;
+       height:175px;
+       padding: 12px;
+}
+
+#profile-edit-profile-name-label,
+#profile-edit-name-label,
+#profile-edit-pdesc-label,
+#profile-edit-gender-label,
+#profile-edit-dob-label,
+#profile-edit-address-label,
+#profile-edit-locality-label,
+#profile-edit-region-label,
+#profile-edit-postal-code-label,
+#profile-edit-country-name-label,
+#profile-edit-marital-label,
+#profile-edit-sexual-label,
+#profile-edit-politic-label,
+#profile-edit-religion-label,
+#profile-edit-pubkeywords-label,
+#profile-edit-prvkeywords-label,
+#profile-edit-homepage-label,
+#profile-edit-hometown-label {
+       font-weight: 700;
+       float: left;
+       width: 175px;
+}
+
+#profile-edit-profile-name,
+#profile-edit-name,
+#profile-edit-pdesc,
+#gender-select,
+#profile-edit-dob,
+#profile-edit-address,
+#profile-edit-locality,
+#profile-edit-region,
+#profile-edit-postal-code,
+#profile-edit-country-name,
+#marital-select,
+#sexual-select,
+#profile-edit-politic,
+#profile-edit-religion,
+#profile-edit-pubkeywords,
+#profile-edit-prvkeywords,
+#profile-in-dir-yes,
+#profile-in-dir-no,
+#profile-in-netdir-yes,
+#profile-in-netdir-no,
+#hide-wall-yes,
+#hide-wall-no,
+#hide-friends-yes,
+#hide-friends-no {
+       float: left;
+       margin-bottom: 20px;
+       margin-left: 20px;
+}
+#profile-edit-country-name {
+       max-width: 260px;
+}
+#profile-edit-pubkeywords,
+#profile-edit-prvkeywords {
+       margin-bottom: 5px;
+}
+#settings-normal,
+#settings-soapbox,
+#settings-freelove,
+#settings-community {
+       float: left;
+}
+#settings-notifications label {
+       margin-left: 20px;
+}
+#settings-notify-desc, #settings-activity-desc {
+       font-weight: bold;
+       margin-bottom: 15px;
+}
+#settings-pagetype-desc {
+       color: #666666;
+       margin-bottom: 15px;
+}
+
+#profile-in-dir-yes-label,
+#profile-in-dir-no-label,
+#profile-in-netdir-yes-label,
+#profile-in-netdir-no-label,
+#hide-wall-yes-label,
+#hide-wall-no-label,
+#hide-friends-yes-label,
+#hide-friends-no-label {
+       margin-left: 125px;
+       float: left;
+       width: 50px;
+}
+
+
+#profile-edit-howlong-label,
+#profile-edit-with-label {
+       display: block;
+       font-style: italic;
+       width: 175px;
+       margin-left: 0px;
+}
+#profile-edit-howlong,
+#profile-edit-with {
+       margin-left: 20px;
+       margin-bottom: 20px;
+}
+
+#profile-publish-yes-reg,
+#profile-publish-no-reg {
+       float: left;
+       margin-bottom: 10px;
+}
+
+#profile-publish-yes-label-reg,
+#profile-publish-no-label-reg {
+       margin-left: 350px;
+       float: left;
+       width: 50px;
+}
+
+#profile-publish-break-reg,
+#profile-publish-end-reg {
+       clear: both;
+}
+
+
+#profile-edit-pdesc-desc,
+#profile-edit-pubkeywords-desc,
+#profile-edit-prvkeywords-desc  {
+       float: left;
+       color: #777;
+       margin-left: 20px;
+       margin-bottom: 20px;
+}
+#profile-edit-prvkeywords-desc {
+       margin-bottom: 0px;
+}
+
+#profile-edit-homepage, #profile-edit-hometown {
+       float: left;
+       margin-bottom: 25px;
+       margin-left: 20px;
+}
+#profile-edit-hometown {
+       margin-bottom: 5px;
+}
+#settings-normal-label,
+#settings-soapbox-label,
+#settings-community-label,
+#settings-freelove-label {
+       float: left;
+       width: 200px;
+}
+#settings-normal-desc,
+#settings-soapbox-desc,
+#settings-community-desc,
+#settings-freelove-desc {
+       /*float: left;
+       margin-left: 75px;*/
+    clear: left;
+    color: #666666;
+    display: block;
+    margin-bottom: 20px        
+}
+
+#profile-edit-profile-name-end,
+#profile-edit-name-end,
+#profile-edit-pdesc-end,
+#profile-edit-gender-end,
+#profile-edit-dob-end,
+#profile-edit-address-end,
+#profile-edit-locality-end,
+#profile-edit-region-end,
+#profile-edit-postal-code-end,
+#profile-edit-country-name-end,
+#profile-edit-marital-end,
+#profile-edit-sexual-end,
+#profile-edit-politic-end,
+#profile-edit-religion-end,
+#profile-edit-pubkeywords-end,
+#profile-edit-prvkeywords-end,
+#profile-edit-homepage-end,
+#profile-edit-hometown-end,
+#profile-in-dir-break,
+#profile-in-dir-end,
+#profile-in-netdir-break,
+#profile-in-netdir-end,
+#hide-wall-break,
+#hide-wall-end,
+#hide-friends-break,
+#hide-friends-end,
+#settings-normal-break,
+#settings-soapbox-break,
+#settings-community-break,
+#settings-freelove-break {
+       clear: both;
+}
+#profile-edit-marital-wrapper, #profile-edit-address-wrapper {
+       margin-top: 50px;
+}
+#profile-edit-marital-end {
+       margin-bottom: 20px;
+}
+
+.settings-widget ul {
+       list-style-type: none;
+       padding: 0px;
+}
+
+.settings-widget li {
+       margin-left: 24px;
+       margin-bottom: 8px;
+}
+
+
+#gender-select, #marital-select, #sexual-select {
+       width: 220px;
+}
+
+#profile-edit-profile-name-wrapper .required {
+       color: #FF0000;
+       float: left;
+}
+
+#contacts-display-wrapper {
+       padding-left: 35px;
+}
+
+#contacts-main {
+       margin-top: 20px;
+       margin-bottom: 20px;
+}
+
+.contact-entry-wrapper {
+       float: left;
+/*     width: 120px;
+       height: 120px;*/
+       padding-left: 15px;
+       padding-right: 15px; 
+       width: 95px;
+       height: 170px;
+}
+#contacts-search-end {
+       margin-bottom: 10px;
+}
+
+.contact-entry-direction-icon {
+       margin-top: 24px;
+       margin-right: 2px;
+}
+
+.contact-entry-photo img {
+       border: none;
+}
+.contact-entry-photo-end {
+       clear: both;
+}
+.contact-entry-name {
+       float: left;
+       margin-left: 0px;
+       margin-right: 10px;
+       padding-bottom: 5px;
+       width: 120px;
+       font-weight: 600;
+       overflow: hidden;
+}
+.contact-entry-details {
+       font-style: italic;
+       font-size: 10px;
+       font-weight: 500;
+}
+.contact-entry-network {
+       font-size: 10px;
+       font-weight: 500;
+}
+.contact-entry-edit-links {
+       margin-top: 6px;
+       margin-left: 10px;
+       width: 16px;
+}
+.contact-entry-nav-wrapper {
+       float: left;
+       margin-left: 10px;
+}
+
+.contact-entry-edit-links img {
+       border: none;
+       margin-right: 15px;
+}
+.contact-entry-photo {
+       float: left;
+       position: relative;
+}
+.contact-entry-end {
+       clear: both;
+}
+
+#fsuggest-desc, #fsuggest-submit-wrapper {
+       margin-top: 15px;
+       margin-bottom: 15px;
+}
+
+#network-star-link{
+       margin-top: 10px;
+}
+.network-star {
+       float: left;
+       margin-right: 5px;
+}
+#network-bmark-link {
+       margin-top: 10px;
+}
+
+.wall-item-content-wrapper {
+       margin-top: 60px;
+       padding-top: 30px;
+       border-top: 2px solid #AAAAAA;
+       position: relative;
+
+}
+
+.wall-item-content-wrapper.comment {
+       margin-top: 30px;
+       padding-top: 0px;
+       margin-left: 5px;
+       margin-right: 5px;
+       border: 2px solid #AAAAAA;
+       border-radius: 10px;
+       -webkit-border-radius: 10px;
+       -moz-border-radius: 10px;
+/*     background: #EEEEEE;*/
+}
+
+.wall-item-like, .wall-item-dislike {
+       font-style: italic;
+       margin-left: 0px;
+       opacity: 0.6;
+}
+
+.wall-item-like.comment, .wall-item-dislike.comment {
+       margin-left: 5px;
+}
+
+.wall-item-info {
+       display: block;
+       float: left;
+       width:110px;
+       margin-right:10px;
+}
+.comment .wall-item-info {
+       width: 70px;
+}
+
+.wall-item-photo-wrapper {
+       margin-bottom: 10px;
+       width: 100px;
+}
+.wall-item-photo-menu-button {
+       display: block;
+       position: absolute;
+       background-image: url("photo-menu.jpg");
+       background-position: top left; 
+       background-repeat: no-repeat;
+       margin: 0px; padding: 0px;
+       width: 16px;
+       height: 16px;
+       top: 94px; left:0px;
+       overflow: hidden;
+       text-indent: 40px;
+       display: none;
+       
+}
+.wall-item-photo-menu {
+       width: auto;
+       border: 2px solid #444444;
+       background: #FFFFFF;
+       position: absolute;
+       left: 0px; top:110px;
+       display: none;
+       z-index: 10000;
+}
+.wall-item-photo-menu ul { margin:0px; padding: 0px; list-style: none }
+.wall-item-photo-menu li a { display: block; padding: 2px; }
+.wall-item-photo-menu li a:hover { color: #FFFFFF; background: #3465A4; text-decoration: none; }
+
+
+.comment .wall-item-photo-menu-button {        top: 64px;}
+.comment .wall-item-photo-menu { top: 80px; }
+
+.wallwall .wwto {
+    left: 50px;
+    margin: 0;
+    position: absolute;
+    top: 80px;
+    width: 30px
+}
+.wallwall .wwto img {
+       width: 30px !important;
+       height: 30px !important;
+}
+
+.wallwall .wall-item-photo-end {
+       clear: both;
+}
+
+.wall-item-arrowphoto-wrapper {
+    position: absolute;
+    left: 75px;
+    top: 80px;
+    z-index: 100;
+}
+.wall-item-wrapper {
+       margin-left:10px;
+}
+.wall-item-lock {
+       margin-top: 30px;
+       left: 105px;
+       position: absolute;
+       top: 1px;       
+}
+.comment .wall-item-lock {
+       margin-top: 0px;
+       left: 65px;
+}
+
+.wall-item-ago {
+       color: #888888;
+       font-size: 0.8em;
+}
+
+.wall-item-location {
+       overflow: hidden;
+       /* add ellipsis on text overflow               */
+       /* this work on safari, opera, ie, chrome.     */
+       /* firefox users have to wait support or we    */
+       /* can use a jquery plugin http://bit.ly/zJskg */
+       text-overflow: ellipsis;
+       -o-text-overflow: ellipsis;
+       width: 100%;
+}
+
+.wall-item-like-buttons {
+       float: left;
+       margin-right: 10px;
+}
+
+.like-rotator {
+       margin-left: 5px;
+}
+
+.wall-item-like-buttons > a,
+.wall-item-like-buttons > img {
+       float: left;
+}
+
+.wall-item-like-buttons img {
+       cursor: pointer;
+}
+
+.wall-item-share-buttons {
+       margin-left: 10px;
+       margin-right: 10px;
+}
+
+.editpost {
+       margin-left: 10px;
+       float: left;
+}
+.star-item {
+       margin-left: 10px;
+       float: left;    
+}
+.tag-item {
+       margin-left: 10px;
+       float: left;    
+}
+
+.filer-item {
+       margin-left: 10px;
+       float: left;
+}
+
+.wall-item-links-wrapper {
+       float: left;
+}
+
+.wall-item-delete-wrapper {
+       float: right;
+}
+
+.wall-item-delete-end {
+       clear: both;
+}
+
+.wall-item-delete-icon {
+       border: none;
+}
+
+
+.wall-item-wrapper-end {
+       clear: both;
+}
+.wall-item-name-link {
+       font-weight: bold;
+       text-decoration: none;
+       color: #3172BD;
+}
+.wall-item-photo {
+       border: none;
+}
+.comment .wall-item-photo {
+       width: 50px !important; 
+       height: 50px !important;
+       border-top-left-radius: 10px;
+}
+.wall-item-content {
+       float: left;
+       margin-left: 3px;
+/*     padding-right: 1em;
+       max-height: 500px;
+       overflow: auto;*/
+}
+
+.wall-item-content img {
+       max-width: 300px;
+       border-radius: 7px;
+       -moz-border-radius: 7px;
+       -webkit-border-radius: 7px;
+}
+
+
+
+.wall-item-title {
+       float: left;
+       font-weight: bold;
+       font-size: 1.6em; 
+       /*width: 450px;*/
+}
+
+.wall-item-title-end {
+       clear: both;
+}
+
+.wall-item-body {
+       text-align: justify;
+       float: left;
+       width: 300px;
+       overflow: hidden;
+       margin-top: 10px;
+       line-height: 23px;
+}
+
+.wall-item-body code {
+       overflow: hidden;
+}
+
+.comment .wall-item-body {
+       margin-left: 5px;
+       width: 280px;
+}
+
+.wall-item-tools {
+       clear: both;
+/*     background-image: url("head.jpg");
+       background-position: 0 -20px;
+       background-repeat: repeat-x;*/
+       padding: 5px 10px 0px;
+       height: 32px;
+}
+.wall-item-author {
+/*     margin-top: 10px;*/
+       margin-top: 0px;
+}
+
+.comment .wall-item-tools {
+/*     background:none;*/
+/*     background-image: url("head.jpg");
+       background-position: 0 -20px;
+       background-repeat: repeat-x;*/
+       border-bottom-left-radius: 10px;
+       border-bottom-right-radius: 10px;
+} 
+
+.comment-edit-wrapper {
+       margin-top: 15px;
+       background: #f3f3f3;
+       margin-left: 50px;
+}
+
+.comment-wwedit-wrapper {
+       margin-top: 15px;
+       background: #f3f3f3;
+       margin-left: 10px;
+       margin-right: 10px;
+}
+
+.comment-edit-photo {
+       margin-top: 15px;
+       margin-left: 10px;
+       margin-bottom: 10px;
+       width: 25px;
+       float: left;
+}
+.comment-edit-photo img {
+       width: 25px;
+}
+.comment-edit-text-empty, .comment-edit-text-full {
+/*     float: left;*/
+       -moz-border-radius: 3px;
+       -webkit-border-radius: 3px;
+       border-radius: 3px;     
+       border: 1px solid #cccccc;
+       padding: 3px 1px 1px 3px;
+}
+
+.comment-edit-text-empty {
+       color: gray;
+       height: 30px;
+       width: 175px;
+/*     overflow: auto;*/
+       margin-top: 40px;
+       margin-bottom: 10px;
+       margin-left: 20px;
+}
+
+.comment-edit-text-full {
+       color: black;
+       height: 150px;
+/*     width: 350px;
+       overflow: auto;*/
+       width: 190px;
+       margin-top: 15px;
+       margin-left: 20px;
+}
+
+.comment-edit-text-end {
+       clear: both;
+}
+
+.comment-edit-submit {
+       font-size: 18px;
+       padding: 5px 10px;
+       margin: 10px 0px 10px 110px;
+}
+
+#profile-jot-wrapper {
+       padding-left: 10px;
+}
+
+#profile-jot-plugin-wrapper,
+#profile-jot-submit-wrapper {
+       margin-top: 15px;
+}
+
+#profile-jot-submit {
+       float: left;
+       font-size: 18px;
+       padding: 5px 8px;
+}
+#profile-upload-wrapper {
+       float: left;
+       margin-left: 30px;
+}
+#profile-attach-wrapper {
+       float: left;
+       margin-left: 15px;
+}
+#profile-rotator {
+       float: left;
+       margin-left: 30px;
+}
+#profile-link-wrapper {
+       float: left;
+       margin-left: 15px;
+}
+#profile-youtube-wrapper {
+       float: left;
+       margin-left: 15px;
+}
+#profile-video-wrapper {
+       float: left;
+       margin-left: 15px;
+}
+#profile-audio-wrapper {
+       float: left;
+       margin-left: 15px;
+}
+#profile-location-wrapper {
+       float: left;
+       margin-left: 15px;
+}
+#jot-preview-link {
+       display: none;
+       float: left;
+       margin-left: 45px;
+       margin-top: 0px !important;
+}
+
+
+#profile-nolocation-wrapper {
+       float: left;
+       margin-left: 15px;
+}
+#profile-title-wrapper {
+       float: left;
+       margin-left: 15px;
+}
+
+#profile-jot-perms {
+       float: left;
+       margin-left: 40px;
+       font-weight: bold;
+       font-size: 1.2em;
+}
+
+
+#profile-jot-perms-end {
+       /*clear: left;*/
+       height: 30px;
+}
+
+#profile-jot-plugin-end{
+  clear: both;
+}
+.profile-jot-net {
+       float: left;
+       margin-right: 10px;
+       margin-top: 5px;
+       margin-bottom: 5px;
+}
+
+#profile-jot-networks-end {
+       clear: both;
+}
+
+.profile-jot-box {
+       margin-top: 50px;
+}
+.profile-edit-textarea {
+       margin-left: 20px;
+}
+
+#profile-jot-end {
+       /*clear: both;*/
+       margin-bottom: 30px;
+}
+#about-jot-submit-wrapper {
+       margin-top: 15px;
+}
+#about-jot-end {
+       margin-bottom: 30px;
+}
+#contacts-main {
+       margin-bottom: 30px;
+}
+
+#profile-listing-desc {
+       margin-left: 30px;
+}
+
+#profile-listing-new-link-wrapper {
+       margin-left: 30px;
+       margin-bottom: 30px;
+}
+.profile-listing-photo-wrapper {
+       float: left;
+}
+
+.profile-listing-edit-buttons-wrapper {
+       clear: both;
+}
+.profile-listing-photo-edit-link {
+       float: left;
+       width: 125px;
+}
+.profile-listing-end {
+       clear: both;
+}
+.profile-listing-edit-buttons-wrapper img{
+       border: none;
+       margin-right: 20px;
+}
+.profile-listing {
+       float: left;
+       margin-left: 30px;
+       margin-top: 25px;
+}
+.profile-listing-visible {
+       margin-left: 100px;
+}
+.profile-listing-name {
+       float: left;
+       margin-left: 12px;
+       margin-top: 10px;
+       color: #3172BD;
+       font-weight: bold;
+       width: 200px;
+
+}
+.fortune {
+       margin-top: 50px;
+       color: #4444FF;
+       font-weight: bold;
+       margin-bottom: 20px;
+}
+
+
+.directory-end {
+       clear: both;
+}
+.directory-name {
+       text-align: center;
+}
+.directory-photo {
+       margin-left: 15px;
+}
+.directory-details {
+       font-size: 0.7em;
+       text-align: center;
+       margin-left: 5px;
+       margin-right: 5px;
+}
+.directory-item {
+       float: left;
+/*     width: 225px;
+       height: 260px;*/
+       padding-left: 15px;
+       width: 130px;
+       height: 235px;
+       overflow: auto;
+}
+
+#directory-search-wrapper {
+       margin-top: 20px;
+       margin-right: 20px;
+       margin-bottom: 50px;
+}
+
+#directory-search-end {
+}
+
+.directory-photo-img {
+       width: 125px;
+       border: none;
+}
+
+
+.pager {
+  margin-top: 30px;
+  margin-right: auto;
+  margin-left: auto;
+
+  padding-top: 10px;
+  padding-bottom: 10px;
+  padding-left: 10px;
+  text-align: center;
+/*  line-height: 2.75em;*/
+}
+
+.pager a {
+       font-size: 1.5em;
+       padding: 0.2em 1em;
+       border: 1px solid #aaa;
+       border-radius: 10px;
+       -moz-border-radius: 10px;
+       -webkit-border-radius: 10px;
+}
+
+
+.pager_first,
+.pager_last,
+.pager_prev,
+.pager_next,
+.pager_n {
+/*     float: left;
+       border: 1px solid black;
+       border-radius: 7px;
+       background: #EEE;
+       text-align: center;
+       width: 50px;
+       margin-right: 5px;
+       margin-bottom: 10px;*/
+/*     float: left;*/
+       margin-right: 15px;
+       margin-left: 15px;
+}
+
+.pager_first,
+.pager_last,
+.pager_n {
+       display: none;
+}
+
+.pager_first a,
+.pager_last a,
+.pager_prev a,
+.pager_next a {
+/*     padding-top: 2px;
+       padding-bottom: 2px;
+       padding-left: 4px;
+       padding-right: 8px;*/
+       padding-top: 5px;
+       padding-bottom: 5px;
+       padding-left: 25px;
+       padding-right: 30px;
+
+       border: 2px solid #AAAAAA;
+       border-radius: 10px;
+       -moz-border-radius: 10px;
+       -webkit-border-radius: 10px;
+    font-size: 1.25em;
+       text-align: center;
+       text-decoration: none;
+}
+.pager_n a {
+       padding-top: 2px;
+       padding-bottom: 2px;
+       padding-left: 9px;
+       padding-right: 18px;
+       text-decoration: none;
+}
+
+.pager_current {
+       display: none;
+       float: left;
+       border: 1px solid black;
+       border-radius: 7px;
+       -moz-border-radius: 7px;
+       -webkit-border-radius: 7px;
+       background: #FFCCCC;
+       font-size: 1.25em;
+       text-align: center;
+       width: 50px;
+       margin-right: 5px;
+       margin-bottom: 10px;
+}
+
+
+#advanced-profile-name-wrapper,
+#advanced-profile-gender-wrapper,
+#advanced-profile-dob-wrapper,
+#advanced-profile-age-wrapper,
+#advanced-profile-marital-wrapper,
+#advanced-profile-sexual-wrapper,
+#advanced-profile-homepage-wrapper,
+#advanced-profile-politic-wrapper,
+#advanced-profile-religion-wrapper,
+#advanced-profile-about-wrapper,
+#advanced-profile-interest-wrapper,
+#advanced-profile-contact-wrapper,
+#advanced-profile-music-wrapper,
+#advanced-profile-book-wrapper,
+#advanced-profile-tv-wrapper,
+#advanced-profile-film-wrapper,
+#advanced-profile-romance-wrapper,
+#advanced-profile-work-wrapper,
+#advanced-profile-education-wrapper {
+       margin-top: 20px;
+}
+
+#advanced-profile-name-text,
+#advanced-profile-gender-text,
+#advanced-profile-dob-text,
+#advanced-profile-age-text,
+#advanced-profile-marital-text,
+#advanced-profile-sexual-text,
+#advanced-profile-homepage-text,
+#advanced-profile-politic-text,
+#advanced-profile-religion-text,
+#advanced-profile-about-text,
+#advanced-profile-interest-text,
+#advanced-profile-contact-text,
+#advanced-profile-music-text,
+#advanced-profile-book-text,
+#advanced-profile-tv-text,
+#advanced-profile-film-text,
+#advanced-profile-romance-text,
+#advanced-profile-work-text,
+#advanced-profile-education-text {
+       width: 300px;
+       float: left;
+}
+
+#advanced-profile-name-end,
+#advanced-profile-gender-end,
+#advanced-profile-dob-end,
+#advanced-profile-age-end,
+#advanced-profile-marital-end,
+#advanced-profile-sexual-end,
+#advanced-profile-homepage-end,
+#advanced-profile-politic-end,
+#advanced-profile-religion-end {
+       height: 10px;
+}
+
+#advanced-profile-about-end,
+#advanced-profile-interest-end,
+#advanced-profile-contact-end,
+#advanced-profile-music-end,
+#advanced-profile-book-end,
+#advanced-profile-tv-end,
+#advanced-profile-film-end,
+#advanced-profile-romance-end,
+#advanced-profile-work-end,
+#advanced-profile-education-end {
+
+
+}
+
+#advanced-profile-name,
+#advanced-profile-gender,
+#advanced-profile-dob,
+#advanced-profile-age,
+#advanced-profile-marital,
+#advanced-profile-sexual,
+#advanced-profile-homepage,
+#advanced-profile-politic,
+#advanced-profile-religion {
+       float: left;
+
+}
+
+
+#advanced-profile-about,
+#advanced-profile-interest,
+#advanced-profile-contact,
+#advanced-profile-music,
+#advanced-profile-book,
+#advanced-profile-tv,
+#advanced-profile-film,
+#advanced-profile-romance,
+#advanced-profile-work,
+#advanced-profile-education {
+       margin-top: 10px;
+       margin-left: 50px;
+       margin-right: 20px;
+       padding: 10px;
+       border: 1px solid #CCCCCC;
+}
+
+#advanced-profile-with {
+       float: left;
+       margin-left: 15px;
+}
+
+#contact-edit-wrapper {
+       margin-top: 10px;
+}
+
+#contact-edit-banner-name {
+       font-size: 1.4em;
+       font-weight: bold;
+}
+
+#contact-edit-poll-wrapper {
+       margin-top: 15px;
+}
+
+#contact-edit-poll-text {
+       margin-top: 15px;
+       margin-bottom: 5px;
+}
+
+#contact-edit-update-now {
+       margin-top: 15px;
+}
+
+#contact-edit-links{
+       clear: both;
+}
+
+#contact-edit-links ul {
+       list-style: none;
+       list-style-type: none;
+       margin-left: 0px;
+       padding-left: 0px;
+}
+
+#contact-edit-links li {
+       margin-top: 5px;
+}
+
+#contact-edit-drop-link {
+       float: right;
+       margin-right: 20px;
+}
+
+#contact-edit-nav-end {
+       clear: both;
+}
+
+#contact-edit-wrapper {
+       width: 100%;
+}
+
+#contact-edit-end {
+       clear: both;
+       margin-top: 15px;
+}
+
+#contact-profile-selector {
+       width: 175px;
+       margin-left: 175px;
+}
+
+.contact-edit-submit {
+       margin-top: 20px;
+}
+
+
+.contact-photo-menu-button {
+/*     position: absolute;
+       background-image: url("photo-menu.jpg");
+       background-position: top left; 
+       background-repeat: no-repeat;
+       margin: 0px; padding: 0px;
+       width: 16px;
+       height: 16px;
+       top: 64px; left:0px;
+       overflow: hidden;
+       text-indent: 40px;
+       display: none;*/
+       
+}
+.contact-photo-menu {
+       width: 130px;
+       border: 1px solid #AAA;
+       background: #FFFFFF;
+       position: absolute;
+       left: -30px; top: 80px;
+       display: none;
+       z-index: 10000;
+       -moz-box-shadow: 3px 3px 5px #555;
+       -webkit-box-shadow: 3px 3px 5px #555;
+       box-shadow: 3px 3px 5px #555;
+}
+.contact-photo-menu ul { margin:0px; padding: 0px; list-style: none }
+.contact-photo-menu li a { display: block; padding: 2px; }
+.contact-photo-menu li a:hover { color: #FFFFFF; background: #3465A4; text-decoration: none; }
+
+
+#block-message, #ignore-message, #archive-message, #lost-contact-message {
+       color: #FF0000;
+}
+
+#profile-edit-insecure {
+       margin-top: 20px;
+       color: #FF0000;
+       font-size: 1.1em;
+       border: 1px solid #FF8888;
+       background-color: #FFEEEE;
+       padding-left: 5px;
+       /*: 3px 3px 3px 5px; */
+       width: 587px;
+}
+
+#profile-jot-desc {
+       /*float: left;*/
+       width: 100%;
+       color: #FF0000;
+       margin-top: 10px;
+       margin-bottom: 10px;
+}
+
+#profile-jot-text {
+       width: 90%;
+       height: 20px;
+       color:#cccccc;
+       border: 1px solid #cccccc;
+       padding: 3px 0px 0px 5px;
+       -moz-border-radius: 3px;
+       -webkit-border-radius: 3px;
+       border-radius: 3px;     
+}
+
+
+/** acl **/
+#photo-edit-perms-select,
+#photos-upload-permissions-wrapper,
+#profile-jot-acl-wrapper{
+       display:block!important;
+}
+
+#photos-usage-message {
+       margin-bottom: 15px;
+}
+
+#profile-jot-acl-wrapper{
+       width:270px;
+       padding-left:10px;
+       height:auto;
+       overflow:visible;
+}
+
+#acl-wrapper {
+       width: 270px;
+       float:left;
+}
+#acl-search {
+       display: none;
+       float:right;
+       background: #ffffff url("../../../images/search_18.png") no-repeat right center;
+       padding-right:20px;
+}
+#acl-showall {
+       float: left;
+       display: block;
+       width: auto;
+       height: 18px;
+       background-color: #cccccc;
+       background-image: url("../../../images/show_all_off.png");
+       background-position: 7px 7px;
+       background-repeat: no-repeat;
+       padding: 7px 5px 0px 30px;
+       -webkit-border-radius: 5px ;
+       -moz-border-radius: 5px;
+       border-radius: 5px;
+       color: #999999;
+}
+#acl-showall.selected {
+       color: #000000;
+       background-color: #ff9900;
+       background-image: url("../../../images/show_all_on.png");
+}
+
+#acl-list {
+/*     height: 210px;*/
+       border: 1px solid #cccccc;
+       clear: both;
+       margin-top: 30px;
+       overflow: visible;
+}
+#acl-list-content {
+       
+}
+.acl-list-item {
+       display: block;
+       width: 120px;
+       height: 30px;
+       border: 1px solid #cccccc;
+       -moz-border-radius: 4px;
+       -webkit-border-radius: 4px;
+       border-radius: 4px;
+       margin-top: 5px;
+       margin-bottom: 5px;
+       margin-right: 2px;
+       margin-left: 2px;
+       padding-left: 5px;
+       float: left;
+}
+.acl-list-item img{
+       display: none;
+       width:22px;
+       height: 22px;
+       float: left;
+       margin: 4px;
+}
+.acl-list-item p { height: 12px; font-size: 10px; margin: 0px; padding: 2px 0px 1px; overflow: hidden;}
+.acl-list-item a { 
+       font-size: 8px;
+       display: block;
+       width: 40px;
+       height: 10px;
+       float: left;
+       color: #999999;
+       background-color: #cccccc;
+       background-position: 3px 3px;
+       background-repeat: no-repeat;
+       margin-right: 5px;
+       -webkit-border-radius: 2px ;
+       -moz-border-radius: 2px;
+       border-radius: 2px;
+       padding-left: 15px;
+}
+#acl-wrapper a:hover {
+       text-decoration: none;
+       color:#000000;
+}
+.acl-button-show { background-image: url("../../../images/show_off.png"); }
+.acl-button-hide { background-image: url("../../../images/hide_off.png"); }
+
+.acl-button-show.selected {
+       color: #000000;
+       background-color: #9ade00;
+       background-image: url("../../../images/show_on.png");
+}
+.acl-button-hide.selected {
+       color: #000000;
+       background-color: #ff4141;
+       background-image: url("../../../images/hide_on.png");
+}
+.acl-list-item.groupshow { border-color: #9ade00; }
+.acl-list-item.grouphide { border-color: #ff4141; }
+/** /acl **/
+
+
+#group-new-submit-wrapper {
+       margin-top: 30px;
+}
+
+#group-edit-name-label {
+       float: left;
+       width: 175px;
+       margin-top: 20px;
+       margin-bottom: 20px;
+}
+
+#group-edit-name {
+       float: left;
+       width: 225px;
+       margin-top: 20px;
+       margin-bottom: 20px;
+}
+
+#group-edit-name-wrapper {
+
+
+}
+
+
+#group_members_select_label {
+       display: block;
+       float: left;
+       width: 175px;
+}
+
+.group_members_select {
+       float: left;
+       width: 230px;
+       overflow: auto;
+}
+
+#group_members_select_end {
+       clear: both;
+}
+#group-edit-name-end {
+       clear: both;
+}
+
+#prvmail-to-label, #prvmail-subject-label, #prvmail-message-label {
+       margin-bottom: 10px;
+       margin-top: 20px;
+}
+
+#prvmail-submit {
+       float: left;
+       font-size: 18px;
+       padding: 0.25em 0.5em;
+       margin-top: 10px;
+       margin-right: 30px;
+}
+#prvmail-upload-wrapper,
+#prvmail-link-wrapper,
+#prvmail-rotator-wrapper {
+       float: left;
+       margin-top: 10px;
+       margin-right: 10px;
+       width: 24px;
+}
+
+#prvmail-end {
+       clear: both;
+}
+
+.mail-list-sender,
+.mail-list-detail {
+       float: left;
+}
+.mail-list-detail {
+       margin-left: 20px;
+}
+
+.mail-list-subject {
+       font-size: 1.1em;
+       margin-top: 10px;
+}
+a.mail-list-link {
+    display: block;
+    font-size: 1.3em;
+    padding: 4px 0;
+}
+
+/*
+*a.mail-list-link:hover {
+*      background-color: #15607B;
+*      color: #F5F6FB;
+*}
+*/
+
+.mail-list-outside-wrapper-end {
+       clear: both;
+}
+
+.mail-list-outside-wrapper {
+       margin-top: 30px;
+}
+
+.mail-list-delete-wrapper {
+       float: right;
+       margin-right: 30px;
+       margin-top: 15px;
+}
+
+.mail-list-delete-icon {
+       border: none;
+}
+
+.mail-conv-sender,
+.mail-conv-detail {
+       float: left;
+}
+.mail-conv-detail {
+       margin-left: 20px;
+       margin-bottom: 10px;
+       width: 270px;
+}
+
+.mail-conv-subject {
+    font-size: 1.4em;
+    margin: 10px 0;
+}
+
+.mail-conv-outside-wrapper-end {
+       clear: both;
+}
+
+.mail-conv-outside-wrapper {
+       margin-top: 30px;
+}
+
+.mail-conv-delete-wrapper {
+       float: right;
+       margin-right: 5px;
+       margin-top: 15px;
+}
+.mail-conv-break {
+       clear: both;
+}
+
+.mail-conv-delete-icon {
+       border: none;
+}
+
+.message-links ul {
+       list-style-type: none;
+       padding: 0px;
+}
+
+.message-links li {
+       margin-top: 10px;
+       float: left;
+}
+.message-links a {
+       padding: 3px 5px;
+}
+
+.message-links-end {
+       clear: both;
+}
+
+#sidebar-group-list ul {
+       list-style-type: none;
+}
+
+#sidebar-group-list .icon, #sidebar-group-list .iconspacer {
+       display: inline-block;
+       height: 12px;
+       width: 12px;
+}
+
+#sidebar-group-list li {
+       margin-top: 10px;
+}
+
+.nets-ul, .fileas-ul, .categories-ul {
+       list-style-type: none;
+}
+
+.nets-ul li, .fileas-ul li, .categories-ul li {
+       margin-top: 10px;
+}
+
+.nets-link {
+       margin-left: 24px;
+}
+.nets-all {
+       margin-left: 42px;
+}
+
+.fileas-link, .categories-link {
+       margin-left: 24px;
+}
+
+.fileas-all, .categories-all {
+       margin-left: 0px;
+}
+
+#search-save {
+       margin-left: 5px;
+}
+.groupsideedit {
+       margin-right: 10px;
+}
+#saved-search-ul {
+       list-style-type: none;
+}
+.savedsearchdrop, .savedsearchterm {
+       float: left;
+       margin-top: 10px;
+}
+.savedsearchterm {
+       margin-left: 10px;
+}
+
+
+#side-follow-wrapper {
+       margin-top: 20px;
+}
+#side-follow-url, #side-peoplefind-url {
+       margin-top: 5px;
+}
+#side-follow-submit, #side-peoplefind-submit {
+       margin-top: 15px;
+}
+
+#side-match-link {
+       margin-top: 10px;
+}
+
+aside input[type='text'] {
+ width: 174px;
+}
+
+.widget {
+       border: 1px solid #DDDDDD;
+       padding: 8px;
+       margin-top: 5px;
+       -moz-border-radius:5px;
+       -webkit-border-radius:5px;
+       border-radius:5px;
+
+}
+
+
+/*.photos {
+       height: auto;
+       overflow: auto;
+}*/
+
+.photos-end {
+       clear: both;
+       margin-bottom: 25px;
+}
+
+.photo-album-image-wrapper {
+       float: left;
+       margin-top: 15px;
+       margin-right: 15px;
+       margin-left: 15px;
+/*     width: 200px; height: 200px; 
+       overflow: hidden; 
+       position: relative; */
+}
+.photo-album-image-wrapper .caption {
+       display: none; 
+       width: 100%;
+/*     position: absolute; */
+       bottom: 0px; 
+       padding: 0.5em 0.5em 0px 0.5em;
+       background-color: rgba(245, 245, 255, 0.8);
+       border-bottom: 2px solid #CCC;
+       margin: 0px;
+}
+.photo-album-image-wrapper a:hover .caption {
+       display:block;
+}
+
+#photo-album-end {
+       clear: both;
+       margin-bottom: 25px;
+}
+
+.photo-top-image-wrapper {
+/*     position: relative; */
+       float: left;
+       margin-top: 15px;
+       margin-right: 15px;
+       margin-left: 15px;
+       margin-bottom: 15px;
+/*     width: 200px; height: 200px; 
+       overflow: hidden; */
+}
+.photo-top-image-wrapper img {
+       max-width: 290px;
+       border-radius: 10px;
+       -moz-border-radius: 10px;
+       -webkit-border-radius: 10px;
+}
+.photo-top-album-name {
+       width: 100%;
+       min-height: 2em;
+/*     position: absolute;  */
+       bottom: 0px; 
+       padding: 0px 3px;
+       padding-top: 0.5em;
+       background-color: rgb(255, 255, 255);
+}
+#photo-top-end {
+       clear: both;
+}
+
+#photo-top-links {
+       margin-bottom: 30px;
+       margin-left: 30px;
+}
+
+#photos-upload-newalbum-div {
+       float: left;
+       width: 175px;
+}
+
+#photos-upload-noshare {
+       margin-bottom: 10px;
+}
+#photos-upload-existing-album-text {
+       float: left;
+       width: 175px;
+}
+#photos-upload-newalbum {
+       float: left;
+}
+#photos-upload-album-select {
+       float: left;
+}
+
+#photos-upload-spacer {
+       margin-top: 25px;
+}
+#photos-upload-new-end, #photos-upload-exist-end {
+       clear: both;
+}
+#photos-upload-exist-end {
+       margin-bottom: 15px;
+}
+#photos-upload-submit {
+       margin-top: 15px;
+}
+
+#photos_upload_applet_wrapper {
+       margin-bottom: 15px;
+}
+
+#photos-upload-no-java-message {
+       margin-bottom: 15px;
+}
+
+#character-counter {
+       float: right;
+       font-size: 120%;
+}
+
+#character-counter.grey {
+       color: #888888;
+}
+
+#character-counter.orange {
+       color: orange;
+}
+#character-counter.red {
+       color: red;
+}
+
+#profile-jot-banner-end {
+       /* clear: both; */ 
+}
+
+#photos-upload-select-files-text {
+       margin-top: 15px;
+       margin-bottom: 15px;
+}
+
+#photos-upload-perms-menu, #photos-upload-perms-menu:visited, #photos-upload-perms-menu:link {
+       color: #8888FF;
+       text-decoration: none;
+       cursor: pointer;
+}
+
+#photos-upload-perms-menu:hover {
+       color: #0000FF;
+       text-decoration: underline;
+       cursor: pointer;
+}
+#settings-default-perms-menu {
+       margin-top: 15px;
+       margin-bottom: 15px;
+}
+
+#photo-edit-caption-label, #photo-edit-tags-label, #photo-edit-albumname-label, .photo-edit-rotate-label {
+       float: left;
+       width: 150px;
+}
+
+#photo-edit-caption-label, #photo-edit-tags-label, #photo-edit-albumname-label {
+       font-weight: 700;
+}
+
+#photos-upload-noshare-div {
+       margin-top: 140px;
+       margin-bottom: 15px;
+}
+
+#photos-upload-noshare-label {
+       margin-left: 25px;
+}
+
+#photos-upload-noshare {
+       float: left;
+}
+
+.photo-perms-icon {
+       float: left;
+}
+
+#photo-edit-perms-menu, #photos-upload-perms-menu, #settings-default-perms-menu {
+       text-decoration: none;
+}
+
+.photo-jot-perms-text {
+       padding-top: 5px;
+       padding-left: 40px;
+}
+
+#photo-edit-perms, #photos-upload-perms, #settings-default-perms {
+       margin-top: 30px;
+}
+#photos-upload-perms {
+       margin-top: 15px;
+       margin-left: 5px;
+}
+
+#photo-edit-perms-select, #photos-upload-permissions-wrapper, #settings-jot-acl-wrapper {
+       margin-top: 30px;
+       margin-left: 20px;
+}
+
+#advanced-expire-popup {
+       padding-left: 1em;
+       margin-top: 15px;
+       border: 1px solid #aaa;
+       border-radius: 10px;
+       -moz-border-radius: 10px;
+       -webkit-border-radius: 10px;
+}
+
+#photo-edit-perms-end {
+       margin-bottom: 15px;
+}
+
+#photo-edit-caption, #photo-edit-newtag, #photo-edit-albumname {
+       float: left;
+       margin-bottom: 25px;
+}
+
+.photo-edit-rotate {
+       float: left;
+       margin-left: 20px;
+}
+#photo-edit-link-wrap {
+       margin-bottom: 15px;
+}
+#photo-like-div {
+       margin-left: 15px;
+       margin-bottom: 65px;
+}
+
+#photo-edit-caption-end, #photo-edit-tags-end, #photo-edit-albumname-end, #photo-edit-rotate-end {
+       clear: both;
+}
+
+#photo-edit-rotate-end {
+       margin-bottom: 15px;
+}
+
+#photo-edit-submit-button, #photo-edit-delete-button, #photos-upload-submit {
+       margin-top: 30px;
+       padding: 0.25em 0.5em;
+       font-size: 18px;
+}
+#photo-edit-submit-button {
+       margin-left: 10px;
+}
+#photo-edit-delete-button {
+       margin-left: 45px;
+}
+#photos-upload-choose {
+       position: absolute;
+       top: 460px;
+       left: 5px;
+}
+#photos-upload-submit {
+       margin-top: 30px;
+       margin-left: 100px;
+       margin-bottom: 20px;
+}
+.settings-submit, .profile-edit-submit-button {
+       padding: 0.25em 0.5em;
+       margin-bottom: 10px;
+       font-size: 18px;
+}
+#photo-edit-end {
+       margin-bottom: 35px;
+}
+#photo-caption {
+       font-size: 110%;
+       font-weight: bold;
+       margin-top: 15px;
+       margin-bottom: 15px;
+}
+
+#in-this-photo-text {
+       color: #0000FF;
+       margin-left: 30px;
+}
+
+#in-this-photo {
+       margin-left: 60px;
+       margin-top: 10px;
+       margin-bottom: 20px;
+}
+
+#photo-album-edit-submit, #photo-album-edit-drop {
+       margin-top: 15px;
+       margin-bottom: 15px;
+}
+
+#photo-album-edit-drop {
+       margin-left: 200px;
+}
+
+.group-delete-wrapper {
+       float: right;
+       margin-right: 50px;
+}
+
+#install-dbhost-label,
+#install-dbuser-label,
+#install-dbpass-label,
+#install-dbdata-label,
+#install-tz-desc {
+       float: left;
+       width: 250px;
+       margin-top: 10px;
+       margin-bottom: 10px;
+
+}
+
+#install-dbhost,
+#install-dbuser,
+#install-dbpass,
+#install-dbdata {
+       float: left;
+       width: 200px;
+       margin-left: 20px;
+}
+
+#install-dbhost-end,
+#install-dbuser-end,
+#install-dbpass-end,
+#install-dbdata-end,
+#install-tz-end {
+       clear: both;
+}
+
+#install-form select#timezone_select {
+       float: left;
+       margin-top: 18px;
+       margin-left: 20px;
+}
+
+#dfrn-request-networks {
+       margin-bottom: 30px;
+}
+
+#pause {
+  position: fixed;
+  bottom: 5px;
+  right: 5px;
+}
+
+.sparkle {
+       cursor: url('lock.cur'), pointer;
+/*     cursor: pointer !important; */
+}
+
+.contact-block-div {
+       float: left;
+       width: 52px;
+       height: 52px;
+}
+.contact-block-textdiv {
+       float: left;
+       width: 150px;
+       height: 34px;
+}
+
+#contact-block-end {
+       clear: both;
+}
+.contact-block-link {
+       float: left;
+}
+.contact-block-img {
+       width:48px;
+       height:48px;
+}
+
+#tag-remove {
+       margin-bottom: 15px;
+}
+
+#tagrm li {
+       margin-bottom: 10px;
+}
+
+#tagrm-submit, #tagrm-cancel {
+       margin-top: 25px;
+}
+
+#tagrm-cancel {
+       margin-left: 15px;
+}
+
+.wall-item-conv {
+       margin-top: 5px;
+       margin-bottom: 25px;
+}
+
+#search-submit {
+       margin-left: 15px;
+}
+
+#search-box {
+       margin-bottom: 25px;
+}
+
+.location-label, .gender-label, .marital-label, .homepage-label {
+       float: left;
+       text-align: right;
+       display: block;
+       width: 65px;
+}
+
+.adr, .x-gender, .marital-text, .homepage-url {
+       float: left;
+       display: block;
+       margin-left: 8px;
+}
+
+.profile-clear {
+       clear: both;
+}
+
+
+.clear {
+       clear: both;
+}
+
+.cc-license {
+       margin-top: 50px;
+       font-size: 70%;
+}
+
+
+#plugin-settings-link, #account-settings-link {
+       margin-bottom: 10px;
+}
+
+#uexport-link {
+       margin-bottom: 20px;
+}
+
+/* end from default */
+       
+
+.fn {
+       padding: 0px 0px 5px 12px;
+       font-size: 120%;
+       font-weight: bold;
+}
+
+.vcard .title {
+       margin-bottom: 5px;
+       margin-left: 12px;
+}
+
+.vcard dl {
+       clear: both;
+}
+
+#birthday-title {
+       float: left;
+       font-weight: bold;      
+}
+
+#birthday-adjust {
+       float: left;
+       font-size: 75%;
+       margin-left: 10px;
+}
+
+#birthday-title-end {
+       clear: both;
+}
+
+.birthday-list {
+       margin-left: 15px;
+}
+
+#birthday-wrapper {
+       margin-bottom: 20px;
+}
+
+#network-new-link {
+       margin-top: 15px;
+       margin-bottom: 15px;
+}
+
+
+.tool-wrapper {
+  float: left;
+  margin-left: 15px;
+}
+
+.tool-link {
+  cursor: pointer;
+}
+
+.eventcal {
+       float: left;
+       font-size: 20px;
+}
+
+#event-summary-text {
+       margin-top: 15px;
+}
+
+#event-share-checkbox {
+       float: left;
+       margin-top: 10px;
+}
+
+#event-share-text {
+       float: left;
+       margin-top: 10px;
+       margin-left: 5px;
+}
+
+#event-share-break {
+       clear: both;
+       margin-bottom: 10px;
+}
+
+#event-summary {
+       width: 400px;
+}
+
+.vevent {
+       border: 1px solid #CCCCCC;
+}
+
+.vevent .event-summary {
+       margin-left: 10px;
+       margin-right: 10px;
+       font-weight: bold;
+}
+
+.vevent .event-description, .vevent .event-location {
+       margin-left: 10px;
+       margin-right: 10px;
+}
+.vevent .event-start {
+       margin-left: 10px;
+       margin-right: 10px;
+}
+
+#new-event-link {
+       margin-bottom: 10px;
+}
+
+.edit-event-link, .plink-event-link {
+       float: left;
+       margin-top: 4px;
+       margin-right: 4px;
+       margin-bottom: 15px;
+}
+
+.event-description:before {
+       content: url('../../../images/calendar.png');
+       margin-right: 15px;
+}
+
+.event-start, .event-end {
+       margin-left: 10px;
+       width: 330px;
+       clear: both;
+}
+
+.event-start .dtstart, .event-end .dtend {
+       float: right;
+}
+
+.event-list-date {
+       margin-bottom: 10px;
+}
+
+.prevcal, .nextcal {
+       float: left;
+       margin-left: 32px;
+       margin-right: 32px;
+       margin-top: 64px;
+}
+.event-calendar-end {
+       clear: both;
+}
+
+.calendar {
+       font-family: Courier, monospace;
+}
+.today {
+       font-weight: bold;
+       color: #FF0000;
+}
+
+.settings-block {
+       border: 1px solid #AAA;
+       margin: 10px;
+       padding: 10px;
+}
+
+.app-title {
+       margin: 10px;
+}
+
+#identity-manage-desc {
+       margin-top:15px;
+       margin-bottom: 15px;
+}
+
+#identity-manage-choose {
+       margin-bottom: 15px;
+}
+
+#identity-submit {
+       margin-top: 20px;
+}
+
+#photo-nav {
+       position: relative;
+       height: 55px;
+}
+
+#photo-prev-link {
+       position: absolute;
+       left: 5px;
+}
+#photo-next-link {
+       position: absolute;
+       right: 5px;
+}
+#photo-prev-link, #photo-next-link {
+       padding: 10px;
+/*     float: left;*/
+}
+
+/*#photo-photo {
+       float: left;
+}*/
+
+#photo-photo img {
+       max-width: 310px;
+}
+
+#photo-photo-end {
+       clear: both;
+}
+
+.profile-match-photo {
+       float: left;
+       text-align: center;
+       width: 120px;
+}
+
+.profile-match-name {
+       float: left;
+       text-align: center;
+       width: 120px;
+       overflow: hidden;
+}
+
+.profile-match-break,
+.profile-match-end {
+       clear: both;
+}
+
+.profile-match-connect {
+       text-align: center;
+       font-weight: bold;
+}
+
+.profile-match-wrapper {
+       float: left;
+       padding: 10px;
+       width: 120px;
+       height: 120px;
+       scroll: auto;
+}
+#profile-match-wrapper-end {
+       clear: both;
+}
+.side-link {
+       margin-bottom: 15px;
+}
+
+#language-selector {
+       position: absolute;
+       top: 0px;
+       left: 16px;
+}
+
+#group-members {
+       margin-top: 20px;
+       padding: 10px;
+       height: 250px;
+       overflow: auto;
+       border: 1px solid #ddd;
+}
+
+#group-members-end {
+       clear: both;
+}
+
+#group-separator {
+       margin-top: 10px;
+       margin-bottom: 10px;
+}
+
+#group-all-contacts {
+       padding: 10px;
+       height: 450px;
+       overflow: auto;
+       border: 1px solid #ddd;
+}
+
+#group-all-contacts-end {
+       clear: both;
+       margin-bottom: 10px;
+}
+
+#group-edit-desc {
+       margin-top: 15px;
+}
+
+
+#prof-members {
+       margin-top: 20px;
+       padding: 10px;
+       height: 250px;
+       overflow: auto;
+       border: 1px solid #ddd;
+}
+
+#prof-members-end {
+       clear: both;
+}
+
+#prof-separator {
+       margin-top: 10px;
+       margin-bottom: 10px;
+}
+
+#prof-all-contacts {
+       padding: 10px;
+       height: 450px;
+       overflow: auto;
+       border: 1px solid #ddd;
+}
+
+#prof-all-contacts-end {
+       clear: both;
+       margin-bottom: 10px;
+}
+
+#prof-edit-desc {
+       margin-top: 15px;
+}
+
+#crepair-name-label,
+#crepair-nick-label,
+#crepair-attag-label,
+#crepair-url-label,
+#crepair-request-label,
+#crepair-confirm-label,
+#crepair-notify-label,
+#crepair-photo-label,
+#crepair-poll-label {
+       float: left;
+       width: 200px;
+       margin-bottom: 15px;
+}
+
+#crepair-name,
+#crepair-nick,
+#crepair-attag,
+#crepair-url,
+#crepair-request,
+#crepair-confirm,
+#crepair-notify,
+#crepair-photo,
+#crepair-poll {
+       float: left;
+       width: 300px;
+}
+
+
+#netsearch-box {
+       margin-top: 20px;       
+}
+
+#netsearch-box #search-submit {
+       margin: 5px 0px 0px 0px;
+}
+
+.required {
+       color: #FF0000;
+}
+
+#event-start-text, #event-finish-text {
+       margin-top: 10px;
+       margin-bottom: 5px;
+}
+
+#event-nofinish-checkbox, #event-nofinish-text, #event-adjust-checkbox, #event-adjust-text {
+       float: left;
+}
+#event-datetime-break {
+       margin-bottom: 10px;
+}
+
+#event-nofinish-break, #event-adjust-break {
+       clear: both;
+}
+
+#event-desc-text, #event-location-text {
+       margin-top: 10px;
+       margin-bottom: 5px;
+}
+#event-submit {
+       margin-top: 10px;
+}
+
+.body-tag, .filesavetags, .categorytags {
+       opacity: 0.5;
+       filter:alpha(opacity=50);
+}
+
+.body-tag:hover, .filesavetags:hover, .categorytags:hover {
+       opacity: 1.0 !important;
+       filter:alpha(opacity=100) !important;
+}
+
+.item-select {
+       display: none;
+       opacity: 0.1;
+       filter:alpha(opacity=10);
+       float: right;
+       margin-right: 10px;
+
+}
+.item-select:hover, .checkeditem {
+       opacity: 1;
+       filter:alpha(opacity=100);
+}
+
+
+#item-delete-selected {
+       margin-top: 30px;
+}
+
+#item-delete-selected-end {
+       clear: both;
+}
+#item-delete-selected-icon, #item-delete-selected-desc {
+       float: left;
+       margin-right: 5px;
+}
+#item-delete-selected-desc:hover {
+       text-decoration: underline;
+}
+
+#lang-select-icon {
+       cursor: pointer;
+       position: fixed;
+       left: 0px;
+       top: 0px;
+       opacity: 0.2;
+       filter:alpha(opacity=20);
+}
+
+#lang-select-icon:hover {
+       opacity: 1;
+       filter:alpha(opacity=100);
+}
+
+.notif-image {
+       height: 80px;
+       width: 80px;
+       margin-right: 15px;
+}
+.notification-listing-end {
+       clear: both;
+       margin-bottom: 15px;
+}
+
+
+
+/**
+ * Plugins settings
+ */
+
+.settings-block > h3,
+.settings-heading {
+       border-bottom: 1px solid #babdb6;
+}
+
+/**
+ * Form fields
+ */
+.field {
+       margin-bottom: 10px;
+       padding-bottom: 10px;
+       overflow: auto;
+       width: 100%
+}
+
+.field label {
+       font-weight: 700;
+       float: left;
+       width: 200px;
+}
+
+.field input,
+.field textarea {
+       width: 270px;
+       margin-left: 20px;
+}
+.field textarea { height: 100px; }
+.field_help {
+       display: block;
+       margin-left: 20px;
+       color: #666666;
+       
+}
+
+
+.field .onoff {
+       float: left;
+       width: 80px;
+}
+.field .onoff a {
+       display: block;
+       border:1px solid #666666;
+       background-image:url("../../../images/onoff.jpg");
+       background-repeat: no-repeat;
+       padding: 4px 2px 2px 2px;
+       height: 16px;
+       text-decoration: none;
+}
+.field .onoff .off {
+       border-color:#666666;
+       padding-left: 40px;
+       background-position: left center;
+       background-color: #cccccc;
+       color: #666666;
+       text-align: right;
+}
+.field .onoff .on {
+       border-color:#204A87;
+       padding-right: 40px;
+       background-position: right center;
+       background-color: #D7E3F1;
+       color: #204A87;
+       text-align: left;
+}
+.hidden { display: none!important; }
+
+.field.radio .field_help { clear: left; margin-left: 20px; }
+
+/**
+ * ADMIN
+ */
+#pending-update {
+       float:right;
+       color: #ffffff;
+       font-weight: bold;
+       background-color: #FF0000;
+       padding: 0em 0.3em;
+       
+}
+#adminpage dl {
+       clear: left;
+       min-height: 40px;
+       margin-bottom: 2px;
+       padding-bottom: 2px;
+       border-bottom: 1px solid black;
+}
+#adminpage dt {
+       width: 180px;
+       float: left;
+       font-weight: bold;
+}
+#adminpage dd {
+       margin-left: 180px;
+}
+
+#adminpage h3 {
+       border-bottom: 1px solid #cccccc;
+}
+#adminpage .field label {
+       font-weight: bold;
+}
+#adminpage .submit {
+       clear:left;
+       text-align: right;
+}
+
+#adminpage #pluginslist {
+       margin: 0px; padding: 0px;
+}
+#adminpage .plugin {
+       list-style: none;
+       display: block;
+       border: 1px solid #888888;
+       padding: 1em;
+       margin-bottom: 5px;
+       clear: left;
+}
+#adminpage .plugin .desc { margin-left: 2.5em;}
+#adminpage .toggleplugin {
+       float:left;
+       margin-right: 1em;
+}
+
+#adminpage table {width:100%; border-bottom: 1px solid #000000; margin: 5px 0px;}
+#adminpage table th { text-align: left;}
+#adminpage td .icon { float: left;}
+#adminpage table#users img { width: 16px; height: 16px; }
+#adminpage table tr:hover { background-color: #bbc7d7; }
+#adminpage .selectall { text-align: right; }
+
+#cnftheme {
+       display: none;
+}
+
+/*
+ * UPDATE
+ */
+.popup {       
+       width: 100%; height: 100%;
+       top:0px; left:0px;
+       position: absolute;
+       display: none;
+}
+
+.popup .background {
+       background-color: rgba(0,0,0,128);
+       opacity: 0.5;
+       width: 100%; height: 100%;
+       position: absolute;
+       top:0px; left:0px;
+}
+.popup .panel {
+       top:25%;left:25%;width:50%;height:50%;
+       padding: 1em;
+       position: absolute;
+       border: 4px solid #000000;
+       background-color: #FFFFFF;
+}
+.popup .panel .panel_text { display: block; overflow: auto; height: 80%; } 
+.popup .panel .panel_in { width: 100%; height: 100%;   position: relative; }
+.popup .panel .panel_actions {  width: 100%; bottom: 4px; left: 0px; position: absolute; }
+.panel_text .progress { width: 50%; overflow: hidden; height: auto; border: 1px solid #cccccc; margin-bottom: 5px}
+.panel_text .progress span {float: right; display: block; width: 25%; background-color: #eeeeee; text-align: right;}
+
+/**
+ * OAuth
+ */
+.oauthapp {
+       height: auto; overflow: auto;
+       border-bottom: 2px solid #cccccc;
+       padding-bottom: 1em;
+       margin-bottom: 1em;     
+}
+.oauthapp img {
+       float: left;
+       width: 48px; height: 48px;
+       margin: 10px;
+}
+.oauthapp img.noicon {
+       background-image: url("../../../images/icons/48/plugin.png");
+       background-position: center center;
+       background-repeat: no-repeat;
+}
+.oauthapp a {
+       float: left;
+}
+
+/**
+ * ICONS
+ */
+.iconspacer {
+       display: block; width: 16px; height: 16px;
+}
+
+.icon {
+       display: block; width: 16px; height: 16px;
+       background-image: url('../../../images/icons.png');
+}
+.article { background-position: 0px 0px;}
+.audio { display: none; background-position: -16px 0px;}
+.block { background-position: -32px 0px;}
+/*.drop { background-position: -48px 0px;}
+.drophide { background-position: -64px 0px;}*/
+.icon.drop {
+       display: block; width: 28px; height: 28px;
+       background-size: 100% 100%;
+       background-image: url('images/drop-darkred.png');
+       background-repeat: no-repeat;
+}
+.icon.drophide {
+       display: block; width: 28px; height: 28px;
+       background-size: 100% 100%;
+       background-image: url('images/drop-darkred.png');
+       background-repeat: no-repeat;
+}
+.edit { background-position: -80px 0px;}
+/*.camera { background-position: -96px 0px;}*/
+.icon.camera {
+       display: block; width: 28px; height: 21px;
+       margin-top: 4px;
+       background-size: 100% 100%;
+       background-image: url('images/camera.png');
+       background-repeat: no-repeat;
+}
+/*.dislike { background-position: -112px 0px;}*/
+.icon.dislike {
+       display: block;
+       width: 26px; height: 28px;/*31 33*/
+       background-size: 100% 100%;
+       background-image: url('images/disapprove.png');
+       background-repeat: no-repeat;
+       opacity: 0.5;
+}
+/*.like { background-position: -128px 0px;}*/
+.icon.like {
+       display: block; width: 26px; height: 28px;/*31 33*/
+       margin-right: 7px;
+       background-size: 100% 100%;
+       background-image: url('images/approve.png');
+       background-repeat: no-repeat;
+       opacity: 0.5;
+}
+.link { display: none; background-position: -144px 0px;}
+
+/*.globe { background-position: 0px -16px;}*/
+.icon.globe {
+       display: block; width: 28px; height: 28px;
+       background-size: 100% 100%;
+       background-image: url('images/globe.png');
+       background-repeat: no-repeat;
+}
+.noglobe { background-position: -16px -16px;}
+.no { background-position: -32px -16px;}
+.pause { background-position: -48px -16px;}
+.play { background-position: -64px -16px;}
+/*.pencil { background-position: -80px -16px;}
+.small-pencil { background-position: -96px -16px;}*/
+.icon.pencil {
+       display: block; width: 28px; height: 28px;
+       background-size: 100% 100%;
+       background-image: url('images/pencil.png');
+       background-repeat: no-repeat;
+       opacity: 0.5;
+}
+.icon.small-pencil {
+       display: block; width: 28px; height: 28px;
+       background-size: 100% 100%;
+       background-image: url('images/pencil.png');
+       background-repeat: no-repeat;
+       opacity: 0.5;
+}
+/*.recycle { background-position: -112px -16px;}*/
+.icon.recycle {
+       display: block;
+       width: 28px; height: 27px;/*33 32*/
+       background-size: 100% 100%;
+       background-image: url('images/recycle.png');
+       background-repeat: no-repeat;
+       opacity: 0.5;
+}
+/*.remote-link { background-position: -128px -16px;}*/
+.icon.remote-link {
+/*     display: block;*/
+       display: none;
+       width: 28px; height: 28px;
+       background-size: 100% 100%;
+       background-image: url('images/remote-link.png');
+       background-repeat: no-repeat;
+       opacity: 0.5;
+}
+.share { background-position: -144px -16px;}
+
+.tools { background-position: 0px -32px;}
+/*.lock { background-position: -16px -32px;}*/
+.icon.lock {
+       display: block; width: 17px; height: 25px;
+       margin-top: 1px;
+       background-size: 100% 100%;
+       background-image: url('images/lock.png');
+       background-repeat: no-repeat;
+}
+/*.unlock { background-position: -32px -32px;}*/
+.icon.unlock {
+       display: block; width: 17px; height: 28px;
+       margin-top: -2px;
+       background-size: 100% 100%;
+       background-image: url('images/unlock.png');
+       background-repeat: no-repeat;
+}
+.video { display: none; background-position: -48px -32px;}
+.youtube { background-position: -64px -32px;}
+/*.attach { background-position: -80px -32px; }*/
+.icon.attach {
+       display: block; width: 28px; height: 28px;
+       background-size: 100% 100%;
+       background-image: url('images/paperclip.png');
+       background-repeat: no-repeat;
+}
+.language { background-position: -96px -32px; }
+.prev { background-position: -112px -32px; }
+.next { background-position: -128px -32px; }
+.on { background-position: -144px -32px; }
+
+.off { background-position: 0px -48px; }
+/*.starred { background-position: -16px -48px; }*/
+.icon.starred {
+       display: block; width: 28px; height: 28px;
+       background-size: 100% 100%;
+       background-image: url('images/star-yellow.png');
+       background-repeat: no-repeat;
+}
+/*.unstarred { background-position: -32px -48px; }*/
+.icon.unstarred {
+       display: block; width: 28px; height: 28px;
+       background-size: 100% 100%;
+       background-image: url('images/star.png');
+       background-repeat: no-repeat;
+       opacity: 0.5;
+}
+/*.tagged { background-position: -48px -48px; }*/
+.icon.tagged {
+       display: block; width: 28px; height: 28px;
+       background-size: 100% 100%;
+       background-image: url('images/tag.png');
+       background-repeat: no-repeat;
+       opacity: 0.5;
+}
+.yellow { background-position: -64px -48px; }
+
+
+.filer-icon {
+       display: block; width: 24px; height: 24px;
+       background-size: 100% 100%;
+       background-image: url('images/folder.png');
+       background-repeat: no-repeat;
+       opacity: 0.5;
+}
+
+.icon.dim { opacity: 0.3;filter:alpha(opacity=30); }
+
+[class^="comment-edit-bb"] {
+       list-style: none;
+       display: none;
+       margin: 0px 0 -5px 20px;
+       width: 75%;
+}
+[class^="comment-edit-bb"] > li {
+       display: inline-block;
+       margin: 20px 10px 0 0;
+       visibility: none;
+}
+[class^="comment-edit-bb-end"] {
+       clear: both;
+}
+.editicon {
+    display: inline-block;
+       background-size: 100% 100%;
+       background-repeat: no-repeat;
+       background-color: #f3f3f3;
+    text-decoration: none;
+}
+/*.editicon:hover {
+       background-color: #ccc;
+}*/
+.boldbb {
+/*     background-position: 0px 0px;*/
+       width: 26px; height: 28px;
+       background-image: url('images/boldB-serif.png');
+}
+/*.boldbb:hover {
+       background-position: 0px -16px;
+}*/
+.italicbb {
+/*     background-position: -16px 0px;*/
+       width: 16px; height: 28px;
+       background-image: url('images/italicI-serif.png');
+}
+/*.italicbb:hover {
+       background-position: -16px -16px;
+}*/
+.underlinebb {
+/*     background-position: -32px 0px;*/
+       width: 25px; height: 28px;
+       background-image: url('images/underlineU-serif.png');
+}
+/*.underlinebb:hover {
+       background-position: -32px -16px;
+}*/
+.quotebb {
+/*     background-position: -48px 0px;*/
+       width: 28px; height: 28px;
+       background-image: url('images/quote.png');
+}
+/*.quotebb:hover {
+       background-position: -48px -16px;
+}*/
+.codebb {
+/*     background-position: -64px 0px;*/
+       width: 28px; height: 28px;
+       background-image: url('images/code.png');
+}
+/*.codebb:hover {
+       background-position: -64px -16px;
+}*/
+.imagebb {
+       background-position: -80px 0px;
+}
+.imagebb:hover {
+       background-position: -80px -16px;
+}
+.urlbb {
+       background-position: -96px 0px;
+}
+.urlbb:hover {
+       background-position: -96px -16px;
+}
+.videobb {
+       background-position: -112px 0px;
+}
+.videobb:hover {
+       background-position: -112px -16px;
+}
+
+.attachtype {
+       display: block; width: 20px; height: 23px;
+       float: left;
+       background-image: url('../../../images/content-types.png');
+}
+
+.body-attach {
+       margin-top: 10px;
+}
+
+.type-video { background-position: 0px 0px; }
+.type-image { background-position: -20px 0px; }
+.type-audio { background-position: -40px 0px; }
+.type-text  { background-position: -60px 0px; }
+.type-unkn  { background-position: -80px 0px; }
+
+
+/* autocomplete popup */
+.acpopup {
+       max-height:150px;
+       background-color:#ffffff;
+       overflow:auto;
+       z-index:100000;
+       border:1px solid #cccccc;
+}
+.acpopupitem {
+       background-color:#ffffff; padding: 4px;
+       clear:left;
+}
+.acpopupitem img {
+       float: left;
+       margin-right: 4px;
+}
+
+.acpopupitem.selected {
+       color: #FFFFFF; background: #3465A4;
+}
+
+/* popup notifications */
+div.jGrowl div.notice {
+  background: #511919 url("../../../images/icons/48/notice.png") no-repeat 5px center;
+  color: #ffffff;
+  padding-left: 58px;
+}
+div.jGrowl div.info {
+  background: #364e59 url("../../../images/icons/48/info.png") no-repeat 5px center;
+  color: #ffffff;
+  padding-left: 58px;
+}
+#jGrowl.top-right {
+       top: 15px;
+       right: 15px;
+}
+.qcomment {
+       border: 1px solid #EEE;
+       padding: 3px;
+       margin-top: 15px;
+       margin-left: 25px;
+       width: 125px;
+       overflow-y: auto;
+}
+
+
+.qcomment option {
+       width: 125px;
+       overflow-x: hidden;
+}
+
+.qcomment {
+       opacity: 0.3;
+       filter:alpha(opacity=30);
+}
+.qcomment:hover {
+       opacity: 1.0;
+       filter:alpha(opacity=100);
+}
+
+/* notifications popup menu */
+.nav-notify {
+       display: none;
+       position: absolute;
+       font-size: 10px;
+       padding: 1px 3px;
+       top: 0px;
+       right: -10px;
+       min-width: 15px;
+       text-align: right;
+}
+.nav-notify.show {
+       display: block;
+}
+ul.notifications-menu-popup {
+       position: absolute;
+       display: none;
+       width: 10em;
+       margin: 0px;
+       padding: 0px;
+       list-style: none;
+       z-index: 100000;
+       right: -55px;
+}
+#nav-notifications-menu {
+       width: 300px;
+/*     max-height: 400px;*/
+       height: auto;
+       overflow-y: scroll;overflow-style:scrollbar;
+       background-color:#FFFFFF;
+       -moz-border-radius: 5px;
+       -webkit-border-radius: 5px;
+       border-radius:5px;
+       border: 1px solid #AAA;
+       -moz-box-shadow: 3px 3px 5px #555;
+       -webkit-box-shadow: 3px 3px 5px #555;
+       box-shadow: 3px 3px 5px #555;
+}
+#nav-notifications-menu .contactname { font-weight: bold; font-size: 0.9em; }
+#nav-notifications-menu img { float: left; margin-right: 5px; }
+#nav-notifications-menu .notif-when { font-size: 0.8em; display: block; }
+#nav-notifications-menu li {
+       padding: 7px 0px 7px 10px;
+       word-wrap:normal;
+       border-bottom: 1px solid #000;
+}
+
+#nav-notifications-menu li:hover {
+
+}
+
+#nav-notifications-menu a:hover {
+       text-decoration: underline;
+}
+
+.notif-item a {
+       color: #000000;
+}
+
+.notif-item a:hover {
+       text-decoration: underline;
+}
+
+.notif-image {
+       width: 32px;
+       height: 32px;
+       padding: 7px 7px 0px 0px;
+}
+
+.notify-seen {
+       background: #DDDDDD;
+}
+
+#id_term_label {
+       width:75px;
+}
+#id_term {
+       width:100px;
+}
+
+#recip {
+       
+}
+.autocomplete-w1 { background: #ffffff; no-repeat bottom right; position:absolute; top:0px; left:0px; margin:6px 0 0 6px; /* IE6 fix: */ _background:none; _margin:1px 0 0 0; }
+.autocomplete { color:#000; border:1px solid #999; background:#FFF; cursor:default; text-align:left; max-height:350px; overflow:auto; margin:-6px 6px 6px -6px; /* IE6 specific: */ _height:350px;  _margin:0; _overflow-x:hidden; }
+.autocomplete .selected { background:#F0F0F0; }
+.autocomplete div { padding:2px 5px; white-space:nowrap; overflow:hidden; }
+
+#datebrowse-sidebar select {
+       margin-left: 40px;
+       width: 130px;
+}
diff --git a/view/theme/frost-mobile/theme.php b/view/theme/frost-mobile/theme.php
new file mode 100644 (file)
index 0000000..581c351
--- /dev/null
@@ -0,0 +1,23 @@
+<?php
+
+/*
+ * Name: Frost--mobile version
+ * Description: Like frosted glass
+ * Credits: Navigation icons taken from http://iconza.com. Other icons taken from http://thenounproject.com, including: Like, Dislike, Black Lock, Unlock, Pencil, Tag, Camera, Paperclip (Marie Coons), Folder (Sergio Calcara), Chain-link (Andrew Fortnum), Speaker (Harold Kim), Quotes (Henry Ryder), Video Camera (Anas Ramadan), and Left Arrow, Right Arrow, and Delete X (all three P.J. Onori). All under Attribution (CC BY 3.0). Others from The Noun Project are public domain or No Rights Reserved (CC0).
+ * Version: Version 0.1
+ * Author: Zach P <windforest@f.shmuz.in>
+ * Maintainer: Zach P <windforest@f.shmuz.in>
+ */
+
+$a->theme_info = array();
+
+function frost_mobile_init(&$a) {
+
+       // I could do this in style.php, but by having the CSS in a file the browser will cache it,
+       // making pages load faster
+       if( $a->module === 'home' || $a->module === 'login' || $a->module === 'register' || $a->module === 'lostpass' ) {
+               $a->page['htmlhead'] = str_replace('$stylesheet', $a->get_baseurl() . '/view/theme/frost-mobile/login-style.css', $a->page['htmlhead']);
+
+       }
+
+}
diff --git a/view/theme/frost-mobile/wall_item.tpl b/view/theme/frost-mobile/wall_item.tpl
new file mode 100644 (file)
index 0000000..65e2812
--- /dev/null
@@ -0,0 +1,82 @@
+<a name="$item.id" ></a>
+<div class="wall-item-outside-wrapper$item.indent$item.previewing" id="wall-item-outside-wrapper-$item.id" >
+       <div class="wall-item-content-wrapper$item.indent" id="wall-item-content-wrapper-$item.id" >
+               <div class="wall-item-info" id="wall-item-info-$item.id">
+<!--                   <div class="wall-item-photo-wrapper" id="wall-item-photo-wrapper-$item.id" 
+                                onmouseover="if (typeof t$item.id != 'undefined') clearTimeout(t$item.id); openMenu('wall-item-photo-menu-button-$item.id')" 
+                                onmouseout="t$item.id=setTimeout('closeMenu(\'wall-item-photo-menu-button-$item.id\'); closeMenu(\'wall-item-photo-menu-$item.id\');',200)">-->
+                       <div class="wall-item-photo-wrapper" id="wall-item-photo-wrapper-$item.id">
+                               <a href="$item.profile_url" target="redir" title="$item.linktitle" class="wall-item-photo-link" id="wall-item-photo-link-$item.id">
+                                       <img src="$item.thumb" class="wall-item-photo$item.sparkle" id="wall-item-photo-$item.id" style="height: 80px; width: 80px;" alt="$item.name" />
+                               </a>
+                               <!--<span onclick="openClose('wall-item-photo-menu-$item.id');" class="fakelink wall-item-photo-menu-button" id="wall-item-photo-menu-button-$item.id">menu</span>
+                               <div class="wall-item-photo-menu" id="wall-item-photo-menu-$item.id">
+                                       <ul>
+                                               $item.item_photo_menu
+                                       </ul>
+                               </div>-->
+                       </div>
+                       <div class="wall-item-photo-end"></div>
+                       <div class="wall-item-wrapper" id="wall-item-wrapper-$item.id" >
+                               {{ if $item.lock }}<div class="wall-item-lock"><img src="images/lock_icon.gif" class="lockview" alt="$item.lock" onclick="lockview(event,$item.id);" /></div>
+                               {{ else }}<div class="wall-item-lock"></div>{{ endif }} 
+                               <div class="wall-item-location" id="wall-item-location-$item.id">$item.location</div>                           
+                       </div>
+               </div>
+               <div class="wall-item-author">
+                               <a href="$item.profile_url" target="redir" title="$item.linktitle" class="wall-item-name-link"><span class="wall-item-name$item.sparkle" id="wall-item-name-$item.id" >$item.name</span></a>
+                               <div class="wall-item-ago"  id="wall-item-ago-$item.id">$item.ago</div>
+                               
+               </div>
+               <br />
+
+               <div class="wall-item-content" id="wall-item-content-$item.id" >
+                       <div class="wall-item-title" id="wall-item-title-$item.id">$item.title</div>
+                       <div class="wall-item-title-end"></div>
+                       <div class="wall-item-body" id="wall-item-body-$item.id" >$item.body
+                                       <div class="body-tag">
+                                               {{ for $item.tags as $tag }}
+                                                       <span class='tag'>$tag</span>
+                                               {{ endfor }}
+                                       </div>
+                       </div>
+               </div>
+               <div class="wall-item-tools" id="wall-item-tools-$item.id">
+                       {{ if $item.vote }}
+                       <div class="wall-item-like-buttons" id="wall-item-like-buttons-$item.id">
+                               <a href="#" class="icon like" title="$item.vote.like.0" onclick="dolike($item.id,'like'); return false"></a>
+                               <a href="#" class="icon dislike" title="$item.vote.dislike.0" onclick="dolike($item.id,'dislike'); return false"></a>
+                               {{ if $item.vote.share }}<a href="#" class="icon recycle wall-item-share-buttons" title="$item.vote.share.0" onclick="jotShare($item.id); return false"></a>{{ endif }}
+                               <img id="like-rotator-$item.id" class="like-rotator" src="images/rotator.gif" alt="$item.wait" title="$item.wait" style="display: none;" />
+                       </div>
+                       {{ endif }}
+                       {{ if $item.plink }}
+                               <div class="wall-item-links-wrapper"><a href="$item.plink.href" title="$item.plink.title" target="external-link" class="icon remote-link$item.sparkle"></a></div>
+                       {{ endif }}
+                       {{ if $item.edpost }}
+                               <a class="editpost icon pencil" href="$item.edpost.0" title="$item.edpost.1"></a>
+                       {{ endif }}
+                        
+                       {{ if $item.star }}
+                       <a href="#" id="starred-$item.id" onclick="dostar($item.id); return false;" class="star-item icon $item.isstarred" title="$item.star.toggle"></a>
+                       <a href="#" id="tagger-$item.id" onclick="itemTag($item.id); return false;" class="tag-item icon tagged" title="$item.star.tagger"></a>
+                       {{ endif }}
+                       {{ if $item.filer }}
+                       <a href="#" id="filer-$item.id" onclick="itemFiler($item.id); return false;" class="filer-item filer-icon" title="$item.filer"></a>
+                       {{ endif }}                     
+                       <div class="wall-item-delete-wrapper" id="wall-item-delete-wrapper-$item.id" >
+                               {{ if $item.drop.dropping }}<a href="item/drop/$item.id" onclick="return confirmDelete();" class="icon drophide" title="$item.drop.delete" onmouseover="imgbright(this);" onmouseout="imgdull(this);" ></a>{{ endif }}
+                       </div>
+                               {{ if $item.drop.dropping }}<input type="checkbox" onclick="checkboxhighlight(this);" title="$item.drop.select" class="item-select" name="itemselected[]" value="$item.id" />{{ endif }}
+                       <div class="wall-item-delete-end"></div>
+               </div>
+       </div>
+       <div class="wall-item-wrapper-end"></div>
+       <div class="wall-item-like $item.indent" id="wall-item-like-$item.id">$item.like</div>
+       <div class="wall-item-dislike $item.indent" id="wall-item-dislike-$item.id">$item.dislike</div>
+       <div class="wall-item-comment-wrapper" >
+       $item.comment
+       </div>
+
+<div class="wall-item-outside-wrapper-end$item.indent" ></div>
+</div>
diff --git a/view/theme/frost-mobile/wallmsg-header.tpl b/view/theme/frost-mobile/wallmsg-header.tpl
new file mode 100644 (file)
index 0000000..4f184d3
--- /dev/null
@@ -0,0 +1,82 @@
+<!--
+<script language="javascript" type="text/javascript" src="$baseurl/library/tinymce/jscripts/tiny_mce/tiny_mce_src.js"></script>
+<script language="javascript" type="text/javascript">
+
+var plaintext = '$editselect';
+
+if(plaintext != 'none') {
+       tinyMCE.init({
+               theme : "advanced",
+               mode : "specific_textareas",
+               editor_selector: /(profile-jot-text|prvmail-text)/,
+               plugins : "bbcode,paste",
+               theme_advanced_buttons1 : "bold,italic,underline,undo,redo,link,unlink,image,forecolor",
+               theme_advanced_buttons2 : "",
+               theme_advanced_buttons3 : "",
+               theme_advanced_toolbar_location : "top",
+               theme_advanced_toolbar_align : "center",
+               theme_advanced_blockformats : "blockquote,code",
+               gecko_spellcheck : true,
+               paste_text_sticky : true,
+               entity_encoding : "raw",
+               add_unload_trigger : false,
+               remove_linebreaks : false,
+               force_p_newlines : false,
+               force_br_newlines : true,
+               forced_root_block : '',
+               convert_urls: false,
+               content_css: "$baseurl/view/custom_tinymce.css",
+                    //Character count
+               theme_advanced_path : false,
+               setup : function(ed) {
+                       ed.onInit.add(function(ed) {
+                               ed.pasteAsPlainText = true;
+                               var editorId = ed.editorId;
+                               var textarea = $('#'+editorId);
+                               if (typeof(textarea.attr('tabindex')) != "undefined") {
+                                       $('#'+editorId+'_ifr').attr('tabindex', textarea.attr('tabindex'));
+                                       textarea.attr('tabindex', null);
+                               }
+                       });
+               }
+       });
+}
+else
+       $("#prvmail-text").contact_autocomplete(baseurl+"/acl");
+
+
+</script>
+<script>
+
+       function jotGetLink() {
+               reply = prompt("$linkurl");
+               if(reply && reply.length) {
+                       $('#profile-rotator').show();
+                       $.get('parse_url?url=' + reply, function(data) {
+                               tinyMCE.execCommand('mceInsertRawHTML',false,data);
+                               $('#profile-rotator').hide();
+                       });
+               }
+       }
+
+       function linkdropper(event) {
+               var linkFound = event.dataTransfer.types.contains("text/uri-list");
+               if(linkFound)
+                       event.preventDefault();
+       }
+
+       function linkdrop(event) {
+               var reply = event.dataTransfer.getData("text/uri-list");
+               event.target.textContent = reply;
+               event.preventDefault();
+               if(reply && reply.length) {
+                       $('#profile-rotator').show();
+                       $.get('parse_url?url=' + reply, function(data) {
+                               tinyMCE.execCommand('mceInsertRawHTML',false,data);
+                               $('#profile-rotator').hide();
+                       });
+               }
+       }
+
+</script>
+-->