2020-01-26 13:19:35 +00:00
< ? php declare ( strict_types = 1 );
2009-12-24 07:36:09 +00:00
2019-05-28 16:59:38 +00:00
class Notes extends Extension
{
2020-01-26 13:19:35 +00:00
/** @var NotesTheme */
protected $theme ;
2019-11-03 17:19:37 +00:00
public function onDatabaseUpgrade ( DatabaseUpgradeEvent $event )
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 ) {
2019-05-28 16:59:38 +00:00
$database -> Execute ( " ALTER TABLE images ADD COLUMN notes INTEGER NOT NULL DEFAULT 0 " );
$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
}
}
public function onPageRequest ( PageRequestEvent $event )
{
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_note " :
if ( ! $user -> is_anonymous ()) {
$this -> add_new_note ();
}
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 " 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_notes " :
2019-09-29 18:00:51 +00:00
if ( $user -> can ( Permissions :: NOTES_ADMIN )) {
2019-05-28 16:59:38 +00:00
$this -> nuke_notes ();
}
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 ;
case " edit_note " :
if ( ! $user -> is_anonymous ()) {
$this -> update_note ();
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 " delete_note " :
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 ();
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 ;
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
*/
public function onDisplayingImage ( DisplayingImageEvent $event )
{
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
*/
public function onImageAdminBlockBuilding ( ImageAdminBlockBuildingEvent $event )
{
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
*/
public function onSearchTermParse ( SearchTermParseEvent $event )
{
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
}
public function onHelpPageBuilding ( HelpPageBuildingEvent $event )
{
2019-09-29 13:30:55 +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 .
*/
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
" , ['enable'=>'1', 'image_id'=> $imageID ]);
2019-05-28 16:59:38 +00:00
}
/*
* HERE WE ADD A NOTE TO DATABASE
*/
private function add_new_note ()
{
global $database , $user ;
$imageID = int_escape ( $_POST [ " image_id " ]);
$user_id = $user -> id ;
$noteX1 = int_escape ( $_POST [ " note_x1 " ]);
$noteY1 = int_escape ( $_POST [ " note_y1 " ]);
$noteHeight = int_escape ( $_POST [ " note_height " ]);
$noteWidth = int_escape ( $_POST [ " note_width " ]);
$noteText = html_escape ( $_POST [ " note_text " ]);
$database -> execute (
"
2016-05-18 13:36:50 +00:00
INSERT INTO notes ( enable , image_id , user_id , user_ip , date , x1 , y1 , height , width , note )
2019-11-27 11:22:46 +00:00
VALUES ( : enable , : image_id , : user_id , : user_ip , now (), : x1 , : y1 , : height , : width , : note ) " ,
[ 'enable' => 1 , 'image_id' => $imageID , 'user_id' => $user_id , 'user_ip' => $_SERVER [ 'REMOTE_ADDR' ], 'x1' => $noteX1 , 'y1' => $noteY1 , 'height' => $noteHeight , 'width' => $noteWidth , 'note' => $noteText ]
2019-05-28 16:59:38 +00:00
);
2009-12-24 07:36:09 +00:00
2019-05-28 16:59:38 +00:00
$noteID = $database -> get_last_insert_id ( 'notes_id_seq' );
2009-12-24 07:36:09 +00:00
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
2019-11-27 11:22:46 +00:00
$database -> execute ( " UPDATE images SET notes=(SELECT COUNT(*) FROM notes WHERE image_id=:id1) WHERE id=:id2 " , [ 'id1' => $imageID , 'id2' => $imageID ]);
2009-12-24 07:36:09 +00:00
2019-05-28 16:59:38 +00:00
$this -> add_history ( 1 , $noteID , $imageID , $noteX1 , $noteY1 , $noteHeight , $noteWidth , $noteText );
}
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
private function add_note_request ()
{
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
2019-05-28 16:59:38 +00:00
$database -> execute (
"
2016-05-18 13:36:50 +00:00
INSERT INTO note_request ( image_id , user_id , date )
2019-11-27 11:22:46 +00:00
VALUES ( : image_id , : user_id , now ()) " ,
[ 'image_id' => $image_id , 'user_id' => $user_id ]
2019-05-28 16:59:38 +00:00
);
$resultID = $database -> get_last_insert_id ( 'note_request_id_seq' );
log_info ( " notes " , " Note requested { $resultID } by { $user -> name } " );
}
private function update_note ()
{
global $database ;
$note = [
2019-11-27 11:22:46 +00:00
" x1 " => int_escape ( $_POST [ " note_x1 " ]),
" y1 " => int_escape ( $_POST [ " note_y1 " ]),
" height " => int_escape ( $_POST [ " note_height " ]),
" width " => int_escape ( $_POST [ " note_width " ]),
2020-01-28 00:16:22 +00:00
" note " => $_POST [ " note_text " ],
2019-11-27 11:22:46 +00:00
" image_id " => int_escape ( $_POST [ " image_id " ]),
" id " => int_escape ( $_POST [ " note_id " ])
2019-05-28 16:59:38 +00:00
];
// validate parameters
if ( array_search ( null , $note ) || strlen ( $note [ 'noteText' ]) == 0 ) {
return ;
}
2019-11-27 11:22:46 +00:00
$database -> execute ( "
UPDATE notes
SET x1 = : x1 , y1 = : y1 , height = : height , width = : width , note = : note
WHERE image_id = : image_id AND id = : id " , $note );
2019-05-28 16:59:38 +00:00
2019-11-27 11:22:46 +00:00
$this -> add_history ( 1 , $note [ 'id' ], $note [ 'image_id' ], $note [ 'x1' ], $note [ 'y1' ], $note [ 'height' ], $note [ 'width' ], $note [ 'note' ]);
2019-05-28 16:59:38 +00:00
}
private function delete_note ()
{
global $user , $database ;
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
$imageID = int_escape ( $_POST [ " image_id " ]);
$noteID = int_escape ( $_POST [ " note_id " ]);
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
// validate parameters
if ( is_null ( $imageID ) || ! is_numeric ( $imageID ) || is_null ( $noteID ) || ! is_numeric ( $noteID )) {
return ;
}
2016-05-18 13:36:50 +00:00
2019-11-27 11:22:46 +00:00
$database -> execute ( "
UPDATE notes SET enable = : enable
WHERE image_id = : image_id AND id = : id
" , ['enable'=>0, 'image_id'=> $imageID , 'id'=> $noteID ]);
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
log_info ( " notes " , " Note deleted { $noteID } by { $user -> name } " );
}
2009-12-24 07:36:09 +00:00
2019-05-28 16:59:38 +00:00
private function nuke_notes ()
{
global $database , $user ;
$image_id = int_escape ( $_POST [ " image_id " ]);
2019-11-27 11:22:46 +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
2019-05-28 16:59:38 +00:00
private function nuke_requests ()
{
global $database , $user ;
$image_id = int_escape ( $_POST [ " image_id " ]);
2009-12-24 07:36:09 +00:00
2019-11-27 11:22:46 +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
2019-05-28 16:59:38 +00:00
private function get_notes_list ( PageRequestEvent $event )
{
global $database , $config ;
2009-12-24 07:36:09 +00:00
2019-11-04 00:40:10 +00:00
$pageNumber = $event -> try_page_num ( 1 ) - 1 ;
2019-05-28 16:59:38 +00:00
$notesPerPage = $config -> get_int ( 'notesNotesPerPage' );
2019-11-27 11:22:46 +00:00
//$result = $database->get_all("SELECT * FROM pool_images WHERE pool_id=:pool_id", ['pool_id'=>$poolID]);
2019-11-27 12:13:04 +00:00
$result = $database -> execute (
"
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 " ,
[ 'enable' => 1 , 'offset' => $pageNumber * $notesPerPage , 'limit' => $notesPerPage ]
2019-05-28 16:59:38 +00:00
);
$totalPages = ceil ( $database -> get_one ( " SELECT COUNT(DISTINCT image_id) FROM notes " ) / $notesPerPage );
$images = [];
while ( $row = $result -> fetch ()) {
$images [] = [ Image :: by_id ( $row [ " image_id " ])];
}
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
2019-05-28 16:59:38 +00:00
private function get_notes_requests ( PageRequestEvent $event )
{
global $config , $database ;
2016-05-18 13:36:50 +00:00
2019-11-04 00:40:10 +00:00
$pageNumber = $event -> try_page_num ( 1 ) - 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
2009-12-24 07:36:09 +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
2014-04-28 04:56:19 +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 " ,
[ " offset " => $pageNumber * $requestsPerPage , " limit " => $requestsPerPage ]
2019-05-28 16:59:38 +00:00
);
2016-05-18 13:36:50 +00:00
2019-05-28 16:59:38 +00:00
$totalPages = 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 ()) {
$images [] = [ Image :: by_id ( $row [ " image_id " ])];
}
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
2019-05-28 16:59:38 +00:00
private function add_history ( $noteEnable , $noteID , $imageID , $noteX1 , $noteY1 , $noteHeight , $noteWidth , $noteText )
{
global $user , $database ;
2016-05-18 13:36:50 +00:00
2019-11-27 11:22:46 +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 )
" ,
[ 'note_enable' => $noteEnable , 'note_id' => $noteID , 'review_id' => $reviewID , 'image_id' => $imageID , 'user_id' => $user -> id , 'user_ip' => $_SERVER [ 'REMOTE_ADDR' ],
2019-11-27 12:13:04 +00:00
'x1' => $noteX1 , 'y1' => $noteY1 , 'height' => $noteHeight , 'width' => $noteWidth , 'note' => $noteText ]
2019-05-28 16:59:38 +00:00
);
}
private function get_histories ( PageRequestEvent $event )
{
global $config , $database ;
2019-11-04 00:40:10 +00:00
$pageNumber = $event -> try_page_num ( 1 ) - 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 " ,
[ 'offset' => $pageNumber * $historiesPerPage , 'limit' => $historiesPerPage ]
2019-05-28 16:59:38 +00:00
);
$totalPages = ceil ( $database -> get_one ( " SELECT COUNT(*) FROM note_histories " ) / $historiesPerPage );
$this -> theme -> display_histories ( $histories , $pageNumber + 1 , $totalPages );
}
private function get_history ( PageRequestEvent $event )
{
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 " ,
[ 'note_id' => $noteID , 'offset' => $pageNumber * $historiesPerPage , 'limit' => $historiesPerPage ]
2019-05-28 16:59:38 +00:00
);
2019-11-27 11:22:46 +00:00
$totalPages = 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 .
*/
private function revert_history ( int $noteID , int $reviewID )
{
global $database ;
2019-11-27 11:22:46 +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
" , ['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
}