aboutsummaryrefslogtreecommitdiff
path: root/src/components/settings_modal/helpers/integer_setting.js
blob: 17dc0e7b874bac5b1b073cd984dbc3bfa49f829d (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
import { get, set } from 'lodash'
import ModifiedIndicator from './modified_indicator.vue'
export default {
  components: {
    ModifiedIndicator
  },
  props: {
    path: String,
    disabled: Boolean,
    min: Number,
    expert: [Number, String]
  },
  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)
    },
    isChanged () {
      return this.state !== this.defaultState
    },
    matchesExpertLevel () {
      return (this.expert || 0) <= this.$parent.expertLevel
    }
  },
  methods: {
    update (e) {
      set(this.$parent, this.path, parseInt(e.target.value))
    }
  }
}