feat: editor-modal-document UI

pull/621/head
NGPixel 7 years ago
parent c9b6d0ee36
commit f27c1e86b1

@ -2,13 +2,7 @@
"comments": true, "comments": true,
"plugins": [ "plugins": [
"lodash", "lodash",
"graphql-tag", "graphql-tag"
["transform-imports", {
"vuetify": {
"transform": "vuetify/es5/components/${member}",
"preventFullImport": true
}
}]
], ],
"presets": [ "presets": [
["env"], ["env"],

@ -1,6 +1,6 @@
'use strict' 'use strict'
require('vuetify/src/stylus/app.styl') require('vuetify/src/stylus/main.styl')
require('./scss/app.scss') require('./scss/app.scss')
require('./js/compatibility.js') require('./js/compatibility.js')
require('offline-plugin/runtime').install() require('offline-plugin/runtime').install()

@ -13,7 +13,7 @@ import { ApolloLink } from 'apollo-link'
import { createApolloFetch } from 'apollo-fetch' import { createApolloFetch } from 'apollo-fetch'
import { BatchHttpLink } from 'apollo-link-batch-http' import { BatchHttpLink } from 'apollo-link-batch-http'
import { InMemoryCache } from 'apollo-cache-inmemory' import { InMemoryCache } from 'apollo-cache-inmemory'
import { Vuetify, VApp, VBtn, VIcon, VList, VMenu, VSpeedDial, VTooltip } from 'vuetify' import Vuetify from 'vuetify'
import Hammer from 'hammerjs' import Hammer from 'hammerjs'
import store from './store' import store from './store'
@ -93,17 +93,7 @@ Vue.use(VeeValidate, {
dirty: 'is-dirty' // control has been interacted with dirty: 'is-dirty' // control has been interacted with
} }
}) })
Vue.use(Vuetify, { Vue.use(Vuetify)
components: {
VApp,
VBtn,
VIcon,
VList,
VMenu,
VSpeedDial,
VTooltip
}
})
// ==================================== // ====================================
// Register Vue Components // Register Vue Components

@ -75,13 +75,13 @@
v-btn(color='blue', fab, dark, slot='activator') v-btn(color='blue', fab, dark, slot='activator')
v-icon more_horiz v-icon more_horiz
v-icon close v-icon close
v-btn(color='blue-grey', fab, dark): v-icon sort_by_alpha v-btn(color='blue-grey', fab, dark, @click='documentPropsDialog = !documentPropsDialog'): v-icon sort_by_alpha
v-btn(color='green', fab, dark): v-icon save v-btn(color='green', fab, dark): v-icon save
v-btn(color='red', fab, dark, small): v-icon not_interested v-btn(color='red', fab, dark, small): v-icon not_interested
v-btn(color='orange', fab, dark, small): v-icon vpn_lock v-btn(color='orange', fab, dark, small): v-icon vpn_lock
v-btn(color='indigo', fab, dark, small): v-icon restore v-btn(color='indigo', fab, dark, small): v-icon restore
v-btn(color='brown', fab, dark, small): v-icon archive v-btn(color='brown', fab, dark, small): v-icon archive
editorModalDocument(:is-opened='documentPropsDialog')
</template> </template>
<script> <script>
@ -89,15 +89,12 @@ import { codemirror } from 'vue-codemirror'
import 'codemirror/lib/codemirror.css' import 'codemirror/lib/codemirror.css'
// Theme // Theme
import 'codemirror/theme/base16-dark.css' import 'codemirror/theme/base16-dark.css'
// Language // Language
import 'codemirror/mode/markdown/markdown.js' import 'codemirror/mode/markdown/markdown.js'
// Addons // Addons
import 'codemirror/addon/selection/active-line.js' import 'codemirror/addon/selection/active-line.js'
import 'codemirror/addon/display/fullscreen.js' import 'codemirror/addon/display/fullscreen.js'
import 'codemirror/addon/display/fullscreen.css' import 'codemirror/addon/display/fullscreen.css'
@ -109,7 +106,8 @@ import 'codemirror/addon/search/match-highlighter.js'
export default { export default {
components: { components: {
codemirror codemirror,
editorModalDocument: () => import(/* webpackChunkName: "editor" */ './editor-modal-document.vue')
}, },
data() { data() {
return { return {
@ -134,7 +132,8 @@ export default {
if (cm.getOption('fullScreen')) cm.setOption('fullScreen', false) if (cm.getOption('fullScreen')) cm.setOption('fullScreen', false)
} }
} }
} },
documentPropsDialog: false
} }
}, },
computed: { computed: {
@ -281,6 +280,25 @@ export default {
.CodeMirror { .CodeMirror {
height: auto; height: auto;
.cm-header-1 {
font-size: 1.5rem;
}
.cm-header-2 {
font-size: 1.25rem;
}
.cm-header-3 {
font-size: 1.15rem;
}
.cm-header-4 {
font-size: 1.1rem;
}
.cm-header-5 {
font-size: 1.05rem;
}
.cm-header-6 {
font-size: 1.025rem;
}
} }
.CodeMirror-focused .cm-matchhighlight { .CodeMirror-focused .cm-matchhighlight {

@ -0,0 +1,37 @@
<template lang='pug'>
v-bottom-sheet(v-model='isOpened', inset)
v-toolbar(color='blue-grey', flat)
v-icon(color='white') sort_by_alpha
v-toolbar-title.white--text Document Properties
v-spacer
v-btn(icon, dark)
v-icon close
v-card.pa-3(tile)
v-card-text
v-form
v-text-field(label='Title', autofocus, loading='primary')
v-text-field(label='Short Description')
v-card-actions
v-btn(color='green', dark) Save
v-btn Cancel
</template>
<script>
export default {
props: {
isOpened: {
type: Boolean,
default: false
}
},
data() {
return {
}
}
}
</script>
<style lang='scss'>
</style>
Loading…
Cancel
Save