]> git.mxchange.org Git - friendica.git/commitdiff
acl selector add and remove mentions when a forum is selected.
authorFabrixxm <fabrix.xm@gmail.com>
Wed, 18 Dec 2013 15:17:38 +0000 (10:17 -0500)
committerFabrixxm <fabrix.xm@gmail.com>
Wed, 18 Dec 2013 15:18:26 +0000 (10:18 -0500)
include/acl_selectors.php
js/acl.js
js/fk.autocomplete.js
view/templates/acl_selector.tpl

index 6c0222e1c4f969d6fcf46d616999a6a88c5fdcdf..01c2f1d706af648a9f9e5fcaffce8106e27ca9a7 100644 (file)
@@ -474,14 +474,15 @@ function acl_lookup(&$a, $out_type = 'json') {
                                "name"  => $g['name'],
                                "id"    => intval($g['id']),
                                "uids"  => array_map("intval", explode(",",$g['uids'])),
-                               "link"  => ''
+                               "link"  => '',
+                               "forum" => '0'
                        );
                }
        }
        
        if ($type=='' || $type=='c'){
        
-               $r = q("SELECT `id`, `name`, `nick`, `micro`, `network`, `url`, `attag` FROM `contact` 
+               $r = q("SELECT `id`, `name`, `nick`, `micro`, `network`, `url`, `attag`, forum FROM `contact` 
                        WHERE `uid` = %d AND `self` = 0 AND `blocked` = 0 AND `pending` = 0 AND `archive` = 0 AND `notify` != ''
                        $sql_extra2
                        ORDER BY `name` ASC ",
@@ -541,6 +542,7 @@ function acl_lookup(&$a, $out_type = 'json') {
                                "network" => $g['network'],
                                "link" => $g['url'],
                                "nick" => ($g['attag']) ? $g['attag'] : $g['nick'],
+                               "forum" => $g['forum']
                        );
                }                       
        }
index fc6a6c0c1d4cb6283c89aef98cd0d1720fa701ba..f258a29c736e49a32ebddb3a2289c4464397de53 100644 (file)
--- a/js/acl.js
+++ b/js/acl.js
@@ -26,10 +26,42 @@ function ACL(backend_url, preset){
        $("#acl-search").keypress(that.on_search);
        $("#acl-wrapper").parents("form").submit(that.on_submit);
        
+       /* add/remove mentions  */
+       that.element = $("#profile-jot-text");
+       that.htmlelm = that.element.get()[0];
+       
        /* startup! */
        that.get(0,100);
 }
 
+ACL.prototype.remove_mention = function(nick) {
+       searchText = '@'+nick+ " ";
+       // 'editor' is defined in jot-header.tpl : false=plaintext, true:tinyMCE
+       if (editor==false) {
+               start = that.element.val().search(searchText); 
+               if ( start<0) return;
+               end = start+searchText.length;
+               that.element.setSelection(start,end).replaceSelectedText('').collapseSelection(false);
+       } else {
+               start =  tinyMCE.activeEditor.getContent({format : 'raw'}).search( searchText );
+               if ( start<0 ) return;
+               txt = tinyMCE.activeEditor.getContent();
+               newtxt = txt.replace(searchText, '');
+               tinyMCE.activeEditor.setContent(newtxt);
+       }
+}
+
+ACL.prototype.add_mention = function(nick) {
+       // 'editor' is defined in jot-header.tpl : false=plaintext, true:tinyMCE
+       if (editor==false) {
+               if ( that.element.val().search( '@'+nick) >= 0 ) return;
+               that.element.val( "@"+nick+" " + that.element.val() );
+       } else {
+               if ( tinyMCE.activeEditor.getContent({format : 'raw'}).search( '@'+nick) >= 0 ) return;
+               tinyMCE.activeEditor.dom.add(tinyMCE.activeEditor.getBody(), 'span', {}, '@'+nick+" ");
+       }
+}
+
 ACL.prototype.on_submit = function(){
        aclfileds = $("#acl-fields").html("");
        $(that.allow_gid).each(function(i,v){
@@ -105,7 +137,8 @@ ACL.prototype.on_button_hide = function(event){
 
 ACL.prototype.set_allow = function(itemid){
        type = itemid[0];
-       id       = parseInt(itemid.substr(1));
+       id     = parseInt(itemid.substr(1));
+       
        switch(type){
                case "g":
                        if (that.allow_gid.indexOf(id)<0){
@@ -118,8 +151,10 @@ ACL.prototype.set_allow = function(itemid){
                case "c":
                        if (that.allow_cid.indexOf(id)<0){
                                that.allow_cid.push(id)
+                               if (that.data[id].forum=="1") that.add_mention(that.data[id].nick);
                        } else {
                                that.allow_cid.remove(id);
+                               if (that.data[id].forum=="1") that.remove_mention(that.data[id].nick);
                        }
                        if (that.deny_cid.indexOf(id)>=0) that.deny_cid.remove(id);                     
                        break;
@@ -129,7 +164,8 @@ ACL.prototype.set_allow = function(itemid){
 
 ACL.prototype.set_deny = function(itemid){
        type = itemid[0];
-       id       = parseInt(itemid.substr(1));
+       id     = parseInt(itemid.substr(1));
+       
        switch(type){
                case "g":
                        if (that.deny_gid.indexOf(id)<0){
@@ -140,6 +176,7 @@ ACL.prototype.set_deny = function(itemid){
                        if (that.allow_gid.indexOf(id)>=0) that.allow_gid.remove(id);
                        break;
                case "c":
+                       if (that.data[id].forum=="1") that.remove_mention(that.data[id].nick);
                        if (that.deny_cid.indexOf(id)<0){
                                that.deny_cid.push(id)
                        } else {
@@ -246,17 +283,20 @@ ACL.prototype.get = function(start,count, search){
 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}' title='{6}' id='{2}{3}'>"+that.item_tpl+"</div>";
-               html = html.format(this.photo, this.name, this.type, this.id, '', this.network, this.link);
+               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;
                //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){
                // Add src attribute for images with a data-src attribute
                $(el).attr('src', $(el).data("src"));
        });
+       
        that.update_view();
 }
 
index b1bc40be28b12f4bf99c418a044396120ee80c61..2334bb4a2c19887b30f16fa761949fb2de4a1a43 100644 (file)
@@ -89,7 +89,7 @@ ACPopup.prototype._search = function(){
        });
        
 }
-       ACPopup.prototype.add = function(label, value){
+ACPopup.prototype.add = function(label, value){
        var that=this;
        var elm = $("<div class='acpopupitem' title='"+value+"'>"+label+"</div>");
        elm.click(function(e){
index 5fd11e75695398b572526e4c54da2fac2777f3c8..7a9514ea8612fb6f5b579148270cc39773fb2ffe 100644 (file)
@@ -1,8 +1,4 @@
-{{*
- *     AUTOMATICALLY GENERATED TEMPLATE
- *     DO NOT EDIT THIS FILE, CHANGES WILL BE OVERWRITTEN
- *
- *}}
+
 <div id="acl-wrapper">
        <input id="acl-search">
        <a href="#" id="acl-showall">{{$showall}}</a>