]> git.mxchange.org Git - friendica.git/commitdiff
Vier - mobile friendly ACL window and form fields
authorFabrixxm <fabrix.xm@gmail.com>
Wed, 3 Feb 2016 13:03:00 +0000 (14:03 +0100)
committerFabrixxm <fabrix.xm@gmail.com>
Wed, 3 Feb 2016 13:03:00 +0000 (14:03 +0100)
js/acl.js
js/main.js
view/templates/acl_selector.tpl
view/templates/jot-header.tpl
view/theme/vier/mobile.css

index 487ffafc770032578f1437bd84db44e9b39c77c8..8e4e06c83c4b6fab45de46e73f3585512d788088 100644 (file)
--- a/js/acl.js
+++ b/js/acl.js
@@ -1,49 +1,56 @@
-function ACL(backend_url, preset, automention){
-       that = this;
+function ACL(backend_url, preset, automention, is_mobile){
        
-       that.url = backend_url;
-       that.automention = automention;
+       this.url = backend_url;
+       this.automention = automention;
+       this.is_mobile = is_mobile;
        
-       that.kp_timer = null;
+       
+       this.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 = 4; //items per row. should be calulated from #acl-list.width
+       this.allow_cid = (preset[0] || []);
+       this.allow_gid = (preset[1] || []);
+       this.deny_cid  = (preset[2] || []);
+       this.deny_gid  = (preset[3] || []);
+       this.group_uids = [];
+
+       if (this.is_mobile) {
+               this.nw = 1;
+       } else {
+               this.nw = 4;
+       }
        
-       that.list_content = $("#acl-list-content");
-       that.item_tpl = unescape($(".acl-list-item[rel=acl-template]").html());
-       that.showall = $("#acl-showall");
+       
+       this.list_content = $("#acl-list-content");
+       this.item_tpl = unescape($(".acl-list-item[rel=acl-template]").html());
+       this.showall = $("#acl-showall");
 
-       if (preset.length==0) that.showall.addClass("selected");
+       if (preset.length==0) this.showall.addClass("selected");
        
        /*events*/
-       that.showall.click(that.on_showall);
-       $(document).on("click", ".acl-button-show", that.on_button_show);
-       $(document).on("click", ".acl-button-hide", that.on_button_hide);
-       $("#acl-search").keypress(that.on_search);
-       $("#acl-wrapper").parents("form").submit(that.on_submit);
+       this.showall.click(this.on_showall);
+       $(document).on("click", ".acl-button-show", this.on_button_show.bind(this));
+       $(document).on("click", ".acl-button-hide", this.on_button_hide.bind(this));
+       $("#acl-search").keypress(this.on_search.bind(this));
+       $("#acl-wrapper").parents("form").submit(this.on_submit.bind(this));
        
        /* add/remove mentions  */
-       that.element = $("#profile-jot-text");
-       that.htmlelm = that.element.get()[0];
+       this.element = $("#profile-jot-text");
+       this.htmlelm = this.element.get()[0];
        
        /* startup! */
-       that.get(0,100);
+       this.get(0,100);
 }
 
 ACL.prototype.remove_mention = function(id) {
-       if (!that.automention) return;
-       var nick = that.data[id].nick;
+       if (!this.automention) return;
+       var nick = this.data[id].nick;
        var searchText = "@"+nick+"+"+id+" ";
        if (tinyMCE.activeEditor===null) {
-               start = that.element.val().indexOf(searchText); 
+               start = this.element.val().indexOf(searchText); 
                if ( start<0) return;
                end = start+searchText.length;
-               that.element.setSelection(start,end).replaceSelectedText('').collapseSelection(false);
+               this.element.setSelection(start,end).replaceSelectedText('').collapseSelection(false);
        } else {
                start =  tinyMCE.activeEditor.getContent({format : 'raw'}).search( searchText );
                if ( start<0 ) return;
@@ -54,12 +61,12 @@ ACL.prototype.remove_mention = function(id) {
 }
 
 ACL.prototype.add_mention = function(id) {
-       if (!that.automention) return;
-       var nick = that.data[id].nick;
+       if (!this.automention) return;
+       var nick = this.data[id].nick;
        var searchText =  "@"+nick+"+"+id+" ";
        if (tinyMCE.activeEditor===null) {
-               if ( that.element.val().indexOf( searchText) >= 0 ) return;
-               that.element.val( searchText + that.element.val() );
+               if ( this.element.val().indexOf( searchText) >= 0 ) return;
+               this.element.val( searchText + this.element.val() );
        } else {
                if ( tinyMCE.activeEditor.getContent({format : 'raw'}).search(searchText) >= 0 ) return;
                tinyMCE.activeEditor.dom.add(tinyMCE.activeEditor.getBody(), 'dummy', {}, searchText);
@@ -68,46 +75,46 @@ ACL.prototype.add_mention = function(id) {
 
 ACL.prototype.on_submit = function(){
        aclfileds = $("#acl-fields").html("");
-       $(that.allow_gid).each(function(i,v){
+       $(this.allow_gid).each(function(i,v){
                aclfileds.append("<input type='hidden' name='group_allow[]' value='"+v+"'>");
        });
-       $(that.allow_cid).each(function(i,v){
+       $(this.allow_cid).each(function(i,v){
                aclfileds.append("<input type='hidden' name='contact_allow[]' value='"+v+"'>");
        });
-       $(that.deny_gid).each(function(i,v){
+       $(this.deny_gid).each(function(i,v){
                aclfileds.append("<input type='hidden' name='group_deny[]' value='"+v+"'>");
        });
-       $(that.deny_cid).each(function(i,v){
+       $(this.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);
+       this.list_content.html("");
+       this.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);
+       if (this.kp_timer) clearTimeout(this.kp_timer);
+       this.kp_timer = setTimeout( this.search.bind(this), 1000);
 }
 
 ACL.prototype.on_showall = function(event){
        event.preventDefault()
        event.stopPropagation();
        
-       if (that.showall.hasClass("selected")){
+       if (this.showall.hasClass("selected")){
                return false;
        }
-       that.showall.addClass("selected");
+       this.showall.addClass("selected");
        
-       that.allow_cid = [];
-       that.allow_gid = [];
-       that.deny_cid  = [];
-       that.deny_gid  = [];
+       this.allow_cid = [];
+       this.allow_gid = [];
+       this.deny_cid  = [];
+       this.deny_gid  = [];
        
-       that.update_view();
+       this.update_view();
        
        return false;
 }
@@ -117,11 +124,11 @@ ACL.prototype.on_button_show = function(event){
        event.stopImmediatePropagation()
        event.stopPropagation();
 
-       /*that.showall.removeClass("selected");
+       /*this.showall.removeClass("selected");
        $(this).siblings(".acl-button-hide").removeClass("selected");
        $(this).toggleClass("selected");*/
 
-       that.set_allow($(this).parent().attr('id'));
+       this.set_allow($(this).parent().attr('id'));
 
        return false;
 }
@@ -130,11 +137,11 @@ ACL.prototype.on_button_hide = function(event){
        event.stopImmediatePropagation()
        event.stopPropagation();
 
-       /*that.showall.removeClass("selected");
+       /*this.showall.removeClass("selected");
        $(this).siblings(".acl-button-show").removeClass("selected");
        $(this).toggleClass("selected");*/
 
-       that.set_deny($(this).parent().attr('id'));
+       this.set_deny($(this).parent().attr('id'));
 
        return false;
 }
@@ -145,25 +152,25 @@ ACL.prototype.set_allow = function(itemid){
        
        switch(type){
                case "g":
-                       if (that.allow_gid.indexOf(id)<0){
-                               that.allow_gid.push(id)
+                       if (this.allow_gid.indexOf(id)<0){
+                               this.allow_gid.push(id)
                        }else {
-                               that.allow_gid.remove(id);
+                               this.allow_gid.remove(id);
                        }
-                       if (that.deny_gid.indexOf(id)>=0) that.deny_gid.remove(id);
+                       if (this.deny_gid.indexOf(id)>=0) this.deny_gid.remove(id);
                        break;
                case "c":
-                       if (that.allow_cid.indexOf(id)<0){
-                               that.allow_cid.push(id)
-                               if (that.data[id].forum=="1") that.add_mention(id);
+                       if (this.allow_cid.indexOf(id)<0){
+                               this.allow_cid.push(id)
+                               if (this.data[id].forum=="1") this.add_mention(id);
                        } else {
-                               that.allow_cid.remove(id);
-                               if (that.data[id].forum=="1") that.remove_mention(id);
+                               this.allow_cid.remove(id);
+                               if (this.data[id].forum=="1") this.remove_mention(id);
                        }
-                       if (that.deny_cid.indexOf(id)>=0) that.deny_cid.remove(id);                     
+                       if (this.deny_cid.indexOf(id)>=0) this.deny_cid.remove(id);                     
                        break;
        }
-       that.update_view();
+       this.update_view();
 }
 
 ACL.prototype.set_deny = function(itemid){
@@ -172,34 +179,34 @@ ACL.prototype.set_deny = function(itemid){
        
        switch(type){
                case "g":
-                       if (that.deny_gid.indexOf(id)<0){
-                               that.deny_gid.push(id)
+                       if (this.deny_gid.indexOf(id)<0){
+                               this.deny_gid.push(id)
                        } else {
-                               that.deny_gid.remove(id);
+                               this.deny_gid.remove(id);
                        }
-                       if (that.allow_gid.indexOf(id)>=0) that.allow_gid.remove(id);
+                       if (this.allow_gid.indexOf(id)>=0) this.allow_gid.remove(id);
                        break;
                case "c":
-                       if (that.data[id].forum=="1") that.remove_mention(id);
-                       if (that.deny_cid.indexOf(id)<0){
-                               that.deny_cid.push(id)
+                       if (this.data[id].forum=="1") this.remove_mention(id);
+                       if (this.deny_cid.indexOf(id)<0){
+                               this.deny_cid.push(id)
                        } else {
-                               that.deny_cid.remove(id);
+                               this.deny_cid.remove(id);
                        }
-                       if (that.allow_cid.indexOf(id)>=0) that.allow_cid.remove(id);
+                       if (this.allow_cid.indexOf(id)>=0) this.allow_cid.remove(id);
                        break;
        }
-       that.update_view();
+       this.update_view();
 }
 
 ACL.prototype.is_show_all = function() {
-       return (that.allow_gid.length==0 && that.allow_cid.length==0 &&
-               that.deny_gid.length==0 && that.deny_cid.length==0);
+       return (this.allow_gid.length==0 && this.allow_cid.length==0 &&
+               this.deny_gid.length==0 && this.deny_cid.length==0);
 }
 
 ACL.prototype.update_view = function(){
        if (this.is_show_all()){
-                       that.showall.addClass("selected");
+                       this.showall.addClass("selected");
                        /* jot acl */
                                $('#jot-perms-icon').removeClass('lock').addClass('unlock');
                                $('#jot-public').show();
@@ -209,7 +216,7 @@ ACL.prototype.update_view = function(){
                                }
                        
        } else {
-                       that.showall.removeClass("selected");
+                       this.showall.removeClass("selected");
                        /* jot acl */
                                $('#jot-perms-icon').removeClass('unlock').addClass('lock');
                                $('#jot-public').hide();
@@ -220,29 +227,29 @@ ACL.prototype.update_view = function(){
                $(this).removeClass("groupshow grouphide");
        });
        
-       $("#acl-list-content .acl-list-item").each(function(){
-               itemid = $(this).attr('id');
+       $("#acl-list-content .acl-list-item").each(function(index, element){
+               itemid = $(element).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");  
+               btshow = $(element).children(".acl-button-show").removeClass("selected");
+               bthide = $(element).children(".acl-button-hide").removeClass("selected");       
                
                switch(type){
                        case "g":
                                var uclass = "";
-                               if (that.allow_gid.indexOf(id)>=0){
+                               if (this.allow_gid.indexOf(id)>=0){
                                        btshow.addClass("selected");
                                        bthide.removeClass("selected");
                                        uclass="groupshow";
                                }
-                               if (that.deny_gid.indexOf(id)>=0){
+                               if (this.deny_gid.indexOf(id)>=0){
                                        btshow.removeClass("selected");
                                        bthide.addClass("selected");
                                        uclass="grouphide";
                                }
                                
-                               $(that.group_uids[id]).each(function(i,v) {
+                               $(this.group_uids[id]).each(function(i,v) {
                                        if(uclass == "grouphide")
                                                $("#c"+v).removeClass("groupshow");
                                        if(uclass != "") {
@@ -257,17 +264,17 @@ ACL.prototype.update_view = function(){
                                
                                break;
                        case "c":
-                               if (that.allow_cid.indexOf(id)>=0){
+                               if (this.allow_cid.indexOf(id)>=0){
                                        btshow.addClass("selected");
                                        bthide.removeClass("selected");
                                }
-                               if (that.deny_cid.indexOf(id)>=0){
+                               if (this.deny_cid.indexOf(id)>=0){
                                        btshow.removeClass("selected");
                                        bthide.addClass("selected");
                                }                       
                }
                
-       });
+       }.bind(this));
        
 }
 
@@ -281,30 +288,30 @@ ACL.prototype.get = function(start,count, search){
        
        $.ajax({
                type:'POST',
-               url: that.url,
+               url: this.url,
                data: postdata,
                dataType: 'json',
-               success:that.populate
+               success:this.populate.bind(this)
        });
 }
 
 ACL.prototype.populate = function(data){
-       var height = Math.ceil(data.tot / that.nw) * 42;
-       that.list_content.height(height);
-       that.data = {};
-       $(data.items).each(function(){
-               html = "<div class='acl-list-item {4} {5} type{2}' title='{6}' id='{2}{3}'>"+that.item_tpl+"</div>";
-               html = html.format(this.photo, this.name, this.type, this.id, (this.forum=='1'?'forum':''), this.network, this.link);
-               if (this.uids!=undefined) that.group_uids[this.id] = this.uids;
+       var height = Math.ceil(data.tot / this.nw) * 42;
+       this.list_content.height(height);
+       this.data = {};
+       $(data.items).each(function(index, item){
+               html = "<div class='acl-list-item {4} {5} type{2}' title='{6}' id='{2}{3}'>"+this.item_tpl+"</div>";
+               html = html.format(item.photo, item.name, item.type, item.id, (item.forum=='1'?'forum':''), item.network, item.link);
+               if (item.uids!=undefined) this.group_uids[item.id] = item.uids;
                //console.log(html);
-               that.list_content.append(html);
-               that.data[this.id] = this;
-       });
-       $(".acl-list-item img[data-src]", that.list_content).each(function(i, el){
+               this.list_content.append(html);
+               this.data[item.id] = item;
+       }.bind(this));
+       $(".acl-list-item img[data-src]", this.list_content).each(function(i, el){
                // Add src attribute for images with a data-src attribute
                $(el).attr('src', $(el).data("src"));
        });
        
-       that.update_view();
+       this.update_view();
 }
 
index bba5e92969771dc9d039e65d3b8a152b903642fe..5a1affe3cb7aa3cb815d3eca84622aa96b52fff8 100644 (file)
@@ -9,7 +9,7 @@
                if (h==ch) {
                        return;
                }
-               console.log("_resizeIframe", obj, desth, ch);
+               //console.log("_resizeIframe", obj, desth, ch);
                if (desth!=ch) {
                        setTimeout(_resizeIframe, 500, obj, ch);
                } else {
index bf9470b64efa65e3165a69512654016b14d5b7f4..bb76135067acf0be39ab2f73d8d5dde2c16f2d32 100644 (file)
@@ -29,7 +29,8 @@ $(document).ready(function() {
                acl = new ACL(
                        baseurl+"/acl",
                        [ {{$allowcid}},{{$allowgid}},{{$denycid}},{{$denygid}} ],
-                       {{$features.aclautomention}}
+                       {{$features.aclautomention}},
+                       {{$APP->is_mobile}}
                );
        }
 });
index 647f261c45f668f684201ec1c95c6fc3ec3d1c7b..b06f6032c30ea338f909fde7975da9309b01f30a 100644 (file)
@@ -8,16 +8,24 @@ var plaintext = '{{$editselect}}';
 
 function initEditor(cb){
        if (editor==false){
+               var  colorbox_options = {
+                       {{if $APP->is_mobile}}
+                       'width' : '100%',
+                       'height' : '100%',
+                       {{/if}}
+                       'inline' : true,
+                       'transition' : 'elastic'
+               }
+               
+               
+               
                $("#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").colorbox({
-                               'inline' : true,
-                               'transition' : 'elastic'
-                       });
+                       $("a#jot-perms-icon").colorbox(colorbox_options);
                        $(".jothidden").show();
                        if (typeof cb!="undefined") cb();
                        return;
@@ -107,10 +115,7 @@ function initEditor(cb){
                });
                editor = true;
                // setup acl popup
-               $("a#jot-perms-icon").colorbox({
-                       'inline' : true,
-                       'transition' : 'elastic'
-               });
+               $("a#jot-perms-icon").colorbox(colorbox_options);
        } else {
                if (typeof cb!="undefined") cb();
        }
index f6ec2b8ccbd89a6167561a17426a1e04c175e536..128fb469c670f551281b9c59a76dc522aca8b440 100644 (file)
@@ -161,3 +161,77 @@ aside.show {
 }
 .tabs.show::after { display: none; }
 .tabs.show .tab { display: block; }
+
+/* ACL window */
+#profile-jot-acl-wrapper, #profile-jot-acl-wrapper * { box-sizing: border-box; }
+#acl-wrapper { width: 100%; float: none; }
+#acl-search { width: 100%; float: none; padding-right: 0px; margin-bottom: 1em; }
+#acl-showall { width: 100%; height: 48px; margin-bottom: 1em; }
+.acl-list-item { width: auto; float: none; height: auto; overflow: hidden; position: relative;}
+.acl-list-item img { width: 48px; height: 48px; }
+.acl-list-item p { height: auto; font-size: inherit; }
+.acl-list-item a {
+  float: none;
+  position: absolute;
+  top: 5px;
+  right: 5px;
+  height: 48px;
+  padding: 10px 2px 2px 2px;
+  font-size: 12px;
+  width: 20%;
+  text-align: center;
+  background-position: center 5px;
+}
+.acl-list-item a.acl-button-hide { right: 25%; }
+/* flexbox for ACL window */
+#cboxLoadedContent,
+#cboxLoadedContent > div,
+#acl-wrapper {
+  display: -ms-Flexbox !important;
+  -ms-box-orient: vertival;
+
+  display: -webkit-flex !important;
+  display: -moz-flex !important;
+  display: -ms-flex !important;
+  display: flex !important;
+
+  -webkit-flex-flow: column;
+  -moz-flex-flow: column;
+  -ms-flex-flow: column;
+  flex-flow: column;
+  
+  -webkit-flex: 1 100%;
+  -moz-flex: 1 100%;
+  -ms-flex: 1 100%;
+  flex: 1 100%;
+}
+#acl-list {
+  -webkit-flex: 1 1 auto;
+  -moz-flex: 1 1 auto;
+  -ms-flex: 1 1 auto;
+  flex: 1 1 auto;  
+}
+
+/** input elements **/
+input,
+textarea,
+select {
+    font-size: 18px;
+    border: 1px solid #888;
+    padding: 0.2em;
+}
+input:focus,
+textarea:focus,
+select:focus {
+    box-shadow: 1px 1px 10px rgba(46, 151, 255, 0.62);
+}
+
+.field, .field > * {  box-sizing: border-box; }
+.field label { width: 100%; float: none; display: block; }
+.field input, .field textarea, .field select { max-width: 100%; width: 100%; }
+.field.yesno .onoff,
+.field.checkbox input { width: auto; float: right; }
+.field.yesno label,
+.field.checkbox label { width: 70%; float: left; }
+.field .field_help { margin: 0; }
+