| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364 | <template lang='pug'>  v-container(fluid, grid-list-lg)    v-layout(row wrap)      v-flex(xs12)        .admin-header          img.animated.fadeInUp(src='/_assets/svg/icon-categorize.svg', alt='General', style='width: 80px;')          .admin-header-title            .headline.primary--text.animated.fadeInLeft {{ $t('admin:general.title') }}            .subtitle-1.grey--text.animated.fadeInLeft {{ $t('admin:general.subtitle') }}          v-spacer          v-btn.animated.fadeInDown(color='success', depressed, @click='save', large)            v-icon(left) mdi-check            span {{$t('common:actions.apply')}}        v-form.pt-3          v-layout(row wrap)            v-flex(lg6 xs12)              v-form                v-card.animated.fadeInUp                  v-toolbar(color='primary', dark, dense, flat)                    v-toolbar-title.subtitle-1 {{ $t('admin:general.siteInfo') }}                  .overline.grey--text.pa-4 {{$t('admin:general.general')}}                  .px-3.pb-3                    v-text-field(                      outlined                      :label='$t(`admin:general.siteUrl`)'                      required                      :counter='255'                      v-model='config.host'                      prepend-icon='mdi-label-variant-outline'                      :hint='$t(`admin:general.siteUrlHint`)'                      persistent-hint                      )                    v-text-field.mt-3(                      outlined                      :label='$t(`admin:general.siteTitle`)'                      required                      :counter='50'                      v-model='config.title'                      prepend-icon='mdi-earth'                      :hint='$t(`admin:general.siteTitleHint`)'                      persistent-hint                      )                  v-divider                  .overline.grey--text.pa-4 {{$t('admin:general.logo')}}                  .pt-2.pb-7.pl-10.pr-3                    .d-flex.align-center                      v-avatar(size='100', tile)                        v-img(                          :src='config.logoUrl'                          lazy-src=''                          aspect-ratio='1'                          )                      .ml-4(style='flex: 1 1 auto;')                        v-text-field(                          outlined                          :label='$t(`admin:general.logoUrl`)'                          v-model='config.logoUrl'                          :hint='$t(`admin:general.logoUrlHint`)'                          persistent-hint                          append-icon='mdi-folder-image'                          @click:append='browseLogo'                          @keyup.enter='refreshLogo'                        )                  v-divider                  .overline.grey--text.pa-4 {{$t('admin:general.footerCopyright')}}                  .px-3.pb-3                    v-text-field(                      outlined                      :label='$t(`admin:general.companyName`)'                      v-model='config.company'                      :counter='255'                      prepend-icon='mdi-domain'                      persistent-hint                      :hint='$t(`admin:general.companyNameHint`)'                      )                    v-select.mt-3(                      outlined                      :label='$t(`admin:general.contentLicense`)'                      :items='contentLicenses'                      v-model='config.contentLicense'                      prepend-icon='mdi-creative-commons'                      :return-object='false'                      :hint='$t(`admin:general.contentLicenseHint`)'                      persistent-hint                      )                  v-divider                  .overline.grey--text.pa-4 SEO                  .px-3.pb-3                    v-text-field(                      outlined                      :label='$t(`admin:general.siteDescription`)'                      :counter='255'                      v-model='config.description'                      prepend-icon='mdi-compass'                      :hint='$t(`admin:general.siteDescriptionHint`)'                      persistent-hint                      )                    v-select.mt-3(                      outlined                      :label='$t(`admin:general.metaRobots`)'                      multiple                      :items='metaRobots'                      v-model='config.robots'                      prepend-icon='mdi-compass'                      :return-object='false'                      :hint='$t(`admin:general.metaRobotsHint`)'                      persistent-hint                      )            v-flex(lg6 xs12)              v-card.animated.fadeInUp.wait-p4s                v-toolbar(color='indigo', dark, dense, flat)                  v-toolbar-title.subtitle-1 Features                v-card-text                  //- v-switch(                  //-   inset                  //-   label='Asset Image Optimization'                  //-   color='indigo'                  //-   v-model='config.featureTinyPNG'                  //-   persistent-hint                  //-   hint='Image optimization tool to reduce filesize and bandwidth costs.'                  //-   disabled                  //-   )                  //- v-text-field.mt-3(                  //-   outlined                  //-   label='TinyPNG API Key'                  //-   :counter='255'                  //-   v-model='config.description'                  //-   prepend-icon='mdi-subdirectory-arrow-right'                  //-   hint='Get your API key at https://tinypng.com/developers'                  //-   persistent-hint                  //-   disabled                  //-   )                  //- v-divider.mt-3                  //- v-switch(                  //-   inset                  //-   label='Page Ratings'                  //-   color='indigo'                  //-   v-model='config.featurePageRatings'                  //-   persistent-hint                  //-   hint='Allow users to rate pages.'                  //-   disabled                  //-   )                  //- v-divider.mt-3                  v-switch(                    inset                    label='Comments'                    color='indigo'                    v-model='config.featurePageComments'                    persistent-hint                    hint='Allow users to leave comments on pages.'                    )                  //- v-divider.mt-3                  //- v-switch(                  //-   inset                  //-   label='Personal Wikis'                  //-   color='indigo'                  //-   v-model='config.featurePersonalWikis'                  //-   persistent-hint                  //-   hint='Allow users to have their own personal wiki.'                  //-   disabled                  //-   )    component(:is='activeModal')</template><script>import _ from 'lodash'import { sync } from 'vuex-pathify'import gql from 'graphql-tag'import editorStore from '../../store/editor'/* global WIKI */WIKI.$store.registerModule('editor', editorStore)export default {  i18nOptions: { namespaces: 'editor' },  components: {    editorModalMedia: () => import(/* webpackChunkName: "editor", webpackMode: "lazy" */ '../editor/editor-modal-media.vue')  },  data() {    return {      analyticsServices: [        { text: 'None', value: '' },        { text: 'Elasticsearch APM RUM', value: 'elk' },        { text: 'Google Analytics', value: 'ga' },        { text: 'Google Tag Manager', value: 'gtm' }      ],      config: {        host: '',        title: '',        description: '',        robots: [],        analyticsService: '',        analyticsId: '',        company: '',        contentLicense: '',        logoUrl: '',        featureAnalytics: false,        featurePageRatings: false,        featurePageComments: false,        featurePersonalWikis: false,        featureTinyPNG: false      },      metaRobots: [        { text: 'Index', value: 'index' },        { text: 'Follow', value: 'follow' },        { text: 'No Index', value: 'noindex' },        { text: 'No Follow', value: 'nofollow' }      ]    }  },  computed: {    siteTitle: sync('site/title'),    logoUrl: sync('site/logoUrl'),    company: sync('site/company'),    contentLicense: sync('site/contentLicense'),    activeModal: sync('editor/activeModal'),    contentLicenses () {      return [        { value: '', text: this.$t('common:license.none') },        { value: 'alr', text: this.$t('common:license.alr') },        { value: 'cc0', text: this.$t('common:license.cc0') },        { value: 'ccby', text: this.$t('common:license.ccby') },        { value: 'ccbysa', text: this.$t('common:license.ccbysa') },        { value: 'ccbynd', text: this.$t('common:license.ccbynd') },        { value: 'ccbync', text: this.$t('common:license.ccbync') },        { value: 'ccbyncsa', text: this.$t('common:license.ccbyncsa') },        { value: 'ccbyncnd', text: this.$t('common:license.ccbyncnd') }      ]    }  },  methods: {    async save () {      try {        await this.$apollo.mutate({          mutation: gql`            mutation (              $host: String!              $title: String!              $description: String!              $robots: [String]!              $analyticsService: String!              $analyticsId: String!              $company: String!              $contentLicense: String!              $logoUrl: String!              $featurePageRatings: Boolean!              $featurePageComments: Boolean!              $featurePersonalWikis: Boolean!            ) {              site {                updateConfig(                  host: $host,                  title: $title,                  description: $description,                  robots: $robots,                  analyticsService: $analyticsService,                  analyticsId: $analyticsId,                  company: $company,                  contentLicense: $contentLicense,                  logoUrl: $logoUrl,                  featurePageRatings: $featurePageRatings,                  featurePageComments: $featurePageComments,                  featurePersonalWikis: $featurePersonalWikis                ) {                  responseResult {                    succeeded                    errorCode                    slug                    message                  }                }              }            }          `,          variables: {            host: _.get(this.config, 'host', ''),            title: _.get(this.config, 'title', ''),            description: _.get(this.config, 'description', ''),            robots: _.get(this.config, 'robots', []),            analyticsService: _.get(this.config, 'analyticsService', ''),            analyticsId: _.get(this.config, 'analyticsId', ''),            company: _.get(this.config, 'company', ''),            contentLicense: _.get(this.config, 'contentLicense', ''),            logoUrl: _.get(this.config, 'logoUrl', ''),            featurePageRatings: _.get(this.config, 'featurePageRatings', false),            featurePageComments: _.get(this.config, 'featurePageComments', false),            featurePersonalWikis: _.get(this.config, 'featurePersonalWikis', false)          },          watchLoading (isLoading) {            this.$store.commit(`loading${isLoading ? 'Start' : 'Stop'}`, 'admin-site-update')          }        })        this.$store.commit('showNotification', {          style: 'success',          message: 'Configuration saved successfully.',          icon: 'check'        })        this.siteTitle = this.config.title        this.company = this.config.company        this.contentLicense = this.config.contentLicense        this.logoUrl = this.config.logoUrl      } catch (err) {        this.$store.commit('pushGraphError', err)      }    },    browseLogo () {      this.$store.set('editor/editorKey', 'common')      this.activeModal = 'editorModalMedia'    },    refreshLogo () {      this.$forceUpdate()    }  },  mounted () {    this.$root.$on('editorInsert', opts => {      this.config.logoUrl = opts.path    })  },  beforeDestroy() {    this.$root.$off('editorInsert')  },  apollo: {    config: {      query: gql`        {          site {            config {              host              title              description              robots              analyticsService              analyticsId              company              contentLicense              logoUrl              featurePageRatings              featurePageComments              featurePersonalWikis            }          }        }      `,      fetchPolicy: 'network-only',      update: (data) => _.cloneDeep(data.site.config),      watchLoading (isLoading) {        this.$store.commit(`loading${isLoading ? 'Start' : 'Stop'}`, 'admin-site-refresh')      }    }  }}</script><style lang='scss'></style>
 |