Allow for template inside Timeago component that shows unless the time string is 'just now'
This commit is contained in:
		
							parent
							
								
									b70d50407c
								
							
						
					
					
						commit
						04e62df377
					
				
					 2 changed files with 25 additions and 19 deletions
				
			
		|  | @ -336,16 +336,12 @@ | |||
|                 tag="span" | ||||
|               > | ||||
|                 <template #time> | ||||
|                   <i18n-t | ||||
|                     keypath="time.in_past" | ||||
|                     tag="span" | ||||
|                   > | ||||
|                     <Timeago | ||||
|                       :time="status.edited_at" | ||||
|                       :auto-update="60" | ||||
|                       :long-format="true" | ||||
|                     /> | ||||
|                   </i18n-t> | ||||
|                   <Timeago | ||||
|                     template-key="time.in_past" | ||||
|                     :time="status.edited_at" | ||||
|                     :auto-update="60" | ||||
|                     :long-format="true" | ||||
|                   /> | ||||
|                 </template> | ||||
|               </i18n-t> | ||||
|             </div> | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ | |||
|     :datetime="time" | ||||
|     :title="localeDateString" | ||||
|   > | ||||
|     {{ $tc(relativeTime.key, relativeTime.num, [relativeTime.num]) }} | ||||
|     {{ relativeTimeString }} | ||||
|   </time> | ||||
| </template> | ||||
| 
 | ||||
|  | @ -13,7 +13,7 @@ import localeService from 'src/services/locale/locale.service.js' | |||
| 
 | ||||
| export default { | ||||
|   name: 'Timeago', | ||||
|   props: ['time', 'autoUpdate', 'longFormat', 'nowThreshold'], | ||||
|   props: ['time', 'autoUpdate', 'longFormat', 'nowThreshold', 'templateKey'], | ||||
|   data () { | ||||
|     return { | ||||
|       relativeTime: { key: 'time.now', num: 0 }, | ||||
|  | @ -26,6 +26,23 @@ export default { | |||
|       return typeof this.time === 'string' | ||||
|         ? new Date(Date.parse(this.time)).toLocaleString(browserLocale) | ||||
|         : this.time.toLocaleString(browserLocale) | ||||
|     }, | ||||
|     relativeTimeString () { | ||||
|       const timeString = this.$i18n.tc(this.relativeTime.key, this.relativeTime.num, [this.relativeTime.num]) | ||||
| 
 | ||||
|       if (typeof this.templateKey === 'string' && this.relativeTime.key !== 'time.now') { | ||||
|         return this.$i18n.t(this.templateKey, [timeString]) | ||||
|       } | ||||
| 
 | ||||
|       return timeString | ||||
|     } | ||||
|   }, | ||||
|   watch: { | ||||
|     time (newVal, oldVal) { | ||||
|       if (oldVal !== newVal) { | ||||
|         clearTimeout(this.interval) | ||||
|         this.refreshRelativeTimeObject() | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   created () { | ||||
|  | @ -34,13 +51,6 @@ export default { | |||
|   unmounted () { | ||||
|     clearTimeout(this.interval) | ||||
|   }, | ||||
|   watch: { | ||||
|     time (newVal, oldVal) { | ||||
|       if (oldVal !== newVal) { | ||||
|         this.refreshRelativeTimeObject() | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   methods: { | ||||
|     refreshRelativeTimeObject () { | ||||
|       const nowThreshold = typeof this.nowThreshold === 'number' ? this.nowThreshold : 1 | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Sean King
						Sean King