2021-12-14 18:32:47 +00:00
< ? php
declare ( strict_types = 1 );
2009-12-24 07:36:09 +00:00
2023-01-10 22:44:09 +00:00
namespace Shimmie2 ;
2019-05-28 16:59:38 +00:00
class Notes extends Extension
{
2020-01-26 13:19:35 +00:00
/** @var NotesTheme */
2023-06-27 14:56:49 +00:00
protected Themelet $theme ;
2020-01-26 13:19:35 +00:00
2024-01-15 18:01:48 +00:00
public function onInitExt ( InitExtEvent $event ) : void
{
Image :: $prop_types [ " notes " ] = ImagePropType :: INT ;
}
2024-01-15 11:52:35 +00:00
public function onDatabaseUpgrade ( DatabaseUpgradeEvent $event ) : void
2019-05-28 16:59:38 +00:00
{
global $config , $database ;
// shortcut to latest
2019-11-03 19:49:52 +00:00
if ( $this -> get_version ( " ext_notes_version " ) < 1 ) {
2020-10-25 21:34:52 +00:00
$database -> execute ( " ALTER TABLE images ADD COLUMN notes INTEGER NOT NULL DEFAULT 0 " );
2019-05-28 16:59:38 +00:00
$database -> create_table ( " notes " , "
2009-12-24 07:36:09 +00:00
id SCORE_AIPK ,
enable INTEGER NOT NULL ,
image_id INTEGER NOT NULL ,
user_id INTEGER NOT NULL ,
user_ip CHAR ( 15 ) NOT NULL ,
2019-11-03 19:25:51 +00:00
date TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ,
2009-12-24 07:36:09 +00:00
x1 INTEGER NOT NULL ,
y1 INTEGER NOT NULL ,
height INTEGER NOT NULL ,
width INTEGER NOT NULL ,
note TEXT NOT NULL ,
2012-03-11 02:13:18 +00:00
FOREIGN KEY ( user_id ) REFERENCES users ( id ) ON UPDATE CASCADE ON DELETE CASCADE ,
2009-12-24 07:36:09 +00:00
FOREIGN KEY ( image_id ) REFERENCES images ( id ) ON DELETE CASCADE
" );
2019-05-28 16:59:38 +00:00
$database -> execute ( " CREATE INDEX notes_image_id_idx ON notes(image_id) " , []);
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
$database -> create_table ( " note_request " , "
2009-12-24 07:36:09 +00:00
id SCORE_AIPK ,
image_id INTEGER NOT NULL ,
user_id INTEGER NOT NULL ,
2019-11-03 19:25:51 +00:00
date TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ,
2012-03-11 02:13:18 +00:00
FOREIGN KEY ( user_id ) REFERENCES users ( id ) ON UPDATE CASCADE ON DELETE CASCADE ,
2009-12-24 07:36:09 +00:00
FOREIGN KEY ( image_id ) REFERENCES images ( id ) ON DELETE CASCADE
" );
2019-05-28 16:59:38 +00:00
$database -> execute ( " CREATE INDEX note_request_image_id_idx ON note_request(image_id) " , []);
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
$database -> create_table ( " note_histories " , "
2009-12-24 07:36:09 +00:00
id SCORE_AIPK ,
note_enable INTEGER NOT NULL ,
note_id INTEGER NOT NULL ,
review_id INTEGER NOT NULL ,
image_id INTEGER NOT NULL ,
user_id INTEGER NOT NULL ,
user_ip CHAR ( 15 ) NOT NULL ,
2019-11-03 19:25:51 +00:00
date TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ,
2009-12-24 07:36:09 +00:00
x1 INTEGER NOT NULL ,
y1 INTEGER NOT NULL ,
height INTEGER NOT NULL ,
width INTEGER NOT NULL ,
note TEXT NOT NULL ,
2012-03-11 02:13:18 +00:00
FOREIGN KEY ( user_id ) REFERENCES users ( id ) ON UPDATE CASCADE ON DELETE CASCADE ,
2009-12-24 07:36:09 +00:00
FOREIGN KEY ( note_id ) REFERENCES notes ( id ) ON DELETE CASCADE
" );
2019-05-28 16:59:38 +00:00
$database -> execute ( " CREATE INDEX note_histories_image_id_idx ON note_histories(image_id) " , []);
$config -> set_int ( " notesNotesPerPage " , 20 );
$config -> set_int ( " notesRequestsPerPage " , 20 );
$config -> set_int ( " notesHistoriesPerPage " , 20 );
2019-11-03 19:49:52 +00:00
$this -> set_version ( " ext_notes_version " , 1 );
2019-05-28 16:59:38 +00:00
}
}
2024-01-15 11:52:35 +00:00
public function onPageRequest ( PageRequestEvent $event ) : void
2019-05-28 16:59:38 +00:00
{
global $page , $user ;
if ( $event -> page_matches ( " note " )) {
switch ( $event -> get_arg ( 0 )) {
case " list " : //index
$this -> get_notes_list ( $event ); // This should show images like post/list but i don't know how do that.
break ;
case " requests " : // The same as post/list but only for note_request table.
$this -> get_notes_requests ( $event ); // This should show images like post/list but i don't know how do that.
break ;
case " search " :
if ( ! $user -> is_anonymous ()) {
$this -> theme -> search_notes_page ( $page );
}
break ;
case " updated " : //Thinking how to build this function.
$this -> get_histories ( $event );
break ;
case " history " : //Thinking how to build this function.
$this -> get_history ( $event );
break ;
case " revert " :
2020-01-26 13:19:35 +00:00
$noteID = int_escape ( $event -> get_arg ( 1 ));
$reviewID = int_escape ( $event -> get_arg ( 2 ));
2019-05-28 16:59:38 +00:00
if ( ! $user -> is_anonymous ()) {
$this -> revert_history ( $noteID , $reviewID );
}
2019-06-19 01:58:28 +00:00
$page -> set_mode ( PageMode :: REDIRECT );
2019-05-28 16:59:38 +00:00
$page -> set_redirect ( make_link ( " note/updated " ));
break ;
case " add_request " :
if ( ! $user -> is_anonymous ()) {
$this -> add_note_request ();
}
2019-06-19 01:58:28 +00:00
$page -> set_mode ( PageMode :: REDIRECT );
2019-05-28 16:59:38 +00:00
$page -> set_redirect ( make_link ( " post/view/ " . $_POST [ " image_id " ]));
break ;
case " nuke_requests " :
2019-09-29 18:00:51 +00:00
if ( $user -> can ( Permissions :: NOTES_ADMIN )) {
2019-05-28 16:59:38 +00:00
$this -> nuke_requests ();
}
2019-06-19 01:58:28 +00:00
$page -> set_mode ( PageMode :: REDIRECT );
2019-05-28 16:59:38 +00:00
$page -> set_redirect ( make_link ( " post/view/ " . $_POST [ " image_id " ]));
break ;
2024-01-05 02:03:41 +00:00
case " create_note " :
$page -> set_mode ( PageMode :: DATA );
if ( ! $user -> is_anonymous ()) {
$note_id = $this -> add_new_note ();
2024-01-20 20:48:47 +00:00
$page -> set_data ( json_encode_ex ([
2024-01-05 02:03:41 +00:00
'status' => 'success' ,
'note_id' => $note_id ,
]));
}
break ;
case " update_note " :
$page -> set_mode ( PageMode :: DATA );
2019-05-28 16:59:38 +00:00
if ( ! $user -> is_anonymous ()) {
$this -> update_note ();
2024-01-20 20:48:47 +00:00
$page -> set_data ( json_encode_ex ([ 'status' => 'success' ]));
2019-05-28 16:59:38 +00:00
}
break ;
case " delete_note " :
2024-01-05 02:03:41 +00:00
$page -> set_mode ( PageMode :: DATA );
2019-09-29 18:00:51 +00:00
if ( $user -> can ( Permissions :: NOTES_ADMIN )) {
2019-05-28 16:59:38 +00:00
$this -> delete_note ();
2024-01-20 20:48:47 +00:00
$page -> set_data ( json_encode_ex ([ 'status' => 'success' ]));
2019-05-28 16:59:38 +00:00
}
break ;
2024-01-05 02:03:41 +00:00
case " nuke_notes " :
if ( $user -> can ( Permissions :: NOTES_ADMIN )) {
$this -> nuke_notes ();
}
$page -> set_mode ( PageMode :: REDIRECT );
$page -> set_redirect ( make_link ( " post/view/ " . $_POST [ " image_id " ]));
break ;
2019-05-28 16:59:38 +00:00
default :
2019-06-19 01:58:28 +00:00
$page -> set_mode ( PageMode :: REDIRECT );
2019-05-28 16:59:38 +00:00
$page -> set_redirect ( make_link ( " note/list " ));
break ;
}
}
}
/*
* HERE WE LOAD THE NOTES IN THE IMAGE
*/
2024-01-15 11:52:35 +00:00
public function onDisplayingImage ( DisplayingImageEvent $event ) : void
2019-05-28 16:59:38 +00:00
{
global $page , $user ;
//display form on image event
$notes = $this -> get_notes ( $event -> image -> id );
2019-09-29 18:00:51 +00:00
$this -> theme -> display_note_system ( $page , $event -> image -> id , $notes , $user -> can ( Permissions :: NOTES_ADMIN ));
2019-05-28 16:59:38 +00:00
}
/*
* HERE WE ADD THE BUTTONS ON SIDEBAR
*/
2024-01-15 11:52:35 +00:00
public function onImageAdminBlockBuilding ( ImageAdminBlockBuildingEvent $event ) : void
2019-05-28 16:59:38 +00:00
{
global $user ;
if ( ! $user -> is_anonymous ()) {
$event -> add_part ( $this -> theme -> note_button ( $event -> image -> id ));
$event -> add_part ( $this -> theme -> request_button ( $event -> image -> id ));
2019-09-29 18:00:51 +00:00
if ( $user -> can ( Permissions :: NOTES_ADMIN )) {
2019-05-28 16:59:38 +00:00
$event -> add_part ( $this -> theme -> nuke_notes_button ( $event -> image -> id ));
$event -> add_part ( $this -> theme -> nuke_requests_button ( $event -> image -> id ));
}
}
}
/*
* HERE WE ADD QUERYLETS TO ADD SEARCH SYSTEM
*/
2024-01-15 11:52:35 +00:00
public function onSearchTermParse ( SearchTermParseEvent $event ) : void
2019-05-28 16:59:38 +00:00
{
2020-01-26 16:38:26 +00:00
if ( is_null ( $event -> term )) {
return ;
}
2020-01-26 13:19:35 +00:00
2019-05-28 16:59:38 +00:00
$matches = [];
if ( preg_match ( " /^note[=|:](.*) $ /i " , $event -> term , $matches )) {
$notes = int_escape ( $matches [ 1 ]);
$event -> add_querylet ( new Querylet ( " images.id IN (SELECT image_id FROM notes WHERE note = $notes ) " ));
} elseif ( preg_match ( " /^notes([:]?<|[:]?>|[:]?<=|[:]?>=|[:|=])( \ d+)%/i " , $event -> term , $matches )) {
$cmp = ltrim ( $matches [ 1 ], " : " ) ? : " = " ;
$notes = $matches [ 2 ];
$event -> add_querylet ( new Querylet ( " images.id IN (SELECT id FROM images WHERE notes $cmp $notes ) " ));
} elseif ( preg_match ( " /^notes_by[=|:](.*) $ /i " , $event -> term , $matches )) {
2019-11-11 16:31:14 +00:00
$user_id = User :: name_to_id ( $matches [ 1 ]);
2019-05-28 16:59:38 +00:00
$event -> add_querylet ( new Querylet ( " images.id IN (SELECT image_id FROM notes WHERE user_id = $user_id ) " ));
2019-08-02 20:05:49 +00:00
} elseif ( preg_match ( " /^(notes_by_userno|notes_by_user_id)[=|:]( \ d+) $ /i " , $event -> term , $matches )) {
$user_id = int_escape ( $matches [ 2 ]);
2019-05-28 16:59:38 +00:00
$event -> add_querylet ( new Querylet ( " images.id IN (SELECT image_id FROM notes WHERE user_id = $user_id ) " ));
}
2019-08-02 20:05:49 +00:00
}
2024-01-15 11:52:35 +00:00
public function onHelpPageBuilding ( HelpPageBuildingEvent $event ) : void
2019-08-02 20:05:49 +00:00
{
2023-11-11 21:49:12 +00:00
if ( $event -> key === HelpPages :: SEARCH ) {
2019-08-02 20:05:49 +00:00
$block = new Block ();
$block -> header = " Notes " ;
$block -> body = $this -> theme -> get_help_html ();
$event -> add_block ( $block );
}
2019-05-28 16:59:38 +00:00
}
/**
* HERE WE GET ALL NOTES FOR DISPLAYED IMAGE .
2024-01-20 14:10:59 +00:00
*
* @ return array < string , mixed >
2019-05-28 16:59:38 +00:00
*/
private function get_notes ( int $imageID ) : array
{
global $database ;
2019-11-27 11:22:46 +00:00
return $database -> get_all ( "
SELECT *
FROM notes
WHERE enable = : enable AND image_id = : image_id
ORDER BY date ASC
2023-11-11 21:49:12 +00:00
" , ['enable' => '1', 'image_id' => $imageID ]);
2019-05-28 16:59:38 +00:00
}
/*
* HERE WE ADD A NOTE TO DATABASE
*/
2024-01-05 02:03:41 +00:00
private function add_new_note () : int
2019-05-28 16:59:38 +00:00
{
global $database , $user ;
2024-01-20 20:48:47 +00:00
$note = json_decode ( file_get_contents_ex ( 'php://input' ), true );
2019-05-28 16:59:38 +00:00
2023-06-25 20:31:11 +00:00
$database -> execute (
2019-05-28 16:59:38 +00:00
"
2016-05-18 13:36:50 +00:00
INSERT INTO notes ( enable , image_id , user_id , user_ip , date , x1 , y1 , height , width , note )
2023-06-25 20:31:11 +00:00
VALUES ( : enable , : image_id , : user_id , : user_ip , now (), : x1 , : y1 , : height , : width , : note ) " ,
2024-01-05 02:03:41 +00:00
[
'enable' => 1 ,
'image_id' => $note [ 'image_id' ],
'user_id' => $user -> id ,
'user_ip' => get_real_ip (),
'x1' => $note [ 'x1' ],
'y1' => $note [ 'y1' ],
'height' => $note [ 'height' ],
'width' => $note [ 'width' ],
'note' => $note [ 'note' ],
]
2019-05-28 16:59:38 +00:00
);
2009-12-24 07:36:09 +00:00
2023-06-25 20:31:11 +00:00
$noteID = $database -> get_last_insert_id ( 'notes_id_seq' );
2019-05-28 16:59:38 +00:00
log_info ( " notes " , " Note added { $noteID } by { $user -> name } " );
2009-12-24 07:36:09 +00:00
2024-01-05 02:03:41 +00:00
$database -> execute ( " UPDATE images SET notes=(SELECT COUNT(*) FROM notes WHERE image_id=:id) WHERE id=:id " , [ 'id' => $note [ 'image_id' ]]);
2009-12-24 07:36:09 +00:00
2024-01-05 02:03:41 +00:00
$this -> add_history (
2024-01-05 04:06:19 +00:00
1 ,
$noteID ,
$note [ 'image_id' ],
$note [ 'x1' ],
$note [ 'y1' ],
$note [ 'height' ],
$note [ 'width' ],
2024-01-05 02:03:41 +00:00
$note [ 'note' ]
);
return $noteID ;
2019-05-28 16:59:38 +00:00
}
2016-05-18 13:36:50 +00:00
2024-01-20 14:10:59 +00:00
private function add_note_request () : void
2019-05-28 16:59:38 +00:00
{
global $database , $user ;
2009-12-24 07:36:09 +00:00
2019-05-28 16:59:38 +00:00
$image_id = int_escape ( $_POST [ " image_id " ]);
$user_id = $user -> id ;
2009-12-24 07:36:09 +00:00
2023-06-25 20:31:11 +00:00
$database -> execute (
2019-05-28 16:59:38 +00:00
"
2016-05-18 13:36:50 +00:00
INSERT INTO note_request ( image_id , user_id , date )
2023-06-25 20:31:11 +00:00
VALUES ( : image_id , : user_id , now ()) " ,
2023-11-11 21:49:12 +00:00
[ 'image_id' => $image_id , 'user_id' => $user_id ]
2019-05-28 16:59:38 +00:00
);
2023-06-25 20:31:11 +00:00
$resultID = $database -> get_last_insert_id ( 'note_request_id_seq' );
2019-05-28 16:59:38 +00:00
log_info ( " notes " , " Note requested { $resultID } by { $user -> name } " );
}
2024-01-20 14:10:59 +00:00
private function update_note () : void
2019-05-28 16:59:38 +00:00
{
global $database ;
2024-01-20 20:48:47 +00:00
$note = json_decode ( file_get_contents_ex ( 'php://input' ), true );
2019-05-28 16:59:38 +00:00
// validate parameters
2023-02-04 20:50:26 +00:00
if ( empty ( $note [ 'note' ])) {
2019-05-28 16:59:38 +00:00
return ;
}
2019-11-27 11:22:46 +00:00
$database -> execute ( "
UPDATE notes
SET x1 = : x1 , y1 = : y1 , height = : height , width = : width , note = : note
2024-01-05 02:03:41 +00:00
WHERE image_id = : image_id AND id = : note_id " , $note );
2019-05-28 16:59:38 +00:00
2024-01-05 02:03:41 +00:00
$this -> add_history ( 1 , $note [ 'note_id' ], $note [ 'image_id' ], $note [ 'x1' ], $note [ 'y1' ], $note [ 'height' ], $note [ 'width' ], $note [ 'note' ]);
2019-05-28 16:59:38 +00:00
}
2024-01-20 14:10:59 +00:00
private function delete_note () : void
2019-05-28 16:59:38 +00:00
{
global $user , $database ;
2016-05-18 13:36:50 +00:00
2024-01-20 20:48:47 +00:00
$note = json_decode ( file_get_contents_ex ( 'php://input' ), true );
2019-11-27 11:22:46 +00:00
$database -> execute ( "
UPDATE notes SET enable = : enable
WHERE image_id = : image_id AND id = : id
2024-01-05 02:03:41 +00:00
" , ['enable' => 0, 'image_id' => $note["image_id"] , 'id' => $note["note_id"] ]);
2016-05-18 13:36:50 +00:00
2024-01-05 02:03:41 +00:00
log_info ( " notes " , " Note deleted { $note [ " note_id " ] } by { $user -> name } " );
2019-05-28 16:59:38 +00:00
}
2009-12-24 07:36:09 +00:00
2024-01-20 14:10:59 +00:00
private function nuke_notes () : void
2019-05-28 16:59:38 +00:00
{
global $database , $user ;
$image_id = int_escape ( $_POST [ " image_id " ]);
2023-11-11 21:49:12 +00:00
$database -> execute ( " DELETE FROM notes WHERE image_id = :image_id " , [ 'image_id' => $image_id ]);
2019-05-28 16:59:38 +00:00
log_info ( " notes " , " Notes deleted from { $image_id } by { $user -> name } " );
}
2009-12-24 07:36:09 +00:00
2024-01-20 14:10:59 +00:00
private function nuke_requests () : void
2019-05-28 16:59:38 +00:00
{
global $database , $user ;
$image_id = int_escape ( $_POST [ " image_id " ]);
2009-12-24 07:36:09 +00:00
2023-11-11 21:49:12 +00:00
$database -> execute ( " DELETE FROM note_request WHERE image_id = :image_id " , [ 'image_id' => $image_id ]);
2009-12-24 07:36:09 +00:00
2019-05-28 16:59:38 +00:00
log_info ( " notes " , " Requests deleted from { $image_id } by { $user -> name } " );
}
2016-05-18 13:36:50 +00:00
2024-01-20 14:10:59 +00:00
private function get_notes_list ( PageRequestEvent $event ) : void
2019-05-28 16:59:38 +00:00
{
global $database , $config ;
2009-12-24 07:36:09 +00:00
2020-03-27 14:41:24 +00:00
$pageNumber = $event -> try_page_num ( 1 );
2019-05-28 16:59:38 +00:00
$notesPerPage = $config -> get_int ( 'notesNotesPerPage' );
2024-01-20 20:48:47 +00:00
$totalPages = ( int ) ceil ( $database -> get_one ( " SELECT COUNT(DISTINCT image_id) FROM notes " ) / $notesPerPage );
2019-05-28 16:59:38 +00:00
2019-11-27 11:22:46 +00:00
//$result = $database->get_all("SELECT * FROM pool_images WHERE pool_id=:pool_id", ['pool_id'=>$poolID]);
2024-01-20 20:48:47 +00:00
$image_ids = $database -> get_col (
2019-11-27 12:13:04 +00:00
"
2019-11-27 11:22:46 +00:00
SELECT DISTINCT image_id
FROM notes
WHERE enable = : enable
ORDER BY date DESC LIMIT : limit OFFSET : offset " ,
2023-11-11 21:49:12 +00:00
[ 'enable' => 1 , 'offset' => $pageNumber * $notesPerPage , 'limit' => $notesPerPage ]
2019-05-28 16:59:38 +00:00
);
$images = [];
2024-01-20 20:48:47 +00:00
foreach ( $image_ids as $id ) {
$images [] = Image :: by_id ( $id );
2019-05-28 16:59:38 +00:00
}
2009-12-24 07:36:09 +00:00
2019-05-28 16:59:38 +00:00
$this -> theme -> display_note_list ( $images , $pageNumber + 1 , $totalPages );
}
2009-12-24 07:36:09 +00:00
2024-01-20 14:10:59 +00:00
private function get_notes_requests ( PageRequestEvent $event ) : void
2019-05-28 16:59:38 +00:00
{
global $config , $database ;
2016-05-18 13:36:50 +00:00
2020-03-27 14:41:24 +00:00
$pageNumber = $event -> try_page_num ( 1 );
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
$requestsPerPage = $config -> get_int ( 'notesRequestsPerPage' );
2016-05-18 13:36:50 +00:00
2019-11-27 11:22:46 +00:00
//$result = $database->get_all("SELECT * FROM pool_images WHERE pool_id=:pool_id", ['pool_id'=>$poolID]);
2009-12-24 07:36:09 +00:00
2019-05-28 16:59:38 +00:00
$result = $database -> execute (
"
2019-11-27 11:22:46 +00:00
SELECT DISTINCT image_id
FROM note_request
ORDER BY date DESC LIMIT : limit OFFSET : offset " ,
2023-11-11 21:49:12 +00:00
[ " offset " => $pageNumber * $requestsPerPage , " limit " => $requestsPerPage ]
2019-05-28 16:59:38 +00:00
);
2016-05-18 13:36:50 +00:00
2024-01-20 14:10:59 +00:00
$totalPages = ( int ) ceil ( $database -> get_one ( " SELECT COUNT(*) FROM note_request " ) / $requestsPerPage );
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
$images = [];
while ( $row = $result -> fetch ()) {
2024-01-20 20:48:47 +00:00
$images [] = Image :: by_id ( $row [ " image_id " ]);
2019-05-28 16:59:38 +00:00
}
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
$this -> theme -> display_note_requests ( $images , $pageNumber + 1 , $totalPages );
}
2016-05-18 13:36:50 +00:00
2024-01-20 14:10:59 +00:00
private function add_history ( int $noteEnable , int $noteID , int $imageID , int $noteX1 , int $noteY1 , int $noteHeight , int $noteWidth , string $noteText ) : void
2019-05-28 16:59:38 +00:00
{
global $user , $database ;
2016-05-18 13:36:50 +00:00
2023-11-11 21:49:12 +00:00
$reviewID = $database -> get_one ( " SELECT COUNT(*) FROM note_histories WHERE note_id = :note_id " , [ 'note_id' => $noteID ]);
2019-05-28 16:59:38 +00:00
$reviewID = $reviewID + 1 ;
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
$database -> execute (
"
2016-05-18 13:36:50 +00:00
INSERT INTO note_histories ( note_enable , note_id , review_id , image_id , user_id , user_ip , date , x1 , y1 , height , width , note )
2019-11-27 11:22:46 +00:00
VALUES ( : note_enable , : note_id , : review_id , : image_id , : user_id , : user_ip , now (), : x1 , : y1 , : height , : width , : note )
" ,
2023-11-11 21:49:12 +00:00
[ 'note_enable' => $noteEnable , 'note_id' => $noteID , 'review_id' => $reviewID , 'image_id' => $imageID , 'user_id' => $user -> id , 'user_ip' => get_real_ip (),
'x1' => $noteX1 , 'y1' => $noteY1 , 'height' => $noteHeight , 'width' => $noteWidth , 'note' => $noteText ]
2019-05-28 16:59:38 +00:00
);
}
2024-01-20 14:10:59 +00:00
private function get_histories ( PageRequestEvent $event ) : void
2019-05-28 16:59:38 +00:00
{
global $config , $database ;
2020-03-27 14:41:24 +00:00
$pageNumber = $event -> try_page_num ( 1 );
2019-05-28 16:59:38 +00:00
$historiesPerPage = $config -> get_int ( 'notesHistoriesPerPage' );
//ORDER BY IMAGE & DATE
$histories = $database -> get_all (
" SELECT h.note_id, h.review_id, h.image_id, h.date, h.note, u.name AS user_name " .
" FROM note_histories AS h " .
" INNER JOIN users AS u " .
" ON u.id = h.user_id " .
2019-11-27 11:22:46 +00:00
" ORDER BY date DESC LIMIT :limit OFFSET :offset " ,
2023-11-11 21:49:12 +00:00
[ 'offset' => $pageNumber * $historiesPerPage , 'limit' => $historiesPerPage ]
2019-05-28 16:59:38 +00:00
);
2024-01-20 14:10:59 +00:00
$totalPages = ( int ) ceil ( $database -> get_one ( " SELECT COUNT(*) FROM note_histories " ) / $historiesPerPage );
2019-05-28 16:59:38 +00:00
$this -> theme -> display_histories ( $histories , $pageNumber + 1 , $totalPages );
}
2024-01-20 14:10:59 +00:00
private function get_history ( PageRequestEvent $event ) : void
2019-05-28 16:59:38 +00:00
{
global $config , $database ;
$noteID = $event -> get_arg ( 1 );
2019-11-04 00:40:10 +00:00
$pageNumber = $event -> try_page_num ( 2 );
2019-05-28 16:59:38 +00:00
$historiesPerPage = $config -> get_int ( 'notesHistoriesPerPage' );
$histories = $database -> get_all (
" SELECT h.note_id, h.review_id, h.image_id, h.date, h.note, u.name AS user_name " .
" FROM note_histories AS h " .
" INNER JOIN users AS u " .
" ON u.id = h.user_id " .
2019-11-27 11:22:46 +00:00
" WHERE note_id = :note_id " .
" ORDER BY date DESC LIMIT :limit OFFSET :offset " ,
2023-11-11 21:49:12 +00:00
[ 'note_id' => $noteID , 'offset' => $pageNumber * $historiesPerPage , 'limit' => $historiesPerPage ]
2019-05-28 16:59:38 +00:00
);
2024-01-20 14:10:59 +00:00
$totalPages = ( int ) ceil ( $database -> get_one ( " SELECT COUNT(*) FROM note_histories WHERE note_id = :note_id " , [ 'note_id' => $noteID ]) / $historiesPerPage );
2019-05-28 16:59:38 +00:00
$this -> theme -> display_history ( $histories , $pageNumber + 1 , $totalPages );
}
/**
* HERE GO BACK IN HISTORY AND SET THE OLD NOTE . IF WAS REMOVED WE RE - ADD IT .
*/
2024-01-20 14:10:59 +00:00
private function revert_history ( int $noteID , int $reviewID ) : void
2019-05-28 16:59:38 +00:00
{
global $database ;
2023-11-11 21:49:12 +00:00
$history = $database -> get_row ( " SELECT * FROM note_histories WHERE note_id = :note_id AND review_id = :review_id " , [ 'note_id' => $noteID , 'review_id' => $reviewID ]);
2019-05-28 16:59:38 +00:00
$noteEnable = $history [ 'note_enable' ];
$noteID = $history [ 'note_id' ];
$imageID = $history [ 'image_id' ];
$noteX1 = $history [ 'x1' ];
$noteY1 = $history [ 'y1' ];
$noteHeight = $history [ 'height' ];
$noteWidth = $history [ 'width' ];
$noteText = $history [ 'note' ];
2019-11-27 11:22:46 +00:00
$database -> execute ( "
2020-01-26 13:19:35 +00:00
UPDATE notes
2019-11-27 11:22:46 +00:00
SET enable = : enable , x1 = : x1 , y1 = : y1 , height = : height , width = : width , note = : note
WHERE image_id = : image_id AND id = : id
2023-11-11 21:49:12 +00:00
" , ['enable' => 1, 'x1' => $noteX1 , 'y1' => $noteY1 , 'height' => $noteHeight , 'width' => $noteWidth , 'note' => $noteText , 'image_id' => $imageID , 'id' => $noteID ]);
2019-05-28 16:59:38 +00:00
$this -> add_history ( $noteEnable , $noteID , $imageID , $noteX1 , $noteY1 , $noteHeight , $noteWidth , $noteText );
}
2009-12-24 07:36:09 +00:00
}