aboutsummaryrefslogtreecommitdiff
path: root/src/components/settings_modal/helpers/boolean_setting.js
blob: 353e551c9fc05fa9d50aa0bd21cbfbecb008ba1c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import { get, set } from 'lodash'
import Checkbox from 'src/components/checkbox/checkbox.vue'
import ModifiedIndicator from './modified_indicator.vue'
import ServerSideIndicator from './server_side_indicator.vue'
export default {
  components: {
    Checkbox,
    ModifiedIndicator,
    ServerSideIndicator
  },
  props: [
    'path',
    'disabled',
    'expert'
  ],
  computed: {
    pathDefault () {
      const [firstSegment, ...rest] = this.path.split('.')
      return [firstSegment + 'DefaultValue', ...rest].join('.')
    },
    state () {
      const value = get(this.$parent, this.path)
      if (value === undefined) {
        return this.defaultState
      } else {
        return value
      }
    },
    defaultState () {
      return get(this.$parent, this.pathDefault)
    },
    isServerSide () {
      return this.path.startsWith('serverSide_')
    },
    isChanged () {
      return !this.path.startsWith('serverSide_') && this.state !== this.defaultState
    },
    matchesExpertLevel () {
      return (this.expert || 0) <= this.$parent.expertLevel
    }
  },
  methods: {
    update (e) {
      set(this.$parent, this.path, e)
    }
  }
}