optimize seen

This commit is contained in:
Dennis Eichhorn 2022-03-22 16:33:00 +01:00
parent 3773d9eb40
commit 1cc6721c12
3 changed files with 49 additions and 24 deletions

View File

@ -207,12 +207,6 @@
"foreignTable": "account",
"foreignKey": "account_id"
},
"task_account_seen": {
"name": "task_account_seen",
"type": "TINYINT",
"default": 0,
"null": false
},
"task_account_duty": {
"name": "task_account_duty",
"type": "TINYINT",
@ -317,12 +311,8 @@
"task_seen_at": {
"name": "task_seen_at",
"type": "DATETIME",
"null": false
},
"task_seen_flag": {
"name": "task_seen_flag",
"type": "TINYINT",
"null": false
"null": true,
"default": null
},
"task_seen_by": {
"name": "task_seen_by",
@ -337,6 +327,25 @@
"null": false,
"foreignTable": "task",
"foreignKey": "task_id"
},
"task_seen_reminder": {
"name": "task_seen_reminder",
"type": "TINYINT",
"null": false
},
"task_seen_reminder_at": {
"name": "task_seen_reminder_at",
"type": "DATETIME",
"null": true,
"default": null
},
"task_seen_reminder_by": {
"name": "task_seen_reminder_by",
"type": "INT",
"null": true,
"default": null,
"foreignTable": "account",
"foreignKey": "account_id"
}
}
}

View File

@ -14,6 +14,8 @@ declare(strict_types=1);
namespace Modules\Tasks\Models;
use Modules\Admin\Models\Account;
/**
* Null model
*
@ -38,16 +40,11 @@ class TaskSeen
public int $task = 0;
/**
* The flag allows to set a task as not seen even it was already seen.
*
* This is helpful for changes to a task or forwarding which should be signaled to the user.
* Another situation could be if a user wants to mark a task as unseen in order to check it out later on again.
*
* @var bool
* @since 1.0.0
*/
public bool $flag = false;
public ?\DateTime $reminderAt = null;
public bool $isRemindered = false;
public ?Account $reminderBy = null;
/**
* Constructor.

View File

@ -14,10 +14,14 @@ declare(strict_types=1);
namespace Modules\Tasks\Models;
use Modules\Admin\Models\AccountMapper;
use phpOMS\DataStorage\Database\Mapper\DataMapperFactory;
/**
* Tasks mapper class.
* Task seen mapper class.
*
* This class is used to mark a task as seen. Additionally, you may set a reminder flag which can be used to highlight
* a task.
*
* @package Modules\Tasks\Models
* @license OMS License 1.0
@ -37,7 +41,22 @@ final class TaskSeenMapper extends DataMapperFactory
'task_seen_at' => ['name' => 'task_seen_at', 'type' => 'DateTime', 'internal' => 'seenAt'],
'task_seen_task' => ['name' => 'task_seen_task', 'type' => 'int', 'internal' => 'task'],
'task_seen_by' => ['name' => 'task_seen_by', 'type' => 'int', 'internal' => 'seenBy'],
'task_seen_flag' => ['name' => 'task_seen_flag', 'type' => 'bool', 'internal' => 'flag'],
'task_seen_reminder' => ['name' => 'task_seen_reminder', 'type' => 'bool', 'internal' => 'isRemindered'],
'task_seen_reminder_at' => ['name' => 'task_seen_reminder_at', 'type' => 'DateTime', 'internal' => 'reminderAt'],
'task_seen_reminder_by' => ['name' => 'task_seen_reminder_by', 'type' => 'int', 'internal' => 'reminderBy'],
];
/**
* Belongs to.
*
* @var array<string, array{mapper:string, external:string}>
* @since 1.0.0
*/
public const BELONGS_TO = [
'reminderBy' => [
'mapper' => AccountMapper::class,
'external' => 'task_seen_reminder_by',
],
];
/**