aboutsummaryrefslogtreecommitdiff
path: root/src/components/user_settings/user_settings.vue
blob: 1ef52bbf45a63d8de8f112feb2360c68fbee7b89 (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
100
101
102
103
<template>
  <div class="settings panel panel-default base00-background">
    <div class="panel-heading base02-background base04">
      {{$t('settings.user_settings')}}
    </div>
    <div class="panel-body profile-edit">
      <div class="setting-item">
        <h3>{{$t('settings.name_bio')}}</h3>
        <p>{{$t('settings.name')}}</p>
        <input class='name-changer base03-border' id='username' v-model="newname"></input>
        <p>{{$t('settings.bio')}}</p>
        <textarea class="bio base03-border" v-model="newbio"></textarea>
        <button :disabled='newname.length <= 0' class="btn btn-default base05 base02-background" @click="updateProfile">{{$t('general.submit')}}</button>
      </div>
      <div class="setting-item">
        <h3>{{$t('settings.avatar')}}</h3>
        <p>{{$t('settings.current_avatar')}}</p>
        <img :src="user.profile_image_url_original" class="old-avatar"></img>
        <p>{{$t('settings.set_new_avatar')}}</p>
        <img class="new-avatar" v-bind:src="previews[0]" v-if="previews[0]">
        </img>
        <div>
          <input type="file" @change="uploadFile(0, $event)" ></input>
        </div>
        <i class="base09 icon-spin4 animate-spin" v-if="uploading[0]"></i>
        <button class="btn btn-default base05 base02-background" v-else-if="previews[0]" @click="submitAvatar">{{$t('general.submit')}}</button>
      </div>
      <div class="setting-item">
        <h3>{{$t('settings.profile_banner')}}</h3>
        <p>{{$t('settings.current_profile_banner')}}</p>
        <img :src="user.cover_photo" class="banner"></img>
        <p>{{$t('settings.set_new_profile_banner')}}</p>
        <img class="banner" v-bind:src="previews[1]" v-if="previews[1]">
        </img>
        <div>
          <input type="file" @change="uploadFile(1, $event)" ></input>
        </div>
        <i class="base09 icon-spin4 animate-spin uploading" v-if="uploading[1]"></i>
        <button class="btn btn-default base05 base02-background" v-else-if="previews[1]" @click="submitBanner">{{$t('general.submit')}}</button>
      </div>
      <div class="setting-item">
        <h3>{{$t('settings.profile_background')}}</h3>
        <p>{{$t('settings.set_new_profile_background')}}</p>
        <img class="bg" v-bind:src="previews[2]" v-if="previews[2]">
        </img>
        <div>
          <input type="file" @change="uploadFile(2, $event)" ></input>
        </div>
        <i class="base09 icon-spin4 animate-spin uploading" v-if="uploading[2]"></i>
        <button class="btn btn-default base05 base02-background" v-else-if="previews[2]" @click="submitBg">{{$t('general.submit')}}</button>
      </div>
      <div class="setting-item" v-if="pleromaBackend">
        <h3>{{$t('settings.follow_import')}}</h3>
        <p>{{$t('settings.import_followers_from_a_csv_file')}}</p>
        <form v-model="followImportForm">
          <input type="file" ref="followlist" v-on:change="followListChange"></input>
        </form>
        <i class="base09 icon-spin4 animate-spin uploading" v-if="uploading[3]"></i>
        <button class="btn btn-default base05 base02-background" v-else @click="importFollows">{{$t('general.submit')}}</button>
        <div v-if="followsImported">
          <i class="icon-cross" @click="dismissImported"></i>
          <p>{{$t('settings.follows_imported')}}</p>
        </div>
        <div v-else-if="followImportError">
          <i class="icon-cross" @click="dismissImported"</i>
          <p>{{$t('settings.follow_import_error')}}</p>
        </div>
      </div>
    </div>
  </div>
</template>

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

<style lang="scss">
.profile-edit {
  .name-changer {
    border-width: 1px;
    border-style: solid;
    border-radius: 5px;
    padding: 0.2em 0.2em 0.2em 0.2em;
  }
  .name-submit {
    padding: 0.2em 0.5em 0.2em 0.5em;
  }
  .bio {
    border-width: 1px;
    border-style: solid;
    border-radius: 5px;
    margin: 0;
  }
  .banner {
    max-width: 400px;
    border-radius: 5px;
  }

  .uploading {
    font-size: 1.5em;
    margin: 0.25em;
  }
}
</style>