2021-10-16 20:28:04 +03:00
import { initCompReactionSelector } from './comp/ReactionSelector.js' ;
2021-12-06 06:57:51 +03:00
import { initRepoIssueContentHistory } from './repo-issue-content.js' ;
2022-01-03 01:31:03 +03:00
import { validateTextareaNonEmpty } from './comp/CommentEasyMDE.js' ;
2021-10-21 10:37:43 +03:00
const { csrfToken } = window . config ;
2021-10-16 20:28:04 +03:00
export function initRepoDiffReviewButton ( ) {
$ ( document ) . on ( 'click' , 'button[name="is_review"]' , ( e ) => {
$ ( e . target ) . closest ( 'form' ) . append ( '<input type="hidden" name="is_review" value="true">' ) ;
} ) ;
}
export function initRepoDiffFileViewToggle ( ) {
$ ( '.file-view-toggle' ) . on ( 'click' , function ( ) {
const $this = $ ( this ) ;
$this . parent ( ) . children ( ) . removeClass ( 'active' ) ;
$this . addClass ( 'active' ) ;
const $target = $ ( $this . data ( 'toggle-selector' ) ) ;
$target . parent ( ) . children ( ) . addClass ( 'hide' ) ;
$target . removeClass ( 'hide' ) ;
} ) ;
}
export function initRepoDiffConversationForm ( ) {
2021-10-16 23:30:31 +03:00
$ ( document ) . on ( 'submit' , '.conversation-holder form' , async ( e ) => {
2021-10-16 20:28:04 +03:00
e . preventDefault ( ) ;
2022-01-03 01:31:03 +03:00
2021-10-16 20:28:04 +03:00
const form = $ ( e . target ) ;
2022-01-03 01:31:03 +03:00
const $textArea = form . find ( 'textarea' ) ;
if ( ! validateTextareaNonEmpty ( form , $textArea ) ) {
return ;
}
2021-10-16 20:28:04 +03:00
const newConversationHolder = $ ( await $ . post ( form . attr ( 'action' ) , form . serialize ( ) ) ) ;
const { path , side , idx } = newConversationHolder . data ( ) ;
form . closest ( '.conversation-holder' ) . replaceWith ( newConversationHolder ) ;
if ( form . closest ( 'tr' ) . data ( 'line-type' ) === 'same' ) {
2021-11-19 05:28:27 +03:00
$ ( ` [data-path=" ${ path } "] a.add-code-comment[data-idx=" ${ idx } "] ` ) . addClass ( 'invisible' ) ;
2021-10-16 20:28:04 +03:00
} else {
2021-11-19 05:28:27 +03:00
$ ( ` [data-path=" ${ path } "] a.add-code-comment[data-side=" ${ side } "][data-idx=" ${ idx } "] ` ) . addClass ( 'invisible' ) ;
2021-10-16 20:28:04 +03:00
}
newConversationHolder . find ( '.dropdown' ) . dropdown ( ) ;
initCompReactionSelector ( newConversationHolder ) ;
} ) ;
$ ( '.resolve-conversation' ) . on ( 'click' , async function ( e ) {
e . preventDefault ( ) ;
const comment _id = $ ( this ) . data ( 'comment-id' ) ;
const origin = $ ( this ) . data ( 'origin' ) ;
const action = $ ( this ) . data ( 'action' ) ;
const url = $ ( this ) . data ( 'update-url' ) ;
2021-10-21 10:37:43 +03:00
const data = await $ . post ( url , { _csrf : csrfToken , origin , action , comment _id } ) ;
2021-10-16 20:28:04 +03:00
if ( $ ( this ) . closest ( '.conversation-holder' ) . length ) {
const conversation = $ ( data ) ;
$ ( this ) . closest ( '.conversation-holder' ) . replaceWith ( conversation ) ;
conversation . find ( '.dropdown' ) . dropdown ( ) ;
initCompReactionSelector ( conversation ) ;
} else {
window . location . reload ( ) ;
}
} ) ;
}
export function initRepoDiffConversationNav ( ) {
// Previous/Next code review conversation
$ ( document ) . on ( 'click' , '.previous-conversation' , ( e ) => {
const $conversation = $ ( e . currentTarget ) . closest ( '.comment-code-cloud' ) ;
const $conversations = $ ( '.comment-code-cloud:not(.hide)' ) ;
const index = $conversations . index ( $conversation ) ;
const previousIndex = index > 0 ? index - 1 : $conversations . length - 1 ;
const $previousConversation = $conversations . eq ( previousIndex ) ;
const anchor = $previousConversation . find ( '.comment' ) . first ( ) . attr ( 'id' ) ;
window . location . href = ` # ${ anchor } ` ;
} ) ;
$ ( document ) . on ( 'click' , '.next-conversation' , ( e ) => {
const $conversation = $ ( e . currentTarget ) . closest ( '.comment-code-cloud' ) ;
const $conversations = $ ( '.comment-code-cloud:not(.hide)' ) ;
const index = $conversations . index ( $conversation ) ;
const nextIndex = index < $conversations . length - 1 ? index + 1 : 0 ;
const $nextConversation = $conversations . eq ( nextIndex ) ;
const anchor = $nextConversation . find ( '.comment' ) . first ( ) . attr ( 'id' ) ;
window . location . href = ` # ${ anchor } ` ;
} ) ;
}
2021-11-09 12:27:25 +03:00
export function initRepoDiffShowMore ( ) {
$ ( '#diff-files, #diff-file-boxes' ) . on ( 'click' , '#diff-show-more-files, #diff-show-more-files-stats' , ( e ) => {
e . preventDefault ( ) ;
if ( $ ( e . target ) . hasClass ( 'disabled' ) ) {
return ;
}
$ ( '#diff-show-more-files, #diff-show-more-files-stats' ) . addClass ( 'disabled' ) ;
const url = $ ( '#diff-show-more-files, #diff-show-more-files-stats' ) . data ( 'href' ) ;
$ . ajax ( {
type : 'GET' ,
url ,
} ) . done ( ( resp ) => {
2021-11-21 19:51:08 +03:00
if ( ! resp ) {
2021-11-09 12:27:25 +03:00
$ ( '#diff-show-more-files, #diff-show-more-files-stats' ) . removeClass ( 'disabled' ) ;
return ;
}
$ ( '#diff-too-many-files-stats' ) . remove ( ) ;
$ ( '#diff-files' ) . append ( $ ( resp ) . find ( '#diff-files li' ) ) ;
$ ( '#diff-incomplete' ) . replaceWith ( $ ( resp ) . find ( '#diff-file-boxes' ) . children ( ) ) ;
2021-12-06 06:57:51 +03:00
initRepoIssueContentHistory ( ) ;
2021-11-21 19:51:08 +03:00
} ) . fail ( ( ) => {
$ ( '#diff-show-more-files, #diff-show-more-files-stats' ) . removeClass ( 'disabled' ) ;
} ) ;
} ) ;
$ ( document ) . on ( 'click' , 'a.diff-show-more-button' , ( e ) => {
e . preventDefault ( ) ;
const $target = $ ( e . target ) ;
if ( $target . hasClass ( 'disabled' ) ) {
return ;
}
$target . addClass ( 'disabled' ) ;
const url = $target . data ( 'href' ) ;
$ . ajax ( {
type : 'GET' ,
url ,
} ) . done ( ( resp ) => {
if ( ! resp ) {
$target . removeClass ( 'disabled' ) ;
return ;
}
$target . parent ( ) . replaceWith ( $ ( resp ) . find ( '#diff-file-boxes .diff-file-body .file-body' ) . children ( ) ) ;
2021-12-06 06:57:51 +03:00
initRepoIssueContentHistory ( ) ;
2021-11-21 19:51:08 +03:00
} ) . fail ( ( ) => {
$target . removeClass ( 'disabled' ) ;
2021-11-09 12:27:25 +03:00
} ) ;
} ) ;
}