67 lines
		
	
	
		
			No EOL
		
	
	
		
			2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			No EOL
		
	
	
		
			2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
<div class="status-article-compose-box">
 | 
						|
  <ComposeBox realm="{{originalStatusId}}"
 | 
						|
              size="slim"
 | 
						|
              autoFocus="true"
 | 
						|
              hideBottomBorder="true"
 | 
						|
              isReply="true"
 | 
						|
              replyVisibility="{{visibility}}"
 | 
						|
              replySpoiler="{{spoilerText}}"
 | 
						|
              inReplyToUuid="{{uuid}}"
 | 
						|
  />
 | 
						|
</div>
 | 
						|
<style>
 | 
						|
  .status-article-compose-box {
 | 
						|
    grid-area: compose;
 | 
						|
  }
 | 
						|
</style>
 | 
						|
<script>
 | 
						|
  import ComposeBox from '../../_components/compose/ComposeBox.html'
 | 
						|
  import { store } from '../../_store/store'
 | 
						|
  import debounce from 'lodash-es/debounce'
 | 
						|
  import throttle from 'lodash-es/throttle'
 | 
						|
  import { on } from '../../_utils/eventBus'
 | 
						|
 | 
						|
  const DEBOUNCE_DELAY = 400
 | 
						|
  const THROTTLE_DELAY = 150
 | 
						|
 | 
						|
  export default {
 | 
						|
    oncreate() {
 | 
						|
      on('postedStatus', this, this.onPostedStatus)
 | 
						|
      this.setupRecalculateHeightListener()
 | 
						|
    },
 | 
						|
    store: () => store,
 | 
						|
    computed: {
 | 
						|
      composeData: ($currentComposeData, originalStatusId) => $currentComposeData[originalStatusId] || {}
 | 
						|
    },
 | 
						|
    methods: {
 | 
						|
      onPostedStatus(realm) {
 | 
						|
        if (realm !== this.get('originalStatusId')) {
 | 
						|
          return
 | 
						|
        }
 | 
						|
        requestAnimationFrame(() => {
 | 
						|
          let uuid = this.get('uuid')
 | 
						|
          let $repliesShown = this.store.get('repliesShown')
 | 
						|
          $repliesShown[uuid] = false
 | 
						|
          this.store.set({'repliesShown': $repliesShown})
 | 
						|
          this.fire('recalculateHeight')
 | 
						|
        })
 | 
						|
      },
 | 
						|
      setupRecalculateHeightListener() {
 | 
						|
        const recalc = () => requestAnimationFrame(() => this.fire('recalculateHeight'))
 | 
						|
        // debounce AND throttle due to 333ms content warning animation
 | 
						|
        const debounced = debounce(recalc, DEBOUNCE_DELAY)
 | 
						|
        const throttled = throttle(() => {
 | 
						|
          debounced()
 | 
						|
          recalc()
 | 
						|
        }, THROTTLE_DELAY, {
 | 
						|
          leading: true,
 | 
						|
          trailing: true
 | 
						|
        })
 | 
						|
        this.observe('composeData', throttled)
 | 
						|
      }
 | 
						|
    },
 | 
						|
    components: {
 | 
						|
      ComposeBox
 | 
						|
    }
 | 
						|
  }
 | 
						|
</script> |