summaryrefslogtreecommitdiffstats
path: root/public/js/gogs.js
diff options
context:
space:
mode:
Diffstat (limited to 'public/js/gogs.js')
-rw-r--r--public/js/gogs.js210
1 files changed, 166 insertions, 44 deletions
diff --git a/public/js/gogs.js b/public/js/gogs.js
index 34c8c9222b..e0738a5061 100644
--- a/public/js/gogs.js
+++ b/public/js/gogs.js
@@ -206,6 +206,31 @@ function initRepository() {
return;
}
+ function initFilterSearchDropdown(selector) {
+ var $dropdown = $(selector);
+ $dropdown.dropdown({
+ fullTextSearch: true,
+ onChange: function (text, value, $choice) {
+ window.location.href = $choice.data('url');
+ console.log($choice.data('url'))
+ },
+ message: {noResults: $dropdown.data('no-results')}
+ });
+ }
+
+ // File list
+ if ($('.repository.file.list').length > 0) {
+ initFilterSearchDropdown('.choose.reference .dropdown');
+
+ $('.reference.column').click(function () {
+ $('.choose.reference .scrolling.menu').css('display', 'none');
+ $('.choose.reference .text').removeClass('black');
+ $($(this).data('target')).css('display', 'block');
+ $(this).find('.text').addClass('black');
+ return false;
+ });
+ }
+
// Options
if ($('.repository.settings.options').length > 0) {
$('#repo_name').keyup(function () {
@@ -289,23 +314,23 @@ function initRepository() {
$('#edit-title').click(editTitleToggle);
$('#cancel-edit-title').click(editTitleToggle);
$('#save-edit-title').click(editTitleToggle).
- click(function () {
- if ($edit_input.val().length == 0 ||
- $edit_input.val() == $issue_title.text()) {
- $edit_input.val($issue_title.text());
- return false;
- }
-
- $.post($(this).data('update-url'), {
- "_csrf": csrf,
- "title": $edit_input.val()
- },
- function (data) {
- $edit_input.val(data.title);
- $issue_title.text(data.title);
- });
+ click(function () {
+ if ($edit_input.val().length == 0 ||
+ $edit_input.val() == $issue_title.text()) {
+ $edit_input.val($issue_title.text());
return false;
- });
+ }
+
+ $.post($(this).data('update-url'), {
+ "_csrf": csrf,
+ "title": $edit_input.val()
+ },
+ function (data) {
+ $edit_input.val(data.title);
+ $issue_title.text(data.title);
+ });
+ return false;
+ });
// Edit issue or comment content
$('.edit-content').click(function () {
@@ -397,33 +422,26 @@ function initRepository() {
}
}
- // Quick start
- if ($('.repository.quickstart').length > 0) {
- $('#repo-clone-ssh').click(function () {
- $('.clone-url').text($(this).data('link'));
- $('#repo-clone-url').val($(this).data('link'));
- $(this).addClass('blue');
- $('#repo-clone-https').removeClass('blue');
- });
- $('#repo-clone-https').click(function () {
- $('.clone-url').text($(this).data('link'));
- $('#repo-clone-url').val($(this).data('link'));
- $(this).addClass('blue');
- $('#repo-clone-ssh').removeClass('blue');
- });
- }
+ // Quick start and repository home
+ $('#repo-clone-ssh').click(function () {
+ $('.clone-url').text($(this).data('link'));
+ $('#repo-clone-url').val($(this).data('link'));
+ $(this).addClass('blue');
+ $('#repo-clone-https').removeClass('blue');
+ });
+ $('#repo-clone-https').click(function () {
+ $('.clone-url').text($(this).data('link'));
+ $('#repo-clone-url').val($(this).data('link'));
+ $(this).addClass('blue');
+ $('#repo-clone-ssh').removeClass('blue');
+ });
+ $('#repo-clone-url').click(function () {
+ $(this).select();
+ });
// Pull request
if ($('.repository.compare.pull').length > 0) {
- var $branch_dropdown = $('.choose.branch .dropdown');
- $branch_dropdown.dropdown({
- fullTextSearch: true,
- onChange: function (text, value, $choice) {
- window.location.href = $choice.data('url');
- console.log($choice.data('url'))
- },
- message: {noResults: $branch_dropdown.data('no-results')}
- });
+ initFilterSearchDropdown('.choose.branch .dropdown');
}
}
@@ -540,7 +558,7 @@ function initAdmin() {
}
function buttonsClickOnEnter() {
- $('.ui.button').keypress(function(e){
+ $('.ui.button').keypress(function (e) {
if (e.keyCode == 13 || e.keyCode == 32) // enter key or space bar
$(this).click();
});
@@ -553,9 +571,9 @@ $(document).ready(function () {
// Show exact time
$('.time-since').each(function () {
$(this).addClass('poping up').
- attr('data-content', $(this).attr('title')).
- attr('data-variation', 'inverted tiny').
- attr('title', '');
+ attr('data-content', $(this).attr('title')).
+ attr('data-variation', 'inverted tiny').
+ attr('title', '');
});
// Semantic UI modules.
@@ -678,6 +696,26 @@ $(document).ready(function () {
$($(this).data('modal')).modal('show');
});
+ // Set anchor.
+ $('.markdown').each(function () {
+ var headers = {};
+ $(this).find('h1, h2, h3, h4, h5, h6').each(function () {
+ var node = $(this);
+ var val = encodeURIComponent(node.text().toLowerCase().replace(/[^\w\- ]/g, '').replace(/[ ]/g, '-'));
+ var name = val;
+ if (headers[val] > 0) {
+ name = val + '-' + headers[val];
+ }
+ if (headers[val] == undefined) {
+ headers[val] = 1;
+ } else {
+ headers[val] += 1;
+ }
+ node = node.wrap('<div id="' + name + '" class="anchor-wrap" ></div>');
+ node.append('<a class="anchor" href="#' + name + '"><span class="octicon octicon-link"></span></a>');
+ });
+ });
+
buttonsClickOnEnter();
initCommentForm();
@@ -687,4 +725,88 @@ $(document).ready(function () {
initUser();
initWebhook();
initAdmin();
+});
+
+$(window).load(function () {
+ function changeHash(hash) {
+ if (history.pushState) {
+ history.pushState(null, null, hash);
+ }
+ else {
+ location.hash = hash;
+ }
+ }
+
+ function deSelect() {
+ if (window.getSelection) {
+ window.getSelection().removeAllRanges();
+ } else {
+ document.selection.empty();
+ }
+ }
+
+ function selectRange($list, $select, $from) {
+ $list.removeClass('active');
+ if ($from) {
+ var a = parseInt($select.attr('rel').substr(1));
+ var b = parseInt($from.attr('rel').substr(1));
+ var c;
+ if (a != b) {
+ if (a > b) {
+ c = a;
+ a = b;
+ b = c;
+ }
+ var classes = [];
+ for (i = a; i <= b; i++) {
+ classes.push('.L' + i);
+ }
+ $list.filter(classes.join(',')).addClass('active');
+ changeHash('#L' + a + '-' + 'L' + b);
+ return
+ }
+ }
+ $select.addClass('active');
+ changeHash('#' + $select.attr('rel'));
+ }
+
+ // Code view.
+ if ($('.code-view').length > 0) {
+ var $block = $('.code-view .linenums');
+ var lines = $block.html().split("\n");
+ $block.html('');
+
+ var $num_list = $('.code-view .lines-num');
+
+ // Building blocks.
+ for (var i = 0; i < lines.length; i++) {
+ $block.append('<li class="L' + (i + 1) + '" rel="L' + (i + 1) + '">' + lines[i] + '</li>');
+ $num_list.append('<span id="L' + (i + 1) + '">' + (i + 1) + '</span>');
+ }
+
+ $(document).on('click', '.lines-num span', function (e) {
+ var $select = $(this);
+ var $list = $select.parent().siblings('.lines-code').find('ol.linenums > li');
+ selectRange($list, $list.filter('[rel=' + $select.attr('id') + ']'), (e.shiftKey ? $list.filter('.active').eq(0) : null));
+ deSelect();
+ });
+
+ $(window).on('hashchange', function (e) {
+ var m = window.location.hash.match(/^#(L\d+)\-(L\d+)$/);
+ var $list = $('.code-view ol.linenums > li');
+ var $first;
+ if (m) {
+ $first = $list.filter('.' + m[1]);
+ selectRange($list, $first, $list.filter('.' + m[2]));
+ $("html, body").scrollTop($first.offset().top - 200);
+ return;
+ }
+ m = window.location.hash.match(/^#(L\d+)$/);
+ if (m) {
+ $first = $list.filter('.' + m[1]);
+ selectRange($list, $first);
+ $("html, body").scrollTop($first.offset().top - 200);
+ }
+ }).trigger('hashchange');
+ }
}); \ No newline at end of file