| 
									
										
										
										
											2018-04-10 22:08:14 -07:00
										 |  |  | {{#if realm === 'home'}} | 
					
						
							|  |  |  |   <h1 class="sr-only">Compose toot</h1> | 
					
						
							|  |  |  | {{/if}} | 
					
						
							| 
									
										
										
										
											2018-03-30 01:06:17 -07:00
										 |  |  | <div class="{{computedClassName}} {{hideAndFadeIn}}"> | 
					
						
							| 
									
										
										
										
											2018-03-03 10:11:32 -08:00
										 |  |  |   <ComposeAuthor /> | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |   {{#if contentWarningShown}} | 
					
						
							| 
									
										
										
										
											2018-03-03 16:25:22 -08:00
										 |  |  |     <div class="compose-content-warning-wrapper" | 
					
						
							|  |  |  |          transition:slide="{duration: 333}"> | 
					
						
							|  |  |  |       <ComposeContentWarning :realm :contentWarning /> | 
					
						
							|  |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |   {{/if}} | 
					
						
							| 
									
										
										
										
											2018-04-11 20:00:43 -07:00
										 |  |  |   <ComposeInput :realm :text :autoFocus on:postAction="doPostStatus()" /> | 
					
						
							| 
									
										
										
										
											2018-03-03 16:12:48 -08:00
										 |  |  |   <ComposeLengthGauge :length :overLimit /> | 
					
						
							| 
									
										
										
										
											2018-03-24 18:04:54 -07:00
										 |  |  |   <ComposeToolbar :realm :postPrivacy :media :contentWarningShown :text /> | 
					
						
							| 
									
										
										
										
											2018-03-03 16:12:48 -08:00
										 |  |  |   <ComposeLengthIndicator :length :overLimit /> | 
					
						
							| 
									
										
										
										
											2018-04-09 18:30:15 -07:00
										 |  |  |   <ComposeMedia :realm :media :mediaDescriptions /> | 
					
						
							| 
									
										
										
										
											2018-02-25 16:26:43 -08:00
										 |  |  | </div> | 
					
						
							| 
									
										
										
										
											2018-03-29 23:16:53 -07:00
										 |  |  | <div class="compose-box-button-sentinel {{hideAndFadeIn}}" ref:sentinel></div> | 
					
						
							| 
									
										
										
										
											2018-03-30 01:06:17 -07:00
										 |  |  | <div class="compose-box-button-wrapper {{realm === 'home' ? 'compose-button-sticky' : ''}} {{hideAndFadeIn}}" > | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |  <ComposeButton :length :overLimit :sticky on:click="onClickPostButton()" /> | 
					
						
							|  |  |  | </div> | 
					
						
							| 
									
										
										
										
											2018-03-30 01:06:17 -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%; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .compose-box-button-wrapper { | 
					
						
							| 
									
										
										
										
											2018-04-12 20:23:38 -07:00
										 |  |  |     /* | 
					
						
							|  |  |  |      * We want pointer-events only for the sticky button, so use fit-content so that | 
					
						
							|  |  |  |      * the element doesn't take up the full width, and then set its left margin to | 
					
						
							|  |  |  |      * auto so that it sticks to the right. fit-content doesn't work in Edge, but | 
					
						
							|  |  |  |      * that just means that content that is level with the button is not clickable. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Before this, I tried a wrapper element with pointer-events:none and then | 
					
						
							|  |  |  |      * pointer-events:auto on the button itself, but in Chrome that made it so | 
					
						
							|  |  |  |      * that occasionally hit detection failed and a click on the button would fall | 
					
						
							|  |  |  |      * through and click something underneath, which is a worse bug. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     width: -moz-fit-content; | 
					
						
							|  |  |  |     width: fit-content; | 
					
						
							|  |  |  |     margin-left: auto; | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |     display: flex; | 
					
						
							|  |  |  |     justify-content: flex-end; | 
					
						
							| 
									
										
										
										
											2018-03-30 01:06:17 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .compose-box-button-wrapper.compose-button-sticky { | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |     position: -webkit-sticky; | 
					
						
							|  |  |  |     position: sticky; | 
					
						
							|  |  |  |     top: 10px; | 
					
						
							| 
									
										
										
										
											2018-04-04 20:32:54 -07:00
										 |  |  |     z-index: 5000; | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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-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-04-12 19:37:37 -07:00
										 |  |  |     .compose-box-button-wrapper.compose-button-sticky { | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |       top: 5px; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											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' | 
					
						
							|  |  |  |   import ComposeButton from './ComposeButton.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' | 
					
						
							|  |  |  |   import { CHAR_LIMIT, POST_PRIVACY_OPTIONS } from '../../_static/statuses' | 
					
						
							|  |  |  |   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-27 00:02:55 -07:00
										 |  |  |   import { importDialogs } from '../../_utils/asyncModules' | 
					
						
							| 
									
										
										
										
											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-03-07 18:04:20 -08:00
										 |  |  |     oncreate() { | 
					
						
							| 
									
										
										
										
											2018-03-09 08:45:12 -08:00
										 |  |  |       let realm = this.get('realm') | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |       if (realm === 'home') { | 
					
						
							| 
									
										
										
										
											2018-03-31 09:36:29 -07:00
										 |  |  |         this.setupStickyObserver() | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |       } else if (realm !== 'dialog') { | 
					
						
							| 
									
										
										
										
											2018-03-09 08:45:12 -08:00
										 |  |  |         // if this is a reply, populate the handle immediately | 
					
						
							|  |  |  |         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
										 |  |  |       let replySpoiler = this.get('replySpoiler') | 
					
						
							|  |  |  |       if (replySpoiler) { | 
					
						
							|  |  |  |         // default spoiler is same as the replied-to status | 
					
						
							|  |  |  |         setReplySpoiler(realm, replySpoiler) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-03 17:50:48 -07:00
										 |  |  |       let replyVisibility = this.get('replyVisibility') | 
					
						
							|  |  |  |       if (replyVisibility) { | 
					
						
							|  |  |  |         // make sure the visibility is consistent with the replied-to status | 
					
						
							|  |  |  |         setReplyVisibility(realm, replyVisibility) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |     ondestroy() { | 
					
						
							| 
									
										
										
										
											2018-03-31 09:36:29 -07:00
										 |  |  |       this.teardownStickyObserver() | 
					
						
							| 
									
										
										
										
											2018-03-07 18:04:20 -08: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-03-01 21:21:49 -08:00
										 |  |  |       ComposeButton, | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |       ComposeMedia, | 
					
						
							|  |  |  |       ComposeContentWarning | 
					
						
							| 
									
										
										
										
											2018-03-03 14:51:48 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     store: () => store, | 
					
						
							|  |  |  |     computed: { | 
					
						
							| 
									
										
										
										
											2018-04-04 23:03:26 -07:00
										 |  |  |       computedClassName: (overLimit, realm, size, postPrivacyKey, isReply) => { | 
					
						
							| 
									
										
										
										
											2018-03-29 23:16:53 -07:00
										 |  |  |         return classname( | 
					
						
							|  |  |  |           'compose-box', | 
					
						
							|  |  |  |           overLimit && 'over-char-limit', | 
					
						
							| 
									
										
										
										
											2018-04-04 23:03:26 -07:00
										 |  |  |           size === 'slim' && 'slim-size', | 
					
						
							|  |  |  |           isReply && postPrivacyKey === 'direct' && 'direct-reply' | 
					
						
							| 
									
										
										
										
											2018-03-29 23:16:53 -07:00
										 |  |  |         ) | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       hideAndFadeIn: (hidden) => { | 
					
						
							|  |  |  |         return classname( | 
					
						
							|  |  |  |           'compose-box-fade-in', | 
					
						
							|  |  |  |           hidden && 'hidden' | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2018-03-03 14:51:48 -08:00
										 |  |  |       composeData: ($currentComposeData, realm) => $currentComposeData[realm] || {}, | 
					
						
							|  |  |  |       text: (composeData) => composeData.text || '', | 
					
						
							|  |  |  |       media: (composeData) => composeData.media || [], | 
					
						
							|  |  |  |       postPrivacy: (postPrivacyKey) => POST_PRIVACY_OPTIONS.find(_ => _.key === postPrivacyKey), | 
					
						
							| 
									
										
										
										
											2018-04-03 17:50:48 -07:00
										 |  |  |       defaultPostPrivacyKey: ($currentVerifyCredentials) => $currentVerifyCredentials.source.privacy, | 
					
						
							| 
									
										
										
										
											2018-03-03 14:51:48 -08:00
										 |  |  |       postPrivacyKey: (composeData, defaultPostPrivacyKey) => composeData.postPrivacy || defaultPostPrivacyKey, | 
					
						
							|  |  |  |       textLength: (text) => measureText(text), | 
					
						
							| 
									
										
										
										
											2018-03-03 16:12:48 -08:00
										 |  |  |       contentWarningLength: (contentWarning) => measureText(contentWarning), | 
					
						
							|  |  |  |       length: (textLength, contentWarningLength, contentWarningShown) => { | 
					
						
							|  |  |  |         return textLength + (contentWarningShown ? contentWarningLength : 0) | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       overLimit: (length) => length > CHAR_LIMIT, | 
					
						
							| 
									
										
										
										
											2018-03-03 15:44:43 -08:00
										 |  |  |       contentWarningShown: (composeData) => composeData.contentWarningShown, | 
					
						
							| 
									
										
										
										
											2018-03-07 18:04:20 -08:00
										 |  |  |       contentWarning: (composeData) => composeData.contentWarning || '', | 
					
						
							| 
									
										
										
										
											2018-04-09 18:30:15 -07:00
										 |  |  |       timelineInitialized: ($timelineInitialized) => $timelineInitialized, | 
					
						
							|  |  |  |       mediaDescriptions: (composeData) => composeData.mediaDescriptions || [] | 
					
						
							| 
									
										
										
										
											2018-03-03 16:25:22 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     transitions: { | 
					
						
							|  |  |  |       slide | 
					
						
							| 
									
										
										
										
											2018-03-04 16:27:15 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     methods: { | 
					
						
							| 
									
										
										
										
											2018-03-27 00:02:55 -07:00
										 |  |  |       async onClickPostButton() { | 
					
						
							|  |  |  |         if (this.get('sticky')) { | 
					
						
							|  |  |  |           // when the button is sticky, we're scrolled down the home timeline, | 
					
						
							|  |  |  |           // so we should launch a new compose dialog | 
					
						
							|  |  |  |           let dialogs = await importDialogs() | 
					
						
							|  |  |  |           dialogs.showComposeDialog() | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |           // else we're actually posting a new toot | 
					
						
							| 
									
										
										
										
											2018-04-11 20:00:43 -07:00
										 |  |  |           this.doPostStatus(); | 
					
						
							| 
									
										
										
										
											2018-04-12 05:01:17 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2018-04-11 20:00:43 -07:00
										 |  |  |       doPostStatus() { | 
					
						
							| 
									
										
										
										
											2018-04-12 05:01:17 +02:00
										 |  |  |         let text = this.get('text') | 
					
						
							|  |  |  |         let media = this.get('media') | 
					
						
							|  |  |  |         let postPrivacyKey = this.get('postPrivacyKey') | 
					
						
							|  |  |  |         let contentWarning = this.get('contentWarning') | 
					
						
							|  |  |  |         let sensitive = media.length && !!contentWarning | 
					
						
							|  |  |  |         let realm = this.get('realm') | 
					
						
							|  |  |  |         let mediaIds = media.map(_ => _.data.id) | 
					
						
							|  |  |  |         let inReplyTo = (realm === 'home' || realm === 'dialog') ? null : realm | 
					
						
							|  |  |  |         let overLimit = this.get('overLimit') | 
					
						
							|  |  |  |         let mediaDescriptions = this.get('mediaDescriptions') | 
					
						
							| 
									
										
										
										
											2018-03-07 18:04:20 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-12 05:01:17 +02:00
										 |  |  |         if (!text || overLimit) { | 
					
						
							|  |  |  |           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, | 
					
						
							|  |  |  |           sensitive, contentWarning, postPrivacyKey, mediaDescriptions) | 
					
						
							| 
									
										
										
										
											2018-03-31 09:36:29 -07:00
										 |  |  |       }, | 
					
						
							|  |  |  |       setupStickyObserver() { | 
					
						
							|  |  |  |         this.__stickyObserver = new IntersectionObserver(entries => { | 
					
						
							|  |  |  |           this.set({sticky: !entries[0].isIntersecting}) | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         this.__stickyObserver.observe(this.refs.sentinel) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // also create a one-shot observer for the $timelineInitialized event, | 
					
						
							|  |  |  |         // due to a bug in Firefox where when the scrollTop is set | 
					
						
							|  |  |  |         // manually, the other observer doesn't necessarily fire | 
					
						
							|  |  |  |         this.observe('timelineInitialized', timelineInitialized => { | 
					
						
							|  |  |  |           if (timelineInitialized) { | 
					
						
							|  |  |  |             let observer = new IntersectionObserver(entries => { | 
					
						
							|  |  |  |               this.set({sticky: !entries[0].isIntersecting}) | 
					
						
							|  |  |  |               observer.disconnect() | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |             observer.observe(this.refs.sentinel) | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         }, {init: false}) | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       teardownStickyObserver() { | 
					
						
							|  |  |  |         if (this.__stickyObserver) { | 
					
						
							|  |  |  |           this.__stickyObserver.disconnect() | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											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> |