}
} elseif (strpos($tag, '#') === 0) {
$tagname = substr($tag, 1);
- $str_tags .= '#[url=' . System::baseUrl() . "/search?tag=" . $tagname . ']' . $tagname . '[/url]';
+ $str_tags .= '#[url=' . System::baseUrl() . "/search?tag=" . $tagname . ']' . $tagname . '[/url],';
}
}
}
if (count($linked_items) && strlen($link_item['tag'])) {
$arr = explode(',', $link_item['tag']);
// parse tags and add links
- $tag_str = '';
+ $tag_arr = [];
foreach ($arr as $t) {
- if (strlen($tag_str)) {
- $tag_str .= ', ';
- }
- $tag_str .= BBCode::convert($t);
+ array_push($tag_arr, ['name' => BBCode::convert($t),
+ 'removeurl' => '/tagrm/'.$link_item['id'] . '/' . bin2hex($t)]);
}
- $tags = [L10n::t('Tags: '), $tag_str];
+ $tags = ['title' => L10n::t('Tags: '), 'tags' => $tag_arr];
if ($cmd === 'edit') {
- $tags[] = 'tagrm/' . $link_item['id'];
- $tags[] = L10n::t('[Remove any tag]');
+ $tags += ['removeanyurl' => 'tagrm/' . $link_item['id']];
+ $tags += ['removetitle' => L10n::t('[Remove any tag]')];
}
}
$a->internalRedirect($_SESSION['photo_return']);
}
- $tag = (x($_POST,'tag') ? hex2bin(notags(trim($_POST['tag']))) : '');
- $item_id = (x($_POST,'item') ? intval($_POST['item']) : 0);
+ $tags = [];
+ if (defaults($_POST, 'tag', '')){
+ foreach ($_POST['tag'] as $t){
+ array_push($tags, hex2bin(notags(trim($t))));
+ }
+ }
+
+ $item_id = defaults($_POST,'item', 0);
+ update_tags($item_id, $tags);
+
+ info(L10n::t('Tag(s) removed') . EOL );
+
+ $a->internalRedirect($_SESSION['photo_return']);
+
+ // NOTREACHED
+}
+
+function update_tags($item_id, $tags){
+ if (empty($item_id) || empty($tags)){
+ $a->internalRedirect($_SESSION['photo_return']);
+ }
$item = Item::selectFirst(['tag'], ['id' => $item_id, 'uid' => local_user()]);
if (!DBA::isResult($item)) {
}
$arr = explode(',', $item['tag']);
- for ($x = 0; $x < count($arr); $x ++) {
- if ($arr[$x] === $tag) {
- unset($arr[$x]);
- break;
+
+ foreach ($tags as $t) {
+ foreach ($arr as $i => $x) {
+ if (strcmp($x, $t) == 0) {
+ unset($arr[$i]);
+ break;
+ }
}
}
$tag_str = implode(',',$arr);
+ if(empty($tag_str)){
+ $tag_str = '';
+ }
Item::update(['tag' => $tag_str], ['id' => $item_id]);
- info(L10n::t('Tag removed') . EOL );
+ info(L10n::t('Tag(s) removed') . EOL );
$a->internalRedirect($_SESSION['photo_return']);
// NOTREACHED
}
-
-
function tagrm_content(App $a)
{
$o = '';
// NOTREACHED
}
+ if ($a->argc == 3){
+ update_tags($a->argv[1], [hex2bin(notags(trim($a->argv[2])))]);
+ goaway('/' . $_SESSION['photo_return']);
+ }
+
$item_id = (($a->argc > 1) ? intval($a->argv[1]) : 0);
if (!$item_id) {
$a->internalRedirect($_SESSION['photo_return']);
$arr = explode(',', $item['tag']);
- if (!count($arr)) {
+
+ if (empty($item['tag'])) {
$a->internalRedirect($_SESSION['photo_return']);
}
$o .= '<ul>';
foreach ($arr as $x) {
- $o .= '<li><input type="checkbox" name="tag" value="' . bin2hex($x) . '" >' . BBCode::convert($x) . '</input></li>';
+ $o .= '<li><input type="checkbox" name="tag[]" value="' . bin2hex($x) . '" >' . BBCode::convert($x) . '</input></li>';
}
$o .= '</ul>';
$tags = $fields['tag'];
$fields['tag'] = null;
} else {
- $tags = '';
+ $tags = null;
}
if (array_key_exists('file', $fields)) {
}
}
- if (!empty($tags)) {
- Term::insertFromTagFieldByItemId($item['id'], $tags);
- if (!empty($item['tag'])) {
- DBA::update('item', ['tag' => ''], ['id' => $item['id']]);
+ if (!is_null($tags)) {
+ Term::deleteAllTags($item['id']);
+
+ if ($tags) {
+ Term::insertFromTagFieldByItemId($item['id'], $tags);
+ if (!empty($item['tag'])) {
+ DBA::update('item', ['tag' => ''], ['id' => $item['id']]);
+ }
}
}
return $return;
}
+
+ /*
+ * Deletes all Tags from an item
+ */
+ public static function deleteAllTags($itemid)
+ {
+ $message = Item::selectFirst(['id'], ['id' => $itemid]);
+ if (!DBA::isResult($message)) {
+ return;
+ }
+
+ // Clean up all tags
+ DBA::delete('term', ['otype' => TERM_OBJ_POST, 'oid' => $itemid, 'type' => [TERM_HASHTAG, TERM_MENTION]]);
+
+ }
}
{{* Tags and mentions *}}
{{if $tags}}
- <div id="photo-tags">{{$tags.1}}</div>
+ <div id="photo-tags">{{$tags.title}}
+ {{foreach $tags.tags as $t}}
+ <span class="category label btn-success sm">
+ <span class="p-category">{{$t.name}}</span>
+ {{if $t.removeurl}} (<a href="{{$t.removeurl}}">x</a>) {{/if}}
+ </span>
+ {{/foreach}}
+ </div>
{{/if}}
- {{if $tags.2}}
+ {{if $tags.removeanyurl}}
<div id="tag-remove">
- <a href="{{$tags.2}}">{{$tags.3}}</a>
+ <a href="{{$tags.removeanyurl}}">{{$tags.removetitle}}</a>
</div>
{{/if}}