mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-11-04 03:17:00 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			115 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
<template>
 | 
						|
  <modals-modal v-model="show" name="sleep-timer" :width="350" :height="'unset'">
 | 
						|
    <template #outer>
 | 
						|
      <div class="absolute top-0 left-0 p-5 w-2/3 overflow-hidden pointer-events-none">
 | 
						|
        <p class="font-book text-3xl text-white truncate pointer-events-none">Sleep Timer</p>
 | 
						|
      </div>
 | 
						|
    </template>
 | 
						|
 | 
						|
    <div ref="container" class="w-full rounded-lg bg-primary box-shadow-md overflow-y-auto overflow-x-hidden" style="max-height: 80vh">
 | 
						|
      <div v-if="!timerSet" class="w-full">
 | 
						|
        <template v-for="time in sleepTimes">
 | 
						|
          <div :key="time.text" class="flex items-center px-6 py-3 justify-center cursor-pointer hover:bg-bg relative" @click="setTime(time)">
 | 
						|
            <p class="text-xl text-center">{{ time.text }}</p>
 | 
						|
          </div>
 | 
						|
        </template>
 | 
						|
      </div>
 | 
						|
      <div v-else class="w-full p-4">
 | 
						|
        <div class="mb-4 flex items-center justify-center">
 | 
						|
          <ui-btn :padding-x="2" small :disabled="remaining < 30 * 60" class="flex items-center mr-4" @click="decrement(30 * 60)">
 | 
						|
            <span class="material-icons text-lg">remove</span>
 | 
						|
            <span class="pl-1 text-base font-mono">30m</span>
 | 
						|
          </ui-btn>
 | 
						|
 | 
						|
          <ui-icon-btn icon="remove" @click="decrement(60 * 5)" />
 | 
						|
 | 
						|
          <p class="mx-6 text-2xl font-mono">{{ $secondsToTimestamp(remaining) }}</p>
 | 
						|
 | 
						|
          <ui-icon-btn icon="add" @click="increment(60 * 5)" />
 | 
						|
 | 
						|
          <ui-btn :padding-x="2" small class="flex items-center ml-4" @click="increment(30 * 60)">
 | 
						|
            <span class="material-icons text-lg">add</span>
 | 
						|
            <span class="pl-1 text-base font-mono">30m</span>
 | 
						|
          </ui-btn>
 | 
						|
        </div>
 | 
						|
        <ui-btn class="w-full" @click="$emit('cancel')">Cancel</ui-btn>
 | 
						|
      </div>
 | 
						|
    </div>
 | 
						|
  </modals-modal>
 | 
						|
</template>
 | 
						|
 | 
						|
<script>
 | 
						|
export default {
 | 
						|
  props: {
 | 
						|
    value: Boolean,
 | 
						|
    timerSet: Boolean,
 | 
						|
    timerTime: Number,
 | 
						|
    remaining: Number
 | 
						|
  },
 | 
						|
  data() {
 | 
						|
    return {
 | 
						|
      sleepTimes: [
 | 
						|
        {
 | 
						|
          seconds: 10,
 | 
						|
          text: '10 seconds'
 | 
						|
        },
 | 
						|
        {
 | 
						|
          seconds: 60 * 5,
 | 
						|
          text: '5 minutes'
 | 
						|
        },
 | 
						|
        {
 | 
						|
          seconds: 60 * 30,
 | 
						|
          text: '30 minutes'
 | 
						|
        },
 | 
						|
        {
 | 
						|
          seconds: 60 * 60,
 | 
						|
          text: '60 minutes'
 | 
						|
        },
 | 
						|
        {
 | 
						|
          seconds: 60 * 90,
 | 
						|
          text: '90 minutes'
 | 
						|
        },
 | 
						|
        {
 | 
						|
          seconds: 60 * 120,
 | 
						|
          text: '2 hours'
 | 
						|
        },
 | 
						|
        {
 | 
						|
          seconds: 60 * 180,
 | 
						|
          text: '3 hours'
 | 
						|
        }
 | 
						|
      ]
 | 
						|
    }
 | 
						|
  },
 | 
						|
  watch: {
 | 
						|
    show(newVal) {
 | 
						|
      if (newVal) {
 | 
						|
      }
 | 
						|
    }
 | 
						|
  },
 | 
						|
  computed: {
 | 
						|
    show: {
 | 
						|
      get() {
 | 
						|
        return this.value
 | 
						|
      },
 | 
						|
      set(val) {
 | 
						|
        this.$emit('input', val)
 | 
						|
      }
 | 
						|
    }
 | 
						|
  },
 | 
						|
  methods: {
 | 
						|
    setTime(time) {
 | 
						|
      this.$emit('set', time.seconds)
 | 
						|
    },
 | 
						|
    increment(amount) {
 | 
						|
      this.$emit('increment', amount)
 | 
						|
    },
 | 
						|
    decrement(amount) {
 | 
						|
      if (amount > this.remaining) {
 | 
						|
        if (this.remaining > 60) amount = 60
 | 
						|
        else amount = 5
 | 
						|
      }
 | 
						|
      this.$emit('decrement', amount)
 | 
						|
    }
 | 
						|
  }
 | 
						|
}
 | 
						|
</script> |