summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/set_status_modal/user_profile_set_status_wrapper.vue
blob: c709611e13d18acd633539974bc165682ebd4e6d (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
<script>
import { secondsToMilliseconds } from '~/lib/utils/datetime_utility';
import dateFormat from '~/lib/dateformat';
import SetStatusForm from './set_status_form.vue';
import { isUserBusy } from './utils';
import { NEVER_TIME_RANGE, AVAILABILITY_STATUS } from './constants';

export default {
  components: { SetStatusForm },
  inject: ['fields'],
  data() {
    return {
      emoji: this.fields.emoji.value,
      message: this.fields.message.value,
      availability: isUserBusy(this.fields.availability.value),
      clearStatusAfter: NEVER_TIME_RANGE,
      currentClearStatusAfter: this.fields.clearStatusAfter.value,
    };
  },
  computed: {
    clearStatusAfterInputValue() {
      return this.clearStatusAfter.label === NEVER_TIME_RANGE.label
        ? null
        : this.clearStatusAfter.shortcut;
    },
    availabilityInputValue() {
      return this.availability
        ? this.$options.AVAILABILITY_STATUS.BUSY
        : this.$options.AVAILABILITY_STATUS.NOT_SET;
    },
  },
  mounted() {
    this.$options.formEl = document.querySelector('form.js-edit-user');

    if (!this.$options.formEl) return;

    this.$options.formEl.addEventListener('ajax:success', this.handleFormSuccess);
  },
  beforeDestroy() {
    if (!this.$options.formEl) return;

    this.$options.formEl.removeEventListener('ajax:success', this.handleFormSuccess);
  },
  methods: {
    handleMessageInput(value) {
      this.message = value;
    },
    handleEmojiClick(emoji) {
      this.emoji = emoji;
    },
    handleClearStatusAfterClick(after) {
      this.clearStatusAfter = after;
    },
    handleAvailabilityInput(value) {
      this.availability = value;
    },
    handleFormSuccess() {
      if (!this.clearStatusAfter?.duration?.seconds) {
        this.currentClearStatusAfter = '';

        return;
      }

      const now = new Date();
      const currentClearStatusAfterDate = new Date(
        now.getTime() + secondsToMilliseconds(this.clearStatusAfter.duration.seconds),
      );

      this.currentClearStatusAfter = dateFormat(
        currentClearStatusAfterDate,
        "UTC:yyyy-mm-dd HH:MM:ss 'UTC'",
      );
      this.clearStatusAfter = NEVER_TIME_RANGE;
    },
  },
  AVAILABILITY_STATUS,
  formEl: null,
};
</script>

<template>
  <div>
    <input :value="emoji" type="hidden" :name="fields.emoji.name" />
    <input :value="message" type="hidden" :name="fields.message.name" />
    <input :value="availabilityInputValue" type="hidden" :name="fields.availability.name" />
    <input :value="clearStatusAfterInputValue" type="hidden" :name="fields.clearStatusAfter.name" />
    <set-status-form
      default-emoji="speech_balloon"
      :emoji="emoji"
      :message="message"
      :availability="availability"
      :clear-status-after="clearStatusAfter"
      :current-clear-status-after="currentClearStatusAfter"
      @message-input="handleMessageInput"
      @emoji-click="handleEmojiClick"
      @clear-status-after-click="handleClearStatusAfterClick"
      @availability-input="handleAvailabilityInput"
    />
  </div>
</template>