Revert "kaban : fix comments count for virtual sample step"

This reverts commit 57b5ee3949.
This commit is contained in:
isUnknown 2025-02-09 10:07:15 +01:00
parent 57b5ee3949
commit 37b0175941
4 changed files with 51 additions and 78 deletions

View file

@ -12,6 +12,7 @@ permissions:
inspirations: false
materials: false
creations: false
pages: false
user:
changeRole: false
delete: false

View file

@ -4,58 +4,56 @@ use adrienpayet\comments\Comment;
return [
'pattern' => '(:all)create-comment.json',
'method' => 'POST',
'method' => 'POST',
'action' => function () {
$json = file_get_contents('php://input');
$data = json_decode($json);
// kirby()->impersonate('kirby');
$page = page($data->fileParentUri);
$project = $page->parent()->template() == 'project' ? $page->parent() : $page->parent()->parent();
$project = $page->parent()->template() == "project" ? $page->parent() : $page->parent()->parent();
$file = $page->file($data->fileName);
$user = kirby()->user($data->userUuid);
$user = kirby()->user($data->userUuid);
$comments = $file->comments()->isEmpty() == true ? [] : Yaml::decode($file->comments()->value());
$commentData = [
'location' => [
'page' => $page,
'project' => $project,
'file' => $file,
"location" => [
"page" => $page,
"project" => $project,
"file" => $file
],
'position' => [
'x' => $data->position->x,
'y' => $data->position->y,
"position" => [
"x" => $data->position->x,
"y" => $data->position->y
],
'date' => (string) $data->date,
'text' => $data->text,
'author' => kirby()->user(),
'id' => Str::uuid(),
'type' => 'comment',
"date" => (string) $data->date,
"text" => $data->text,
"author" => kirby()->user(),
"id" => Str::uuid(),
"type" => "comment",
];
if (isset($data->position->pageIndex)) {
$commentData['position']['pageIndex'] = $data->position->pageIndex;
$commentData["position"]["pageIndex"] = $data->position->pageIndex;
}
$newComment = new Comment($commentData);
$comments[] = $newComment->toArray();
$comments[] = $newComment->toArray();
$newFile = $file->update([
'comments' => $comments,
]);
'comments' => $comments
]);
echo json_encode(getFileData($newFile));
try {
$project->createNotification($commentData);
$project->createNotification($commentData);
} catch (\Throwable $th) {
throw new Exception($th->getMessage() . '. line ' . $th->getLine() . ' in file ' . $th->getFile(), 1);
throw new Exception($th->getMessage() . ". line " . $th->getLine() . " in file " . $th->getFile(), 1);
}
exit;
},
];
}
];

View file

@ -2,46 +2,45 @@
return [
'pattern' => '(:all)delete-comment.json',
'method' => 'POST',
'method' => 'POST',
'action' => function () {
$json = file_get_contents('php://input');
$data = json_decode($json);
// kirby()->impersonate('kirby');
$page = page($data->location->page->uri);
$file = $page->file($data->location->file->uuid);
$comments = $file->comments()->isEmpty() == true ? [] : Yaml::decode($file->comments()->value());
$isReply = $data->location->parent->id ?? false;
foreach ($comments as $key => &$comment) {
if ($isReply) {
if ($comment['id'] === $data->location->parent->id) {
foreach ($comment['replies'] as $replyKey => $reply) {
if ($reply['id'] === $data->id) {
unset($comment['replies'][$replyKey]);
$comment['replies'] = array_values($comment['replies']);
}
}
}
} else {
if ($comment['id'] === $data->id) {
unset($comments[$key]);
if ($isReply) {
if ($comment['id'] === $data->location->parent->id) {
foreach ($comment['replies'] as $replyKey => $reply) {
if ($reply['id'] === $data->id) {
unset($comment['replies'][$replyKey]);
$comment['replies'] = array_values($comment['replies']);
}
}
}
} else {
if ($comment['id'] === $data->id) {
unset($comments[$key]);
}
}
}
$comments = array_values($comments);
$newFile = $file->update([
'comments' => $comments,
'comments' => $comments
]);
echo json_encode(getFileData($newFile));
$project = $page->parents()->findBy('template', 'project');
$project = $page->parents()->findBy("template", "project");
$project->deleteNotification($data->id);
exit;
},
}
];

View file

@ -17,10 +17,12 @@
</template>
</figure>
<footer
v-if="commentsCount > 0"
v-if="images[0]?.comments?.length > 0"
class="order-last | text-sm text-primary font-medium"
>
{{ commentsCount }} commentaire{{ commentsCount > 1 ? 's' : '' }}
{{ images[0].comments.length }} commentaire{{
images[0].comments.length > 1 ? 's' : ''
}}
</footer>
<div
class="btn btn--xs btn--dtl | mt-16"
@ -35,7 +37,6 @@
<script setup>
import DateTime from './DateTime.vue';
import { useDesignToLightStore } from '../../../stores/designToLight';
import { computed } from 'vue';
const { images, step, uri } = defineProps({
images: Array,
@ -44,30 +45,4 @@ const { images, step, uri } = defineProps({
});
const { isDesignToLightStep } = useDesignToLightStore();
const commentsCount = computed(() => {
let count = 0;
if (Array.isArray(step.files)) {
for (const file of step.files) {
count += file?.comments?.length || 0;
}
} else {
if (step.files?.dynamic) {
for (const track of step.files.dynamic) {
for (const file of track.files) {
count += file?.comments?.length || 0;
}
}
}
if (step.files?.static) {
for (const element of Object.values(step.files.static)) {
count += element?.comments?.length || 0;
}
}
}
return count;
});
</script>