| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  | {#if realm === 'home'} | 
					
						
							| 
									
										
										
										
											2018-08-28 06:44:36 -07:00
										 |  |  |   <h1 class="sr-only">Compose status</h1> | 
					
						
							| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  | {/if} | 
					
						
							|  |  |  | <div class="{computedClassName} {hideAndFadeIn}"> | 
					
						
							| 
									
										
										
										
											2018-03-03 10:11:32 -08:00
										 |  |  |   <ComposeAuthor /> | 
					
						
							| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  |   {#if contentWarningShown} | 
					
						
							| 
									
										
										
										
											2018-03-03 16:25:22 -08:00
										 |  |  |     <div class="compose-content-warning-wrapper" | 
					
						
							|  |  |  |          transition:slide="{duration: 333}"> | 
					
						
							| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  |       <ComposeContentWarning {realm} {contentWarning} /> | 
					
						
							| 
									
										
										
										
											2018-03-03 16:25:22 -08:00
										 |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  |   {/if} | 
					
						
							|  |  |  |   <ComposeInput {realm} {text} {autoFocus} on:postAction="doPostStatus()" /> | 
					
						
							|  |  |  |   <ComposeLengthGauge {length} {overLimit} /> | 
					
						
							|  |  |  |   <ComposeToolbar {realm} {postPrivacy} {media} {contentWarningShown} {text} /> | 
					
						
							|  |  |  |   <ComposeLengthIndicator {length} {overLimit} /> | 
					
						
							| 
									
										
										
										
											2018-08-26 18:54:59 -07:00
										 |  |  |   <ComposeMedia {realm} {media} /> | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  | </div> | 
					
						
							| 
									
										
										
										
											2018-12-07 23:23:48 -08:00
										 |  |  | <ComposeStickyButton {showSticky} | 
					
						
							|  |  |  |                      {overLimit} | 
					
						
							|  |  |  |                      {hideAndFadeIn} | 
					
						
							|  |  |  |                      on:postAction="doPostStatus()" /> | 
					
						
							| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  | {#if !hideBottomBorder} | 
					
						
							|  |  |  |   <div class="compose-box-border-bottom {hideAndFadeIn}"></div> | 
					
						
							|  |  |  | {/if} | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  | <style> | 
					
						
							| 
									
										
										
										
											2018-02-26 21:54:21 -08:00
										 |  |  |   .compose-box { | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  |     border-radius: 4px; | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |     padding: 20px 20px 0 20px; | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  |     display: grid; | 
					
						
							|  |  |  |     align-items: flex-start; | 
					
						
							|  |  |  |     grid-template-areas: | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |       "avatar name       handle    handle" | 
					
						
							|  |  |  |       "avatar cw         cw        cw" | 
					
						
							|  |  |  |       "avatar input      input     input" | 
					
						
							|  |  |  |       "avatar gauge      gauge     gauge" | 
					
						
							|  |  |  |       "avatar toolbar    toolbar   length" | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |       "avatar media      media     media"; | 
					
						
							| 
									
										
										
										
											2018-02-26 20:55:49 -08:00
										 |  |  |     grid-template-columns: min-content minmax(0, max-content) 1fr 1fr; | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  |     width: 560px; | 
					
						
							|  |  |  |     max-width: calc(100vw - 40px); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-04 23:03:26 -07:00
										 |  |  |   .compose-box.direct-reply { | 
					
						
							|  |  |  |     background-color: var(--status-direct-background); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-30 01:06:17 -07:00
										 |  |  |   .compose-box.slim-size { | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |     width: 540px; | 
					
						
							| 
									
										
										
										
											2018-03-28 09:05:22 -07:00
										 |  |  |     max-width: calc(100vw - 60px); | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-29 23:16:53 -07:00
										 |  |  |   .compose-box-fade-in { | 
					
						
							|  |  |  |     transition: opacity 0.2s linear; /* main page reveal */ | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |   .compose-box-border-bottom { | 
					
						
							|  |  |  |     height: 1px; | 
					
						
							|  |  |  |     background: var(--main-border); | 
					
						
							|  |  |  |     width: 100%; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-03 16:25:22 -08:00
										 |  |  |   .compose-content-warning-wrapper { | 
					
						
							|  |  |  |     grid-area: cw; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  |   @media (max-width: 767px) { | 
					
						
							| 
									
										
										
										
											2018-02-26 21:54:21 -08:00
										 |  |  |     .compose-box { | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |       padding: 10px 10px 0 10px; | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  |       max-width: calc(100vw - 20px); | 
					
						
							|  |  |  |       width: 580px; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-12-02 11:22:18 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-30 01:06:17 -07:00
										 |  |  |     .compose-box.slim-size { | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |       width: 560px; | 
					
						
							|  |  |  |       max-width: calc(100vw - 40px); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | </style> | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2018-02-26 21:50:03 -08:00
										 |  |  |   import ComposeToolbar from './ComposeToolbar.html' | 
					
						
							|  |  |  |   import ComposeLengthGauge from './ComposeLengthGauge.html' | 
					
						
							|  |  |  |   import ComposeLengthIndicator from './ComposeLengthIndicator.html' | 
					
						
							| 
									
										
										
										
											2018-02-26 21:54:21 -08:00
										 |  |  |   import ComposeAuthor from './ComposeAuthor.html' | 
					
						
							| 
									
										
										
										
											2018-02-26 22:22:56 -08:00
										 |  |  |   import ComposeInput from './ComposeInput.html' | 
					
						
							| 
									
										
										
										
											2018-12-02 11:22:18 -08:00
										 |  |  |   import ComposeStickyButton from './ComposeStickyButton.html' | 
					
						
							| 
									
										
										
										
											2018-03-01 21:21:49 -08:00
										 |  |  |   import ComposeMedia from './ComposeMedia.html' | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |   import ComposeContentWarning from './ComposeContentWarning.html' | 
					
						
							| 
									
										
										
										
											2018-03-03 14:51:48 -08:00
										 |  |  |   import { measureText } from '../../_utils/measureText' | 
					
						
							| 
									
										
										
										
											2018-08-26 12:14:16 -07:00
										 |  |  |   import { POST_PRIVACY_OPTIONS } from '../../_static/statuses' | 
					
						
							| 
									
										
										
										
											2018-03-03 14:51:48 -08:00
										 |  |  |   import { store } from '../../_store/store' | 
					
						
							| 
									
										
										
										
											2018-03-03 16:25:22 -08:00
										 |  |  |   import { slide } from 'svelte-transitions' | 
					
						
							| 
									
										
										
										
											2018-04-03 17:50:48 -07:00
										 |  |  |   import { postStatus, insertHandleForReply, setReplySpoiler, setReplyVisibility } from '../../_actions/compose' | 
					
						
							| 
									
										
										
										
											2018-03-29 23:16:53 -07:00
										 |  |  |   import { classname } from '../../_utils/classname' | 
					
						
							| 
									
										
										
										
											2018-02-25 17:21:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  |   export default { | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |     oncreate () { | 
					
						
							| 
									
										
										
										
											2018-12-02 11:22:18 -08:00
										 |  |  |       let { realm, replySpoiler, replyVisibility } = this.get() | 
					
						
							|  |  |  |       if (realm !== 'home' && realm !== 'dialog') { | 
					
						
							| 
									
										
										
										
											2018-03-09 08:45:12 -08:00
										 |  |  |         // if this is a reply, populate the handle immediately | 
					
						
							| 
									
										
										
										
											2018-12-02 11:22:18 -08:00
										 |  |  |         /* no await */ insertHandleForReply(realm) | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-03-09 08:45:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-03 09:45:17 -07:00
										 |  |  |       if (replySpoiler) { | 
					
						
							|  |  |  |         // default spoiler is same as the replied-to status | 
					
						
							|  |  |  |         setReplySpoiler(realm, replySpoiler) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-03 17:50:48 -07:00
										 |  |  |       if (replyVisibility) { | 
					
						
							|  |  |  |         // make sure the visibility is consistent with the replied-to status | 
					
						
							|  |  |  |         setReplyVisibility(realm, replyVisibility) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  |     components: { | 
					
						
							| 
									
										
										
										
											2018-02-26 21:54:21 -08:00
										 |  |  |       ComposeAuthor, | 
					
						
							| 
									
										
										
										
											2018-02-26 21:50:03 -08:00
										 |  |  |       ComposeToolbar, | 
					
						
							|  |  |  |       ComposeLengthGauge, | 
					
						
							| 
									
										
										
										
											2018-02-26 22:22:56 -08:00
										 |  |  |       ComposeLengthIndicator, | 
					
						
							|  |  |  |       ComposeInput, | 
					
						
							| 
									
										
										
										
											2018-12-02 11:22:18 -08:00
										 |  |  |       ComposeStickyButton, | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |       ComposeMedia, | 
					
						
							|  |  |  |       ComposeContentWarning | 
					
						
							| 
									
										
										
										
											2018-03-03 14:51:48 -08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-04-29 22:13:41 -07:00
										 |  |  |     data: () => ({ | 
					
						
							|  |  |  |       size: void 0, | 
					
						
							|  |  |  |       isReply: false, | 
					
						
							|  |  |  |       autoFocus: false, | 
					
						
							| 
									
										
										
										
											2018-04-30 19:06:08 -07:00
										 |  |  |       hideBottomBorder: false, | 
					
						
							|  |  |  |       hidden: false | 
					
						
							| 
									
										
										
										
											2018-04-29 22:13:41 -07:00
										 |  |  |     }), | 
					
						
							| 
									
										
										
										
											2018-03-03 14:51:48 -08:00
										 |  |  |     store: () => store, | 
					
						
							|  |  |  |     computed: { | 
					
						
							| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  |       computedClassName: ({ overLimit, realm, size, postPrivacyKey, isReply }) => (classname( | 
					
						
							| 
									
										
										
										
											2018-04-20 10:36:05 -07:00
										 |  |  |         'compose-box', | 
					
						
							|  |  |  |         overLimit && 'over-char-limit', | 
					
						
							|  |  |  |         size === 'slim' && 'slim-size', | 
					
						
							|  |  |  |         isReply && postPrivacyKey === 'direct' && 'direct-reply' | 
					
						
							|  |  |  |       )), | 
					
						
							| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  |       hideAndFadeIn: ({ hidden }) => (classname( | 
					
						
							| 
									
										
										
										
											2018-04-20 10:36:05 -07:00
										 |  |  |         'compose-box-fade-in', | 
					
						
							|  |  |  |         hidden && 'hidden' | 
					
						
							|  |  |  |       )), | 
					
						
							| 
									
										
										
										
											2018-12-02 11:22:18 -08:00
										 |  |  |       showSticky: ({ realm }) => realm === 'home', | 
					
						
							| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  |       composeData: ({ $currentComposeData, realm }) => $currentComposeData[realm] || {}, | 
					
						
							|  |  |  |       text: ({ composeData }) => composeData.text || '', | 
					
						
							|  |  |  |       media: ({ composeData }) => composeData.media || [], | 
					
						
							|  |  |  |       postPrivacy: ({ postPrivacyKey }) => POST_PRIVACY_OPTIONS.find(_ => _.key === postPrivacyKey), | 
					
						
							|  |  |  |       defaultPostPrivacyKey: ({ $currentVerifyCredentials }) => $currentVerifyCredentials.source.privacy, | 
					
						
							|  |  |  |       postPrivacyKey: ({ composeData, defaultPostPrivacyKey }) => composeData.postPrivacy || defaultPostPrivacyKey, | 
					
						
							|  |  |  |       textLength: ({ text }) => measureText(text), | 
					
						
							|  |  |  |       contentWarningLength: ({ contentWarning }) => measureText(contentWarning), | 
					
						
							|  |  |  |       length: ({ textLength, contentWarningLength, contentWarningShown }) => ( | 
					
						
							| 
									
										
										
										
											2018-04-20 10:36:05 -07:00
										 |  |  |         textLength + (contentWarningShown ? contentWarningLength : 0) | 
					
						
							|  |  |  |       ), | 
					
						
							| 
									
										
										
										
											2018-08-26 12:14:16 -07:00
										 |  |  |       overLimit: ({ length, $maxStatusChars }) => length > $maxStatusChars, | 
					
						
							| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  |       contentWarningShown: ({ composeData }) => composeData.contentWarningShown, | 
					
						
							| 
									
										
										
										
											2018-12-02 11:22:18 -08:00
										 |  |  |       contentWarning: ({ composeData }) => composeData.contentWarning || '' | 
					
						
							| 
									
										
										
										
											2018-03-03 16:25:22 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     transitions: { | 
					
						
							|  |  |  |       slide | 
					
						
							| 
									
										
										
										
											2018-03-04 16:27:15 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     methods: { | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |       doPostStatus () { | 
					
						
							| 
									
										
										
										
											2018-04-19 09:37:05 -07:00
										 |  |  |         let { | 
					
						
							|  |  |  |           text, | 
					
						
							|  |  |  |           media, | 
					
						
							|  |  |  |           postPrivacyKey, | 
					
						
							|  |  |  |           contentWarning, | 
					
						
							|  |  |  |           realm, | 
					
						
							|  |  |  |           overLimit, | 
					
						
							|  |  |  |           inReplyToUuid | 
					
						
							|  |  |  |         } = this.get() | 
					
						
							| 
									
										
										
										
											2018-04-12 05:01:17 +02:00
										 |  |  |         let sensitive = media.length && !!contentWarning | 
					
						
							|  |  |  |         let mediaIds = media.map(_ => _.data.id) | 
					
						
							| 
									
										
										
										
											2018-08-26 18:54:59 -07:00
										 |  |  |         let mediaDescriptions = media.map(_ => _.description) | 
					
						
							| 
									
										
										
										
											2018-04-12 05:01:17 +02:00
										 |  |  |         let inReplyTo = (realm === 'home' || realm === 'dialog') ? null : realm | 
					
						
							| 
									
										
										
										
											2018-03-07 18:04:20 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-26 18:54:59 -07:00
										 |  |  |         if (overLimit || (!text && !media.length)) { | 
					
						
							| 
									
										
										
										
											2018-04-12 05:01:17 +02:00
										 |  |  |           return // do nothing if invalid | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-12 05:01:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /* no await */ | 
					
						
							|  |  |  |         postStatus(realm, text, inReplyTo, mediaIds, | 
					
						
							| 
									
										
										
										
											2018-04-12 21:18:14 -07:00
										 |  |  |           sensitive, contentWarning, postPrivacyKey, | 
					
						
							|  |  |  |           mediaDescriptions, inReplyToUuid) | 
					
						
							| 
									
										
										
										
											2018-03-04 16:27:15 -08:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-02-26 00:24:28 -08:00
										 |  |  | </script> |