feat: History diff UI

This commit is contained in:
NGPixel 2017-07-02 18:15:05 -04:00 committed by Nicolas Giard
parent 8e6938483c
commit 43f9a10416
5 changed files with 115 additions and 22 deletions

View File

@ -1,41 +1,59 @@
<template lang="pug"> <template lang="pug">
div {{ currentPath }} .history
.history-title {{ currentPath }}
.history-info
.columns
.column
p Timestamp: #[strong 2017/07/02 5:19 PM]
p Author: #[strong Nicolas Giard]
p Commit: #[strong 379ff16957b2b7f978e02bfe50cd0cee182fcb8a]
.column.history-info-actions
.button-group
button.button.is-blue-grey() Compare With...
button.button.is-blue-grey() Revert to version
toggle.is-dark(v-model='sidebyside', desc='Side-by-side View')
.history-diff#diff
</template> </template>
<script> <script>
let diffui
export default { export default {
name: 'history', name: 'history',
props: ['currentPath'], props: ['currentPath'],
data() { data() {
return { return {
tree: [] diffui: {},
sidebyside: true
} }
}, },
methods: { methods: {
fetch(basePath) { draw() {
let self = this diffui.draw('#diff', {
self.$store.dispatch('startLoading') inputFormat: 'json',
self.$nextTick(() => { outputFormat: 'side-by-side',
socket.emit('treeFetch', { basePath }, (data) => { matching: 'words',
if (self.tree.length > 0) { synchronisedScroll: true
let branch = self._.last(self.tree)
branch.hasChildren = true
self._.find(branch.pages, { _id: basePath }).isActive = true
}
self.tree.push({
hasChildren: false,
pages: data
})
self.$store.dispatch('stopLoading')
})
}) })
},
goto(entryPath) {
window.location.assign(siteRoot + '/' + entryPath)
} }
}, },
mounted() { mounted() {
diffui = new Diff2HtmlUI({
diff: `diff --git a/wiki/prerequisites.md b/wiki/prerequisites.md
index 89a10de..4bc0d66 100644
--- a/wiki/prerequisites.md
+++ b/wiki/prerequisites.md
@@ -13,7 +13,7 @@ Wiki.js runs on pretty much any platform that supports the requirements below. H
**CPU:** Runs perfectly fine on a single CPU core machine. However, to maximize Wiki.js background agent feature, using 2 cores is highly recommended.
-**RAM:** Wiki.js uses between 100-200MB of RAM. While Wiki.js itself is able to run with only 512MB total RAM, you will not be able to install and compile the dependencies. You need a minimum of 768MB just to install the dependencies. Note that Windows machines may require more RAM.
+**RAM:** Wiki.js uses between 100-200MB of RAM. While Wiki.js itself is able to run with only 512MB total RAM, you will not be able to install all the dependencies. You need a minimum of 768MB just to install the dependencies. Note that Windows machines may require more RAM.
**Disk Space:** Wiki.js requires about 300MB of disk space when including the dependencies. The actual total space needed for your installation depends on the content and most importantly, the uploads. A wiki with only text content will only use a few megabytes, even for thousands of articles. However, if you start adding images, documents, videos, etc., you must plan required disk space accordingly.
`
})
this.draw()
} }
} }
</script> </script>

View File

@ -19,6 +19,7 @@ $primary: 'indigo';
@import 'components/form'; @import 'components/form';
@import 'components/grid'; @import 'components/grid';
@import 'components/hero'; @import 'components/hero';
@import 'components/history';
@import 'components/markdown-content'; @import 'components/markdown-content';
@import 'components/modal'; @import 'components/modal';
@import 'components/nav'; @import 'components/nav';
@ -34,6 +35,7 @@ $primary: 'indigo';
@import 'libs/jquery-contextmenu'; @import 'libs/jquery-contextmenu';
@import 'node_modules/highlight.js/styles/atom-one-dark'; @import 'node_modules/highlight.js/styles/atom-one-dark';
@import 'node_modules/simplemde/dist/simplemde.min'; @import 'node_modules/simplemde/dist/simplemde.min';
@import 'node_modules/diff2html/dist/diff2html.min';
@import 'components/editor'; @import 'components/editor';

View File

@ -0,0 +1,51 @@
.history {
&-title {
border-top: 1px solid mc('blue-grey', '900');
padding: 8px;
color: mc('blue-grey', '800');
font-size: 13px;
letter-spacing: 1px;
text-transform: uppercase;
background-color: mc('blue-grey', '100');
text-align: center;
box-shadow: 0 0 5px rgba(0,0,0,0.3);
}
&-info {
background-color: mc('blue-grey', '50');
padding: 5px 15px;
p {
padding: 5px 0;
font-size: 14px;
color: mc('blue-grey', '800');
}
&-actions {
display: flex;
flex-basis: initial;
flex-grow: initial;
flex-direction: column;
align-items: center;
justify-content: center;
.button-group {
margin-bottom: 10px;
}
}
}
&-diff {
position: relative;
.d2h-wrapper {
position: absolute;
left: 0;
right: 0;
}
}
}

View File

@ -14,7 +14,7 @@
align-items: center; align-items: center;
height: 24px; height: 24px;
width: 50px; width: 50px;
background-color: mc('grey', '300'); background-color: mc('blue-grey', '200');
border-radius: 12px; border-radius: 12px;
padding: 2px; padding: 2px;
transition: background-color .5s ease; transition: background-color .5s ease;
@ -51,3 +51,17 @@
} }
} }
/* THEME OVERRIDE - START */
@each $color, $colorvalue in $material-colors {
.is-primary-#{$color} .toggle {
&.is-active {
.toggle-container {
background-color: mc($color, '500');
}
}
}
}
/* THEME OVERRIDE - END */

View File

@ -56,6 +56,14 @@ const SHIMS = {
jquery: { jquery: {
source: 'node_modules/jquery/dist/jquery.js', source: 'node_modules/jquery/dist/jquery.js',
exports: '$' exports: '$'
},
diff2html: {
source: 'node_modules/diff2html/dist/diff2html.min.js',
exports: 'Diff2Html'
},
diff2htmlui: {
source: 'node_modules/diff2html/dist/diff2html-ui.min.js',
exports: 'Diff2HtmlUI'
} }
} }