62 lines
		
	
	
		
			No EOL
		
	
	
		
			2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			No EOL
		
	
	
		
			2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <textarea
 | |
|   class="compose-box-input"
 | |
|   placeholder="What's on your mind?"
 | |
|   ref:textarea
 | |
|   bind:value=$rawInputTextInCompose
 | |
| ></textarea>
 | |
| <style>
 | |
|   .compose-box-input {
 | |
|     grid-area: input;
 | |
|     margin: 10px 0 0 5px;
 | |
|     padding: 10px;
 | |
|     border: 1px solid var(--input-border);
 | |
|     min-height: 75px;
 | |
|     resize: none;
 | |
|     overflow: hidden;
 | |
|     word-wrap: break-word;
 | |
|     /* Text must be at least 16px or else iOS Safari zooms in */
 | |
|     font-size: 1.2em;
 | |
|     /* Hack to make Edge stretch the element all the way to the right.
 | |
|      * Also desktop Safari makes the gauge stretch too far to the right without it.
 | |
|      */
 | |
|     width: calc(100% - 5px);
 | |
|   }
 | |
| </style>
 | |
| <script>
 | |
|   import { store } from '../../_store/store'
 | |
|   import { autosize } from '../../_utils/autosize'
 | |
|   import { scheduleIdleTask } from '../../_utils/scheduleIdleTask'
 | |
|   import debounce from 'lodash/debounce'
 | |
|   import { mark, stop } from '../../_utils/marks'
 | |
| 
 | |
|   export default {
 | |
|     oncreate() {
 | |
|       this.store.set({rawInputTextInCompose: store.get('currentInputTextInCompose')})
 | |
| 
 | |
|       requestAnimationFrame(() => {
 | |
|         mark('autosize()')
 | |
|         autosize(this.refs.textarea)
 | |
|         stop('autosize()')
 | |
|       })
 | |
| 
 | |
|       const saveText = debounce(() => scheduleIdleTask(() => this.store.save()), 1000)
 | |
|       this.observe('rawInputTextInCompose', rawInputTextInCompose => {
 | |
|         let inputTextInCompose = this.store.get('inputTextInCompose')
 | |
|         let currentInstance = this.store.get('currentInstance')
 | |
|         inputTextInCompose[currentInstance] = rawInputTextInCompose || ''
 | |
|         this.store.set({inputTextInCompose: inputTextInCompose})
 | |
|         saveText()
 | |
|       }, {init: false})
 | |
|     },
 | |
|     ondestroy() {
 | |
|       mark('autosize.destroy()')
 | |
|       autosize.destroy(this.refs.textarea)
 | |
|       stop('autosize.destroy()')
 | |
|     },
 | |
|     store: () => store,
 | |
|     computed: {
 | |
|       rawInputTextInCompose: ($rawInputTextInCompose) => $rawInputTextInCompose,
 | |
|       currentInputTextInCompose: ($currentInputTextInCompose) => $currentInputTextInCompose,
 | |
|     }
 | |
|   }
 | |
| </script> |