notifications working

This commit is contained in:
isUnknown 2024-11-22 07:53:43 +01:00
parent 699c0bfa1d
commit 8ae00d7657
8 changed files with 28 additions and 202 deletions

View file

@ -28,8 +28,8 @@ Comments:
url: file://s0lNtRA0Z7ybTCWG
position:
pageIndex: 1
x: "64.481176977282"
y: "14.478764478764"
x: '27.05459466102'
y: '35.135135135135'
replies: [ ]
text: test
author:
@ -37,181 +37,7 @@ Comments:
email: adrien.payet@outlook.com
uuid: user://WWjXgPWk
role: admin
date: 2024-11-21T19:18:40+01:00
id: m3rmytqk
type: comment
isRead: false
-
location:
page:
uri: >
projects/miss-dior-blooming-bouquet/client-brief
title: Brief client
href: >
/projects/miss-dior-blooming-bouquet?dialog=client-brief
project:
title: Miss Dior Blooming Bouquet
uri: projects/miss-dior-blooming-bouquet
file:
uuid: file://s0lNtRA0Z7ybTCWG
url: file://s0lNtRA0Z7ybTCWG
position:
pageIndex: 1
x: "64.481176977282"
y: "14.478764478764"
replies: [ ]
text: test
author:
name: Adrien Payet
email: adrien.payet@outlook.com
uuid: user://WWjXgPWk
role: admin
date: 2024-11-21T19:19:27+01:00
id: m3rmzu2u
type: comment
isRead: false
-
location:
page:
uri: >
projects/miss-dior-blooming-bouquet/client-brief
title: Brief client
href: >
/projects/miss-dior-blooming-bouquet?dialog=client-brief
project:
title: Miss Dior Blooming Bouquet
uri: projects/miss-dior-blooming-bouquet
file:
uuid: file://s0lNtRA0Z7ybTCWG
url: file://s0lNtRA0Z7ybTCWG
position:
pageIndex: 1
x: "64.481176977282"
y: "14.478764478764"
replies: [ ]
text: test
author:
name: Adrien Payet
email: adrien.payet@outlook.com
uuid: user://WWjXgPWk
role: admin
date: 2024-11-21T19:19:33+01:00
id: m3rmzyl9
type: comment
isRead: false
-
location:
page:
uri: >
projects/miss-dior-blooming-bouquet/client-brief
title: Brief client
href: >
/projects/miss-dior-blooming-bouquet?dialog=client-brief
project:
title: Miss Dior Blooming Bouquet
uri: projects/miss-dior-blooming-bouquet
file:
uuid: file://s0lNtRA0Z7ybTCWG
url: file://s0lNtRA0Z7ybTCWG
position:
pageIndex: 1
x: "64.481176977282"
y: "14.478764478764"
replies: [ ]
text: test
author:
name: Adrien Payet
email: adrien.payet@outlook.com
uuid: user://WWjXgPWk
role: admin
date: 2024-11-21T19:19:44+01:00
id: m3rn07nl
type: comment
isRead: false
-
location:
page:
uri: >
projects/miss-dior-blooming-bouquet/client-brief
title: Brief client
href: >
/projects/miss-dior-blooming-bouquet?dialog=client-brief
project:
title: Miss Dior Blooming Bouquet
uri: projects/miss-dior-blooming-bouquet
file:
uuid: file://s0lNtRA0Z7ybTCWG
url: file://s0lNtRA0Z7ybTCWG
position:
pageIndex: 1
x: "64.481176977282"
y: "14.478764478764"
replies: [ ]
text: test
author:
name: Adrien Payet
email: adrien.payet@outlook.com
uuid: user://WWjXgPWk
role: admin
date: 2024-11-21T19:20:04+01:00
id: m3rn0mf4
type: comment
isRead: false
-
location:
page:
uri: >
projects/miss-dior-blooming-bouquet/client-brief
title: Brief client
href: >
/projects/miss-dior-blooming-bouquet?dialog=client-brief
project:
title: Miss Dior Blooming Bouquet
uri: projects/miss-dior-blooming-bouquet
file:
uuid: file://s0lNtRA0Z7ybTCWG
url: file://s0lNtRA0Z7ybTCWG
position:
pageIndex: 1
x: "60.383375993749"
y: "31.660231660232"
replies: [ ]
text: test
author:
name: Adrien Payet
email: adrien.payet@outlook.com
uuid: user://WWjXgPWk
role: admin
date: 2024-11-21T19:35:48+01:00
id: m3rnkvcn
type: comment
isRead: false
-
location:
page:
uri: >
projects/miss-dior-blooming-bouquet/client-brief
title: Brief client
href: >
/projects/miss-dior-blooming-bouquet?dialog=client-brief
project:
title: Miss Dior Blooming Bouquet
uri: projects/miss-dior-blooming-bouquet
file:
uuid: file://s0lNtRA0Z7ybTCWG
url: file://s0lNtRA0Z7ybTCWG
position:
pageIndex: 1
x: '64.481176977282'
y: '50.772200772201'
replies: [ ]
text: test
author:
name: Adrien Payet
email: adrien.payet@outlook.com
uuid: user://WWjXgPWk
role: admin
date: 2024-11-21T19:36:11+01:00
id: m3rnld52
date: 2024-11-22T07:49:45+01:00
id: m3sdsq23
type: comment
isRead: false

View file

@ -112,7 +112,17 @@ class ProjectPage extends Page {
return $stepsLabel[$this->currentStep()->value()];
}
public function printManagers() {
return A::implode($this->managers()->toUsers()->pluck('name'), ', ');
// public function printManagers() {
// return A::implode($this->managers()->toUsers()->pluck('name'), ', ');
// }
public function managers() {
return kirby()->users()->filter(function($user) {
if ($user->projects()->isEmpty()) {
return false;
}
return $user->role() === 'admin' || $user->projects()->toPages()->has($this);
});
}
}

View file

@ -53,7 +53,9 @@ return [
try {
$user->sendNotification($page->parent(), $newComment->toArray());
} catch (\Throwable $th) {
return $th->getMessage() . " in " . $th->getFile() . " line " . $th->getLine();
echo json_encode([
"error" => $th->getMessage() . " in " . $th->getFile() . " line " . $th->getLine(),
]);
}
exit;

View file

@ -39,7 +39,7 @@ return [
echo json_encode(getFileData($newFile));
kirby()->user()->deleteNotification($project->managers()->toUsers(), $data->id);
kirby()->user()->deleteNotification($project, $data->id);
exit;
}

View file

@ -1,5 +1,9 @@
<?php
load([
'ProjectPage' => 'models/ProjectPage.php',
], __DIR__);
Kirby::plugin('adrienpayet/pdc-notifications', [
'routes' => [
require(__DIR__ . '/routes/readAll.php'),

View file

@ -1,7 +1,7 @@
<?php
return function($projectManagers, $notificationId) {
foreach ($projectManagers as $projectManager) {
return function($project, $notificationId) {
foreach ($project->managers() as $projectManager) {
try {
$notifications = $projectManager->notifications()->isNotEmpty()
? Yaml::decode($projectManager->notifications()->value())

View file

@ -1,7 +1,6 @@
<?php
return function($notificationId) {
return function($notificationId) {
try {
$notifications = $this->notifications()->isNotEmpty()
? Yaml::decode($this->notifications()->value())

View file

@ -14,22 +14,7 @@
*/
return function ($project, $notificationData) {
$recipients = kirby()->users()->filter(function($user) use ($project) {
if ($user === $this || $user->projects()->isEmpty()) {
return false;
}
throw new Exception(json_encode($user->name()), 1);
$projects = $user->projects();
if ($projects && ($user->role() == 'admin' || $projects->has($project))) {
return false;
}
return false;
});
// $recipients = page($projectUri)->managers()->toUsers()->not($this);
$recipients = $project->managers()->without($this);
if (!$recipients) return;