Merge branch 'master' of https://github.com/friendica/red
This commit is contained in:
commit
6ccf6455c4
4
app/features.apd
Normal file
4
app/features.apd
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
url: $baseurl/settings/features
|
||||||
|
requires: local_user
|
||||||
|
name: Features
|
||||||
|
photo: $baseurl/app/features.png
|
BIN
app/features.png
Normal file
BIN
app/features.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 7.0 KiB |
3
app/hex.apd
Normal file
3
app/hex.apd
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
url: $baseurl/hexit
|
||||||
|
name: Hexit
|
||||||
|
photo: $baseurl/app/hex.png
|
BIN
app/hex.png
Normal file
BIN
app/hex.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 12 KiB |
@ -281,6 +281,14 @@ function bb2diaspora($Text,$preserve_nl = false, $fordiaspora = true) {
|
|||||||
$Text = preg_replace("/\[img\](.*?)\[\/img\]/", '', $Text);
|
$Text = preg_replace("/\[img\](.*?)\[\/img\]/", '', $Text);
|
||||||
$Text = preg_replace("/\[img\=(.*?)\](.*?)\[\/img\]/", '', $Text);
|
$Text = preg_replace("/\[img\=(.*?)\](.*?)\[\/img\]/", '', $Text);
|
||||||
|
|
||||||
|
$Text = preg_replace("/\[zrl\]([$URLSearchString]*)\[\/zrl\]/ism", '[$1]($1)', $Text);
|
||||||
|
$Text = preg_replace("/\#\[zrl\=([$URLSearchString]*)\](.*?)\[\/zrl\]/ism", '[#$2]($1)', $Text);
|
||||||
|
$Text = preg_replace("/\[zrl\=([$URLSearchString]*)\](.*?)\[\/zrl\]/ism", '[$2]($1)', $Text);
|
||||||
|
|
||||||
|
|
||||||
|
$Text = preg_replace("/\[zmg\](.*?)\[\/zmg\]/", '', $Text);
|
||||||
|
$Text = preg_replace("/\[zmg\=(.*?)\](.*?)\[\/zmg\]/", '', $Text);
|
||||||
|
|
||||||
// Perform MAIL Search
|
// Perform MAIL Search
|
||||||
$Text = preg_replace("(\[mail\]([$MAILSearchString]*)\[/mail\])", '[$1](mailto:$1)', $Text);
|
$Text = preg_replace("(\[mail\]([$MAILSearchString]*)\[/mail\])", '[$1](mailto:$1)', $Text);
|
||||||
$Text = preg_replace("/\[mail\=([$MAILSearchString]*)\](.*?)\[\/mail\]/", '[$2](mailto:$1)', $Text);
|
$Text = preg_replace("/\[mail\=([$MAILSearchString]*)\](.*?)\[\/mail\]/", '[$2](mailto:$1)', $Text);
|
||||||
|
@ -2334,6 +2334,34 @@ function tag_deliver($uid,$item_id) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (stristr($item['verb'],ACTIVITY_POKE)) {
|
||||||
|
$poke_notify = true;
|
||||||
|
|
||||||
|
if(($item['obj_type'] == "") || ($item['obj_type'] !== ACTIVITY_OBJ_PERSON) || (! $item['object']))
|
||||||
|
$poke_notify = false;
|
||||||
|
|
||||||
|
$obj = json_decode_plus($item['object']);
|
||||||
|
if($obj) {
|
||||||
|
if($obj['id'] !== $u[0]['channel_hash'])
|
||||||
|
$poke_notify = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$verb = urldecode(substr($item['verb'],strpos($item['verb'],'#')+1));
|
||||||
|
if($poke_notify) {
|
||||||
|
require_once('include/enotify.php');
|
||||||
|
notification(array(
|
||||||
|
'to_xchan' => $u[0]['channel_hash'],
|
||||||
|
'from_xchan' => $item['author_xchan'],
|
||||||
|
'type' => NOTIFY_POKE,
|
||||||
|
'item' => $item,
|
||||||
|
'link' => $i[0]['llink'],
|
||||||
|
'verb' => ACTIVITY_POKE,
|
||||||
|
'activity' => $verb,
|
||||||
|
'otype' => 'item'
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if($item['obj_type'] === ACTIVITY_OBJ_TAGTERM) {
|
if($item['obj_type'] === ACTIVITY_OBJ_TAGTERM) {
|
||||||
|
|
||||||
// We received a community tag activity for a post.
|
// We received a community tag activity for a post.
|
||||||
|
@ -364,6 +364,13 @@ function zot_refresh($them,$channel = null, $force = false) {
|
|||||||
|
|
||||||
if($r) {
|
if($r) {
|
||||||
|
|
||||||
|
// if the dob is the same as what we have stored (disregarding the year), keep the one
|
||||||
|
// we have as we may have updated the year after sending a notification; and resetting
|
||||||
|
// to the one we just received would cause us to create duplicated events.
|
||||||
|
|
||||||
|
if(substr($r[0]['abook_dob'],5) == substr($next_birthday,5))
|
||||||
|
$next_birthday = $r[0]['abook_dob'];
|
||||||
|
|
||||||
$current_abook_connected = (($r[0]['abook_flags'] & ABOOK_FLAG_UNCONNECTED) ? 0 : 1);
|
$current_abook_connected = (($r[0]['abook_flags'] & ABOOK_FLAG_UNCONNECTED) ? 0 : 1);
|
||||||
|
|
||||||
$y = q("update abook set abook_their_perms = %d, abook_dob = '%s'
|
$y = q("update abook set abook_their_perms = %d, abook_dob = '%s'
|
||||||
|
181
mod/hexit.php
Normal file
181
mod/hexit.php
Normal file
@ -0,0 +1,181 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function hexit_content(&$a) {
|
||||||
|
|
||||||
|
|
||||||
|
$o .= <<< EOT
|
||||||
|
|
||||||
|
<script type="text/javascript">
|
||||||
|
/**
|
||||||
|
* A function for converting hex <-> dec w/o loss of precision.
|
||||||
|
*
|
||||||
|
* The problem is that parseInt("0x12345...") isn't precise enough to convert
|
||||||
|
* 64-bit integers correctly.
|
||||||
|
*
|
||||||
|
* Internally, this uses arrays to encode decimal digits starting with the least
|
||||||
|
* significant:
|
||||||
|
* 8 = [8]
|
||||||
|
* 16 = [6, 1]
|
||||||
|
* 1024 = [4, 2, 0, 1]
|
||||||
|
*/
|
||||||
|
|
||||||
|
// Adds two arrays for the given base (10 or 16), returning the result.
|
||||||
|
// This turns out to be the only "primitive" operation we need.
|
||||||
|
function add(x, y, base) {
|
||||||
|
var z = [];
|
||||||
|
var n = Math.max(x.length, y.length);
|
||||||
|
var carry = 0;
|
||||||
|
var i = 0;
|
||||||
|
while (i < n || carry) {
|
||||||
|
var xi = i < x.length ? x[i] : 0;
|
||||||
|
var yi = i < y.length ? y[i] : 0;
|
||||||
|
var zi = carry + xi + yi;
|
||||||
|
z.push(zi % base);
|
||||||
|
carry = Math.floor(zi / base);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
return z;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns a*x, where x is an array of decimal digits and a is an ordinary
|
||||||
|
// JavaScript number. base is the number base of the array x.
|
||||||
|
function multiplyByNumber(num, x, base) {
|
||||||
|
if (num < 0) return null;
|
||||||
|
if (num == 0) return [];
|
||||||
|
|
||||||
|
var result = [];
|
||||||
|
var power = x;
|
||||||
|
while (true) {
|
||||||
|
if (num & 1) {
|
||||||
|
result = add(result, power, base);
|
||||||
|
}
|
||||||
|
num = num >> 1;
|
||||||
|
if (num === 0) break;
|
||||||
|
power = add(power, power, base);
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
function parseToDigitsArray(str, base) {
|
||||||
|
var digits = str.split('');
|
||||||
|
var ary = [];
|
||||||
|
for (var i = digits.length - 1; i >= 0; i--) {
|
||||||
|
var n = parseInt(digits[i], base);
|
||||||
|
if (isNaN(n)) return null;
|
||||||
|
ary.push(n);
|
||||||
|
}
|
||||||
|
return ary;
|
||||||
|
}
|
||||||
|
|
||||||
|
function convertBase(str, fromBase, toBase) {
|
||||||
|
var digits = parseToDigitsArray(str, fromBase);
|
||||||
|
if (digits === null) return null;
|
||||||
|
|
||||||
|
var outArray = [];
|
||||||
|
var power = [1];
|
||||||
|
for (var i = 0; i < digits.length; i++) {
|
||||||
|
// invariant: at this point, fromBase^i = power
|
||||||
|
if (digits[i]) {
|
||||||
|
outArray = add(outArray, multiplyByNumber(digits[i], power, toBase), toBase);
|
||||||
|
}
|
||||||
|
power = multiplyByNumber(fromBase, power, toBase);
|
||||||
|
}
|
||||||
|
|
||||||
|
var out = '';
|
||||||
|
for (var i = outArray.length - 1; i >= 0; i--) {
|
||||||
|
out += outArray[i].toString(toBase);
|
||||||
|
}
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
function decToHex(decStr) {
|
||||||
|
var hex = convertBase(decStr, 10, 16);
|
||||||
|
return hex ? '0x' + hex : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
function hexToDec(hexStr) {
|
||||||
|
if (hexStr.substring(0, 2) === '0x') hexStr = hexStr.substring(2);
|
||||||
|
hexStr = hexStr.toLowerCase();
|
||||||
|
return convertBase(hexStr, 16, 10);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function str_or_null(x) {
|
||||||
|
return x === null ? 'null' : x;
|
||||||
|
}
|
||||||
|
|
||||||
|
// "1.234e+5" -> "12340"
|
||||||
|
function expandExponential(x) {
|
||||||
|
var pos = x.indexOf("e");
|
||||||
|
if (pos === -1) pos = x.indexOf("E");
|
||||||
|
if (pos === -1) return x;
|
||||||
|
|
||||||
|
var base = x.substring(0, pos);
|
||||||
|
var pow = parseInt(x.substring(pos + 1), 10);
|
||||||
|
if (pow < 0) return x; // not supported.
|
||||||
|
|
||||||
|
var dotPos = base.indexOf('.');
|
||||||
|
if (dotPos === -1) dotPos = base.length;
|
||||||
|
|
||||||
|
var ret = base.replace('.', '');
|
||||||
|
while (ret.length < dotPos + pow) ret += '0';
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
function boldDifference(correct, actual) {
|
||||||
|
for (var i = 0, j = 0; i < correct.length && j < actual.length; i++, j++) {
|
||||||
|
if (correct[i] !== actual[j]) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (j < actual.length) {
|
||||||
|
return actual.substring(0, j) + '<b>' + actual.substring(j) + '</b>';
|
||||||
|
} else {
|
||||||
|
return actual;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function convert() {
|
||||||
|
var input = document.getElementById("in").value;
|
||||||
|
if (input) {
|
||||||
|
var aHex = str_or_null(decToHex(input));
|
||||||
|
var aDec = str_or_null(hexToDec(input));
|
||||||
|
var bHex = '0x' + (parseInt(input, 10)).toString(16);
|
||||||
|
var bDec = "" + expandExponential("" +parseInt(input, 16));
|
||||||
|
|
||||||
|
var html = '<p></p><p>To Decimal(' + input + ') = ' + aDec + '</p>';
|
||||||
|
html += '<p>To Hex(' + input + ') = ' + aHex + '</p>';
|
||||||
|
document.getElementById('result').innerHTML = html;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
convert();
|
||||||
|
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<h2>Hexit</h2>
|
||||||
|
|
||||||
|
<p>Type in a hex or decimal string:</p>
|
||||||
|
<input type="text" size=40 id="in" onkeyup="convert()" value="" />
|
||||||
|
<p id="result"></p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
EOT;
|
||||||
|
|
||||||
|
return $o;
|
||||||
|
}
|
@ -1,9 +1,9 @@
|
|||||||
<?php /** @file */
|
<?php /** @file */
|
||||||
|
|
||||||
function notes_init(&$a) {
|
function notes_init(&$a) {
|
||||||
|
|
||||||
if(! local_user())
|
if(! local_user())
|
||||||
return;
|
return;
|
||||||
logger('mod_notes: ' . print_r($_REQUEST,true));
|
|
||||||
|
|
||||||
$ret = array('success' => true);
|
$ret = array('success' => true);
|
||||||
if($_REQUEST['note_text'] || $_REQUEST['note_text'] == '') {
|
if($_REQUEST['note_text'] || $_REQUEST['note_text'] == '') {
|
||||||
@ -18,7 +18,7 @@ function notes_init(&$a) {
|
|||||||
build_sync_packet();
|
build_sync_packet();
|
||||||
}
|
}
|
||||||
|
|
||||||
logger('notes saved.');
|
logger('notes saved.', LOGGER_DEBUG);
|
||||||
json_return_and_die($ret);
|
json_return_and_die($ret);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
10768
view/pt-br/messages.po
10768
view/pt-br/messages.po
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -1,21 +1,33 @@
|
|||||||
function commentOpenRedbasic(obj,id) {
|
function commentOpenRedbasic(obj,id) {
|
||||||
$(document).click(function() {
|
|
||||||
|
$(document).unbind( "click.commentOpen", handler );
|
||||||
|
|
||||||
|
var handler = function() {
|
||||||
if(obj.value == aStr['comment']) {
|
if(obj.value == aStr['comment']) {
|
||||||
obj.value = '';
|
obj.value = '';
|
||||||
$("#comment-edit-text-" + id).addClass("comment-edit-text-full").removeClass("comment-edit-text-empty");
|
$("#comment-edit-text-" + id).addClass("comment-edit-text-full").removeClass("comment-edit-text-empty");
|
||||||
$("#comment-tools-" + id).show();
|
$("#comment-tools-" + id).show();
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
|
$(document).bind( "click.commentOpen", handler );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function commentCloseRedbasic(obj,id) {
|
function commentCloseRedbasic(obj,id) {
|
||||||
$(document).click(function() {
|
|
||||||
|
$(document).unbind( "click.commentClose", handler );
|
||||||
|
|
||||||
|
var handler = function() {
|
||||||
if(obj.value == '') {
|
if(obj.value == '') {
|
||||||
obj.value = aStr['comment'];
|
obj.value = aStr['comment'];
|
||||||
$("#comment-edit-text-" + id).removeClass("comment-edit-text-full").addClass("comment-edit-text-empty");
|
$("#comment-edit-text-" + id).removeClass("comment-edit-text-full").addClass("comment-edit-text-empty");
|
||||||
$("#comment-tools-" + id).hide();
|
$("#comment-tools-" + id).hide();
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
|
$(document).bind( "click.commentClose", handler );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$(document).ready(function() {
|
$(document).ready(function() {
|
||||||
|
Reference in New Issue
Block a user