RSS Git Download  Clone
Raw View History
Blames found: 149 Mode: javascript Binary: false

$(function () {
const Cookies = require('js-cookie') const errorHandler = window.gitlist.ajaxErrorHandler;
const gitHelperAjax = window.gitlist.gitHelperAjax;
const $modalDelete = $('#p3x-gitlist-modal-delete')
if ($modalDelete.length === 0) {
return; }
const $buttonDelete = $('#p3x-gitlist-file-delete') const $buttonDeleteSure = $('#p3x-gitlist-modal-delete-confirm') const $formDeleteForm = $('#p3x-gitlist-modal-delete-form') const $deleteInputName = $('#p3x-gitlist-modal-delete-name'); const $deleteInputEmail = $('#p3x-gitlist-modal-delete-email'); const $deleteInputComment = $('#p3x-gitlist-modal-delete-comment'); const inputs = { name: $deleteInputName, email: $deleteInputEmail, comment: $deleteInputComment, }
$buttonDelete.click(() => {
if (!window.gitlist.changeableCommit()) {
return } $modalDelete.modal('show') })
$formDeleteForm[0].addEventListener('submit', async (ev) => {
ev.preventDefault();
if ($formDeleteForm[0].checkValidity() === false) {
window.gitlist.invalidSnackbarCommit()
return; } try {
const json = await gitHelperAjax({ modal: $modalDelete, action: 'delete', inputs: inputs,
})
if (window.gitlist.gitNewPush(json)) { return }
} catch (e) {
errorHandler(e) } })
const sourceCode = $('#p3x-gitlist-file-editor');
if (sourceCode.length) {
let originalCode = '';
let disableFull = false;
const cookieName = 'p3x-gitlist-codemirror-size' const currentSizing = Cookies.get(cookieName)
const $codeCodeMirroNormal = $('#p3x-gitlist-file-codemirror'); const $codeCodeMirrorBig = $('#p3x-gitlist-file-codemirror-exceeded')
const $codeCodeMirrorFullHeight = $('#p3x-gitlist-file-codemirror-full-height');
const fullHeightCookieName = 'p3x-gitlist-codemirror-full-height'; let fullHeightCookie = Cookies.get(fullHeightCookieName) if (fullHeightCookie !== undefined) { $codeCodeMirrorFullHeight.remove(); }
let value = sourceCode.text();
const maxSize = window.gitlist.codemirror_full_limit;
const size = Math.ceil(value.length / 1024);
let cm;
const createCodeMirror = () => {
if (size > maxSize) { disableFull = true;
$codeCodeMirroNormal.hide(); $codeCodeMirrorBig.show();
} else {
$codeCodeMirroNormal.show();
}
const mode = sourceCode.attr('language'); const pre = sourceCode.get(0);
const $codeMirror = $('.CodeMirror'); const $buttonScroll = $('#p3x-gitlist-file-button-scroll'); const $buttonFull = $('#p3x-gitlist-file-button-full'); const $buttonEdit = $('#p3x-gitlist-file-button-edit'); const $buttonEditCancel = $('#p3x-gitlist-file-button-edit-cancel'); const $buttonEditSave = $('#p3x-gitlist-file-button-edit-save') const $buttonDelete = $('#p3x-gitlist-file-delete')
const codeMirrorHeight = window.gitlist.editorMaxHeight;
//$buttonEditCancel.hide(); //$buttonEditSave.hide();
/*
if (!window.gitlist.changeableCommit({ snack: false})) { $buttonEdit.hide(); $buttonDelete.hide(); } else { $buttonEdit.show(); $buttonDelete.show(); }
*/
$buttonEdit.click(() => {
if (!window.gitlist.changeableCommit()) {
return
}
// buttonEditRow.show();
$buttonEdit.hide(); $buttonDelete.hide() $buttonEditCancel.show(); $buttonEditSave.show();
gitlist.viewer.setOption('readOnly', false) originalCode = gitlist.viewer.getValue() gitlist.viewer.focus(); $.snackbar({
content: `Editing`,
}) })
const validateCodeIsSame = (snack = true) => { value = gitlist.viewer.getValue(); if (originalCode === value) { if (snack) { $.snackbar({ content: 'The code has not changed. No saving.', }) } return true; } return false; } const close = () => {
$buttonDelete.show() $buttonEdit.show(); $buttonEditSave.hide(); $buttonEditCancel.hide();
gitlist.viewer.setOption('readOnly', true)
}
$buttonEditCancel.click(() => {
if (!validateCodeIsSame(false)) { gitlist.viewer.setValue(originalCode) $.snackbar({ htmlAllowed: true, content: 'The changes are reverted.', }) } close();
})
const $commitModal = $('#p3x-gitlist-modal-commit'); $buttonEditSave.click(async () => {
if (validateCodeIsSame()) { return; }
$commitModal.modal('show')
})
const $commitInputName = $('#p3x-gitlist-modal-commit-name'); const $commitInputEmail = $('#p3x-gitlist-modal-commit-email'); const $commitInputComment = $('#p3x-gitlist-modal-commit-comment'); const $commitForm = $('#p3x-gitlist-modal-commit-form');
const inputs = {
name: $commitInputName, email: $commitInputEmail, comment: $commitInputComment,
}
//const $commitCommitPushButton = $('#p3x-gitlist-modal-commit-push')
$commitForm[0].addEventListener('submit', async (ev) => {
ev.preventDefault();
if (validateCodeIsSame()) { return; }
if ($commitForm[0].checkValidity() === false) {
window.gitlist.invalidSnackbarCommit()
return; }
/*
$.snackbar({ htmlAllowed: true, content: ' <i class="fas fa-cog fa-spin"></i>&nbsp;Saving ...' })
*/
try {
await gitHelperAjax({
modal: $commitModal,
action: 'save', inputs: inputs,
data: { value: value },
})
originalCode = value; close(); $.snackbar({ htmlAllowed: true, content: '<i class="fas fa-check"></i>&nbsp;&nbsp;The file is saved.', })
} catch (e) {
errorHandler(e); }
})
const setScroll = () => {
if (fullHeightCookie !== undefined) { $codeCodeMirrorFullHeight.remove() }
$codeCodeMirrorFullHeight.hide()
$buttonFull.removeClass('active') $buttonScroll.addClass('active') $codeMirror.css('height', codeMirrorHeight)
gitlist.viewer.setSize(null, codeMirrorHeight);
if (!disableFull) { Cookies.set(cookieName, 'scroll', window.gitlist.cookieSettings) }
}
$buttonScroll.click(setScroll)
const setFull = () => {
$codeCodeMirrorFullHeight.show()
fullHeightCookie = true Cookies.set(fullHeightCookieName, true, window.gitlist.cookieSettingsShort)
$buttonScroll.removeClass('active') $buttonFull.addClass('active') $codeMirror.css('height', 'auto')
gitlist.viewer.setSize(null, '100%'); Cookies.set(cookieName, 'full', window.gitlist.cookieSettings)
}
$buttonFull.click(setFull)
cm = CodeMirror(function (elt) {
pre.parentNode.replaceChild(elt, pre); }, {
styleActiveLine: true, styleSelectedText: true,
value: value, lineNumbers: true, matchBrackets: true, lineWrapping: true, readOnly: true, mode: mode, theme: window.gitlist.getActualThemeCodemirror(), });
gitlist.viewer = cm; const isReallyFull = currentSizing === 'full' && !disableFull; if (isReallyFull) {
setFull()
} else { setScroll() }
const scrollToEditor = () => {
let line = location.hash.startsWith('#L') ? location.hash.substring(2) : undefined
if (line !== undefined) { setTimeout(() => {
line = parseInt(line) cm.setSelection({
line: line - 1,
char: 0, }, { line: line - 1, char: Number.MAX_SAFE_INTEGER })
cm.scrollIntoView({line: line, char: 0}, isReallyFull ? window.innerHeight / 2 : 100)
/* const codes = $('.CodeMirror-linenumber') for(let codeLinenumber of codes) { const $codeLinenumber = $(codeLinenumber) const findLine = $codeLinenumber.text(); if(findLine === line ) { break; } } */
}, 250) } }
if (location.search.includes('edit=1')) { setTimeout(() => {
$buttonEdit.click();
scrollToEditor();
}, 500)
} else { scrollToEditor();
}
}
createCodeMirror();
const $showSvgButton = $('#p3x-gitlist-file-svg-show') if ($showSvgButton.length > 0) { const $svgElements = $('.p3x-gitlist-file-svg-toggle') const $cmWrapper = $(cm.getWrapperElement()) const $svgContentWrapper = $('#p3x-gitlist-file-svg-content') $showSvgButton.click(() => { if ($showSvgButton.hasClass('active')) { $svgContentWrapper.empty() } else { const image = `<img class="p3x-gitlist-max-width" src="data:image/svg+xml;base64,${btoa(cm.getValue())}"/>` // console.log(image) $svgContentWrapper.append(image) } $showSvgButton.toggleClass('active') $svgElements.toggle() $cmWrapper.toggle() }) }
}
})