[COMPONENT][ACTOR CIRCLE] mention self tag circle with @#self_tag

This commit is contained in:
Phablulo Joel 2021-12-29 13:50:29 -03:00
parent f9bc1c790f
commit 01d5e84a08
4 changed files with 52 additions and 28 deletions

View File

@ -47,6 +47,7 @@ use Doctrine\ORM\QueryBuilder;
use Functional as F; use Functional as F;
use Symfony\Component\Form\Extension\Core\Type\CheckboxType; use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Request;
use App\Util\Nickname;
/** /**
* Component responsible for extracting tags from posted notes, as well as normalizing them * Component responsible for extracting tags from posted notes, as well as normalizing them
@ -59,6 +60,7 @@ class Tag extends Component
{ {
public const MAX_TAG_LENGTH = 64; public const MAX_TAG_LENGTH = 64;
public const TAG_REGEX = '/(^|\\s)(#[\\pL\\pN_\\-]{1,64})/u'; // Brion Vibber 2011-02-23 v2:classes/Notice.php:367 function saveTags public const TAG_REGEX = '/(^|\\s)(#[\\pL\\pN_\\-]{1,64})/u'; // Brion Vibber 2011-02-23 v2:classes/Notice.php:367 function saveTags
public const TAG_CIRCLE_REGEX = '/' . Nickname::BEFORE_MENTIONS . '@#([\pL\pN_\-\.]{1,64})/';
public const TAG_SLUG_REGEX = '[A-Za-z0-9]{1,64}'; public const TAG_SLUG_REGEX = '[A-Za-z0-9]{1,64}';
public function onAddRoute($r): bool public function onAddRoute($r): bool

View File

@ -24,6 +24,7 @@ namespace App\Entity;
use App\Core\Cache; use App\Core\Cache;
use App\Core\DB\DB; use App\Core\DB\DB;
use App\Core\Entity; use App\Core\Entity;
use App\Core\Router\Router;
use DateTimeInterface; use DateTimeInterface;
/** /**
@ -185,6 +186,10 @@ class ActorCircle extends Entity
); );
} }
public function getUrl(int $type = Router::ABSOLUTE_PATH): string {
return Router::url('actor_circle', ['actor_id' => $this->getTagger(), 'tag' => $this->getTag()]);
}
public static function schemaDef(): array public static function schemaDef(): array
{ {
return [ return [

View File

@ -60,6 +60,10 @@ abstract class Main
$r->connect('panel', '/panel', [C\AdminPanel::class, 'site']); $r->connect('panel', '/panel', [C\AdminPanel::class, 'site']);
$r->connect('panel_site', '/panel/site', [C\AdminPanel::class, 'site']); $r->connect('panel_site', '/panel/site', [C\AdminPanel::class, 'site']);
// TODO: don't do
$r->connect('actor_circle', '/', RedirectController::class, ['defaults' => ['route' => 'feed_public']]);
// FAQ static pages // FAQ static pages
foreach (['faq', 'contact', 'tags', 'groups', 'openid'] as $s) { foreach (['faq', 'contact', 'tags', 'groups', 'openid'] as $s) {
$r->connect('doc_' . $s, '/doc/' . $s, C\TemplateController::class, ['template' => 'doc/faq/' . $s . '.html.twig']); $r->connect('doc_' . $s, '/doc/' . $s, C\TemplateController::class, ['template' => 'doc/faq/' . $s . '.html.twig']);

View File

@ -39,9 +39,12 @@ use App\Entity\Note;
use App\Util\Exception\NicknameException; use App\Util\Exception\NicknameException;
use App\Util\Exception\ServerException; use App\Util\Exception\ServerException;
use Component\Group\Entity\LocalGroup; use Component\Group\Entity\LocalGroup;
use Component\Tag\Tag;
use Exception; use Exception;
use Functional as F; use Functional as F;
use InvalidArgumentException; use InvalidArgumentException;
use App\Core\DB\DB;
use App\Entity\ActorCircle;
abstract class Formatting abstract class Formatting
{ {
@ -327,33 +330,43 @@ abstract class Formatting
} }
} }
@#/tag
// TODO Tag subscriptions // TODO Tag subscriptions
// @#tag => mention of all subscriptions tagged 'tag' // @#tag => mention of all subscriptions tagged 'tag'
// $tag_matches = []; $tag_matches = [];
// preg_match_all( preg_match_all(
// '/' . Nickname::BEFORE_MENTIONS . '@#([\pL\pN_\-\.]{1,64})/', Tag::TAG_CIRCLE_REGEX,
// $text, $text,
// $tag_matches, $tag_matches,
// PREG_OFFSET_CAPTURE PREG_OFFSET_CAPTURE
// ); );
// foreach ($tag_matches[1] as $tag_match) { foreach ($tag_matches[1] as $tag_match) {
// $tag = self::canonicalTag($tag_match[0]); $tag = Tag::ensureValid($tag_match[0]);
// $plist = Profile_list::getByTaggerAndTag($actor->getID(), $tag); $ac = DB::findOneBy(ActorCircle::class, [
// if (!$plist instanceof Profile_list || $plist->private) { 'or' => [
// continue; 'tagger' => $actor->getID(),
// } 'and' => [
// $tagged = $actor->getTaggedSubscribers($tag); 'tagger' => null,
// $url = common_local_url( 'tagged' => $actor->getID(),
// 'showprofiletag', ]
// ['nickname' => $actor->getNickname(), 'tag' => $tag] ],
// ); 'tag' => $tag,
// $mentions[] = ['mentioned' => $tagged, ], return_null: true);
// 'type' => 'list',
// 'text' => $tag_match[0], if (\is_null($ac) || $ac->getPrivate()) {
// 'position' => $tag_match[1], continue;
// 'length' => mb_strlen($tag_match[0]), }
// 'url' => $url, ]; $tagged = $ac->getSubscribedActors();
// } $url = $ac->getUrl();
$mentions[] = [
'mentioned' => $tagged,
'type' => 'list',
'text' => $tag_match[0],
'position' => $tag_match[1],
'length' => mb_strlen($tag_match[0]),
'url' => $url,
];
}
// Group mentions // Group mentions
$group_matches = self::findMentionsRaw($text, '!'); $group_matches = self::findMentionsRaw($text, '!');