| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 | <template lang="pug">  transition(:duration="400")    .modal(v-show='isShown', v-cloak)      transition(name='modal-background')        .modal-background(v-show='isShown')      .modal-container        transition(name='modal-content')          .modal-content(v-show='isShown')            header.is-light-blue {{ $t('modal.createpagetitle') }}            section              label.label {{ $t('modal.createpagepath') }}              p.control.is-fullwidth(v-bind:class='{ "is-loading": isLoading }')                input.input(type='text', placeholder='page-name', v-model='userPath', ref='createPageInput', @keyup.enter='create', @keyup.esc='cancel')                span.help.is-red(v-show='isInvalid') {{ $t('modal.createpageinvalid') }}            footer              a.button.is-grey.is-outlined(v-on:click='cancel') {{ $t('modal.discard') }}              a.button.is-light-blue(v-on:click='create') {{ $t('modal.create') }}</template><script>export default {  name: 'modal-create-page',  props: ['basepath'],  data () {    return {      currentPath: '',      userPath: '',      isLoading: false,      isInvalid: false    }  },  computed: {    isShown () {      if (this.$store.state.modalCreatePage.shown) {        this.makeSelection()      }      return this.$store.state.modalCreatePage.shown    }  },  methods: {    makeSelection: function () {      let self = this      self._.delay(() => {        let startPos = (self.currentPath.length > 0) ? self.currentPath.length + 1 : 0        self.$helpers.form.setInputSelection(self.$refs.createPageInput, startPos, self.userPath.length)      }, 100)    },    cancel: function () {      this.$store.dispatch('modalCreatePage/close')    },    create: function () {      this.isInvalid = false      let newDocPath = this.$helpers.pages.makeSafePath(this.userPath)      if (this._.isEmpty(newDocPath)) {        this.isInvalid = true      } else {        this.isLoading = true        window.location.assign('/create/' + newDocPath)      }    }  },  mounted () {    this.currentPath = (this.basepath === 'home') ? '' : this.basepath    this.userPath = (this._.isEmpty(this.currentPath)) ? 'new-page' : this.currentPath + '/new-page'  }}</script>
 |