You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					39 lines
				
				767 B
			
		
		
			
		
	
	
					39 lines
				
				767 B
			| 
								 
											3 years ago
										 
									 | 
							
								// @flow
							 | 
						||
| 
								 | 
							
								import type { Styles } from '../types/style'
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * CSS to represent truncated text with an ellipsis.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @example
							 | 
						||
| 
								 | 
							
								 * // Styles as object usage
							 | 
						||
| 
								 | 
							
								 * const styles = {
							 | 
						||
| 
								 | 
							
								 *   ...ellipsis('250px')
							 | 
						||
| 
								 | 
							
								 * }
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * // styled-components usage
							 | 
						||
| 
								 | 
							
								 * const div = styled.div`
							 | 
						||
| 
								 | 
							
								 *   ${ellipsis('250px')}
							 | 
						||
| 
								 | 
							
								 * `
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * // CSS as JS Output
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * div: {
							 | 
						||
| 
								 | 
							
								 *   'display': 'inline-block',
							 | 
						||
| 
								 | 
							
								 *   'maxWidth': '250px',
							 | 
						||
| 
								 | 
							
								 *   'overflow': 'hidden',
							 | 
						||
| 
								 | 
							
								 *   'textOverflow': 'ellipsis',
							 | 
						||
| 
								 | 
							
								 *   'whiteSpace': 'nowrap',
							 | 
						||
| 
								 | 
							
								 *   'wordWrap': 'normal'
							 | 
						||
| 
								 | 
							
								 * }
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								export default function ellipsis(width?: string | number = '100%'): Styles {
							 | 
						||
| 
								 | 
							
								  return {
							 | 
						||
| 
								 | 
							
								    display: 'inline-block',
							 | 
						||
| 
								 | 
							
								    maxWidth: width,
							 | 
						||
| 
								 | 
							
								    overflow: 'hidden',
							 | 
						||
| 
								 | 
							
								    textOverflow: 'ellipsis',
							 | 
						||
| 
								 | 
							
								    whiteSpace: 'nowrap',
							 | 
						||
| 
								 | 
							
								    wordWrap: 'normal',
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								}
							 |