mirror of
				https://github.com/vector-im/element-web.git
				synced 2025-10-25 14:21:45 +02:00 
			
		
		
		
	Date refinements. Show more detailed timestamps for older messages, and try to show a separator as the first message in every room
This commit is contained in:
		
							parent
							
								
									530b077a8e
								
							
						
					
					
						commit
						d1cda75c8b
					
				| @ -398,6 +398,13 @@ module.exports = { | ||||
|                     continuation = false; | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
|             if (i === 1) { // n.b. 1, not 0, as the 0th event is an m.room.create and so doesn't show on the timeline
 | ||||
|                 var ts1 = this.state.room.timeline[i].getTs(); | ||||
|                 dateSeparator = <DateSeparator key={ts1} ts={ts1}/>; | ||||
|                 continuation = false; | ||||
|             } | ||||
| 
 | ||||
|             if (!TileType) continue; | ||||
|             ret.unshift( | ||||
|                 <li key={mxEv.getId()}><TileType mxEvent={mxEv} continuation={continuation} last={last}/></li> | ||||
|  | ||||
| @ -20,6 +20,9 @@ var React = require('react'); | ||||
| 
 | ||||
| var MessageTimestampController = require('matrix-react-sdk/lib/controllers/atoms/MessageTimestamp') | ||||
| 
 | ||||
| var days = ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"]; | ||||
| var months = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]; | ||||
| 
 | ||||
| module.exports = React.createClass({ | ||||
|     displayName: 'MessageTimestamp', | ||||
|     mixins: [MessageTimestampController], | ||||
| @ -30,7 +33,20 @@ module.exports = React.createClass({ | ||||
|         function pad(n) { | ||||
|             return (n < 10 ? '0' : '') + n; | ||||
|         } | ||||
|         return pad(date.getHours()) + ':' + pad(date.getMinutes()); | ||||
| 
 | ||||
|         var now = new Date(); | ||||
|         if (date.toDateString() === now.toDateString()) { | ||||
|             return pad(date.getHours()) + ':' + pad(date.getMinutes()); | ||||
|         } | ||||
|         else if (now.getTime() - date.getTime() < 6 * 24 * 60 * 60 * 1000) { | ||||
|             return days[date.getDay()] + " " + pad(date.getHours()) + ':' + pad(date.getMinutes()); | ||||
|         } | ||||
|         else if (now.getFullYear() === date.getFullYear()) { | ||||
|             return days[date.getDay()] + ", " + months[date.getMonth()] + " " + (date.getDay()+1) + " " + pad(date.getHours()) + ':' + pad(date.getMinutes()); | ||||
|         } | ||||
|         else { | ||||
|             return days[date.getDay()] + ", " + months[date.getMonth()] + " " + (date.getDay()+1) + " " + date().getFullYear() + " " + pad(date.getHours()) + ':' + pad(date.getMinutes()); | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     render: function() { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user