| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  | <input class="content-warning-input" | 
					
						
							|  |  |  |        type="text" | 
					
						
							|  |  |  |        placeholder="Content warning" | 
					
						
							|  |  |  |        aria-label="Content warning" | 
					
						
							|  |  |  |        bind:value=rawText | 
					
						
							|  |  |  | /> | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  |   .content-warning-input { | 
					
						
							|  |  |  |     font-size: 1.2em; | 
					
						
							|  |  |  |     margin: 10px 0 0 5px; | 
					
						
							|  |  |  |     padding: 10px; | 
					
						
							|  |  |  |     border: 1px solid var(--input-border); | 
					
						
							|  |  |  |     width: calc(100% - 5px); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | </style> | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  |   import { store } from '../../_store/store' | 
					
						
							| 
									
										
										
										
											2018-04-05 17:57:36 -07:00
										 |  |  |   import debounce from 'lodash-es/debounce' | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |   import { scheduleIdleTask } from '../../_utils/scheduleIdleTask' | 
					
						
							| 
									
										
										
										
											2018-04-30 08:29:04 -07:00
										 |  |  |   import { observe } from 'svelte-extras' | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   export default { | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |     oncreate () { | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |       this.setupSyncFromStore() | 
					
						
							|  |  |  |       this.setupSyncToStore() | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     store: () => store, | 
					
						
							|  |  |  |     data: () => ({ | 
					
						
							|  |  |  |       rawText: '' | 
					
						
							|  |  |  |     }), | 
					
						
							|  |  |  |     methods: { | 
					
						
							| 
									
										
										
										
											2018-04-30 08:29:04 -07:00
										 |  |  |       observe, | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |       setupSyncFromStore () { | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |         this.observe('contentWarning', contentWarning => { | 
					
						
							| 
									
										
										
										
											2018-08-29 21:42:57 -07:00
										 |  |  |           this.set({ rawText: contentWarning }) | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |         }) | 
					
						
							|  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |       setupSyncToStore () { | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |         const saveText = debounce(() => scheduleIdleTask(() => this.store.save()), 1000) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.observe('rawText', rawText => { | 
					
						
							| 
									
										
										
										
											2018-04-19 09:37:05 -07:00
										 |  |  |           let { realm } = this.get() | 
					
						
							|  |  |  |           this.store.setComposeData(realm, { | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |             contentWarning: rawText | 
					
						
							|  |  |  |           }) | 
					
						
							|  |  |  |           saveText() | 
					
						
							| 
									
										
										
										
											2018-08-29 21:42:57 -07:00
										 |  |  |         }, { init: false }) | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | </script> |