63 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
| /* eslint-disable import/prefer-default-export */
 | |
| import type { CSSObject } from '../_util/cssinjs';
 | |
| 
 | |
| export const roundedArrow = (
 | |
|   width: number,
 | |
|   innerRadius: number,
 | |
|   outerRadius: number,
 | |
|   bgColor: string,
 | |
|   boxShadow: string,
 | |
| ): CSSObject => {
 | |
|   const unitWidth = width / 2;
 | |
| 
 | |
|   const ax = unitWidth - outerRadius * (Math.sqrt(2) - 1);
 | |
|   const ay = unitWidth;
 | |
|   const bx = unitWidth + outerRadius * (1 - 1 / Math.sqrt(2));
 | |
|   const by = unitWidth - outerRadius * (1 - 1 / Math.sqrt(2));
 | |
|   const cx = 2 * unitWidth - innerRadius * (1 / Math.sqrt(2));
 | |
|   const cy = innerRadius * (1 / Math.sqrt(2));
 | |
|   const dx = 4 * unitWidth - cx;
 | |
|   const dy = cy;
 | |
|   const ex = 4 * unitWidth - bx;
 | |
|   const ey = by;
 | |
|   const fx = 4 * unitWidth - ax;
 | |
|   const fy = ay;
 | |
| 
 | |
|   return {
 | |
|     borderRadius: { _skip_check_: true, value: `0 0 ${innerRadius}px` },
 | |
|     pointerEvents: 'none',
 | |
|     width: width * 2,
 | |
|     height: width * 2,
 | |
|     overflow: 'hidden',
 | |
| 
 | |
|     '&::after': {
 | |
|       content: '""',
 | |
|       position: 'absolute',
 | |
|       width: width / Math.sqrt(2),
 | |
|       height: width / Math.sqrt(2),
 | |
|       bottom: 0,
 | |
|       insetInline: 0,
 | |
|       margin: 'auto',
 | |
|       borderRadius: {
 | |
|         _skip_check_: true,
 | |
|         value: `0 0 ${innerRadius}px 0`,
 | |
|       },
 | |
|       transform: 'translateY(50%) rotate(-135deg)',
 | |
|       boxShadow,
 | |
|       zIndex: 0,
 | |
|       background: 'transparent',
 | |
|     },
 | |
| 
 | |
|     '&::before': {
 | |
|       position: 'absolute',
 | |
|       bottom: 0,
 | |
|       insetInlineStart: 0,
 | |
|       width: width * 2,
 | |
|       height: width / 2,
 | |
|       background: bgColor,
 | |
|       clipPath: `path('M ${ax} ${ay} A ${outerRadius} ${outerRadius} 0 0 0 ${bx} ${by} L ${cx} ${cy} A ${innerRadius} ${innerRadius} 0 0 1 ${dx} ${dy} L ${ex} ${ey} A ${outerRadius} ${outerRadius} 0 0 0 ${fx} ${fy} Z')`,
 | |
|       content: '""',
 | |
|     },
 | |
|   };
 | |
| };
 |