aboutsummaryrefslogtreecommitdiff
path: root/src/components/style_switcher/style_switcher.vue
blob: 31bf546db9c4095f2ea36ad176cabce18f1deef5 (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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<template>
  <div>
    <p>{{$t('settings.presets')}}</p>
    <select v-model="selected" class="style-switcher">
      <option v-for="style in availableStyles" :value="style">{{style[0]}}</option>
    </select>
    <p>{{$t('settings.theme_help')}}</p>
    <div class="color-container">
      <div class="color-item">
        <label for="bgcolor" class="base04 theme-color-lb">{{$t('settings.background')}}</label>
        <input id="bgcolor" class="theme-color-cl" type="color" v-model="bgColorLocal">
        <input id="bgcolor-t" class="theme-color-in" type="text" v-model="bgColorLocal">
      </div>
      <div class="color-item">
        <label for="fgcolor" class="base04 theme-color-lb">{{$t('settings.foreground')}}</label>
        <input id="fgcolor" class="theme-color-cl" type="color" v-model="fgColorLocal">
        <input id="fgcolor-t" class="theme-color-in" type="text" v-model="fgColorLocal">
      </div>
      <div class="color-item">
        <label for="textcolor" class="base04 theme-color-lb">{{$t('settings.text')}}</label>
        <input id="textcolor" class="theme-color-cl" type="color" v-model="textColorLocal">
        <input id="textcolor-t" class="theme-color-in" type="text" v-model="textColorLocal">
      </div>
      <div class="color-item">
        <label for="linkcolor" class="base04 theme-color-lb">{{$t('settings.links')}}</label>
        <input id="linkcolor" class="theme-color-cl" type="color" v-model="linkColorLocal">
        <input id="linkcolor-t" class="theme-color-in" type="text" v-model="linkColorLocal">
      </div>
    </div>
    <div>
      <div class="panel">
        <div class="panel-heading" :style="{ 'background-color': fgColorLocal, 'color': textColorLocal }">Preview</div>
        <div class="panel-body theme-preview-content" :style="{ 'background-color': bgColorLocal, 'color': textColorLocal }">
          <h4>Content</h4>
          <br>
          A bunch of more content and
          <a :style="{ 'color': linkColorLocal }">a nice lil' link</a>
          <br>
          <button class="btn" :style="{ 'background-color': fgColorLocal, 'color': textColorLocal }">Button</button>
        </div>
      </div>
    </div>
    <button class="btn base02-background base04" @click="setCustomTheme">{{$t('general.apply')}}</button>
  </div>
</template>

<script src="./style_switcher.js"></script>

<style lang="scss">
.style-switcher {
    margin-right: 1em;
}

.color-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.color-item {
    min-width: 20em;
    display:flex;
    flex: 1 1 0;
    align-items: baseline;
    margin: 5px 6px 5px 0;
}
.theme-color-cl,
.theme-color-in {
    margin-left: 4px;
    border-radius: 2px;
    border: 0;
}

.theme-color-in {
    padding: 5px;
    min-width: 4em;
    max-width: 7em;
    flex: 1;
}
.theme-color-lb {
    flex: 2;
    min-width: 7em;
    max-width: 10em;
}

.theme-color-cl {
    padding: 1px;
    max-width: 8em;
    align-self: stretch;
    height: 100%;
    flex: 0;
    min-width: 2em;
    cursor: pointer;
 }

 .theme-preview-content {
   padding: 20px;
 }
</style>