New component library based on ALF (#2459)
* Install on native as well * Add button and link components * Comments * Use new prop * Add some form elements * Add labels to input * Fix line height, add suffix * Date inputs * Autofill styles * Clean up InputDate types * Improve types for InputText, value handling * Enforce a11y props on buttons * Add Dialog, Portal * Dialog contents * Native dialog * Clean up * Fix animations * Improvements to web modal, exiting still broken * Clean up dialog types * Add Prompt, Dialog refinement, mobile refinement * Integrate new design tokens, reorg storybook * Button colors * Dim mode * Reorg * Some styles * Toggles * Improve a11y * Autosize dialog, handle max height, Dialog.ScrolLView not working * Try to use BottomSheet's own APIs * Scrollable dialogs * Add web shadow * Handle overscroll * Styles * Dialog text input * Shadows * Button focus states * Button pressed states * Gradient poc * Gradient colors and hovers * Add hrefAttrs to Link * Some more a11y * Toggle invalid states * Update dialog descriptions for demo * Icons * WIP Toggle cleanup * Refactor toggle to not rely on immediate children * Make Toggle controlled * Clean up Toggles storybook * ToggleButton styles * Improve a11y labels * ToggleButton hover darkmode * Some i18n * Refactor input * Allow extension of input * Remove old input * Improve icons, add CalendarDays * Refactor DateField, web done * Add label example * Clean up old InputDate, DateField android, text area example * Consistent imports * Button context, icons * Add todo * Add closeAllDialogs control * Alignment * Expand color palette * Hitslops, add shortcut to Storybook in dev * Fix multiline on ios * Mark dialog close button as unused
This commit is contained in:
		
							parent
							
								
									9cbd3c0937
								
							
						
					
					
						commit
						66b8774ecb
					
				
					 60 changed files with 4683 additions and 968 deletions
				
			
		
							
								
								
									
										5
									
								
								src/components/icons/ArrowTopRight.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/components/icons/ArrowTopRight.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| import {createSinglePathSVG} from './TEMPLATE' | ||||
| 
 | ||||
| export const ArrowTopRight_Stroke2_Corner0_Rounded = createSinglePathSVG({ | ||||
|   path: 'M8 6a1 1 0 0 1 1-1h9a1 1 0 0 1 1 1v9a1 1 0 1 1-2 0V8.414l-9.793 9.793a1 1 0 0 1-1.414-1.414L15.586 7H9a1 1 0 0 1-1-1Z', | ||||
| }) | ||||
							
								
								
									
										5
									
								
								src/components/icons/CalendarDays.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/components/icons/CalendarDays.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| import {createSinglePathSVG} from './TEMPLATE' | ||||
| 
 | ||||
| export const CalendarDays_Stroke2_Corner0_Rounded = createSinglePathSVG({ | ||||
|   path: 'M4 3a1 1 0 0 0-1 1v16a1 1 0 0 0 1 1h16a1 1 0 0 0 1-1V4a1 1 0 0 0-1-1H4Zm1 16V9h14v10H5ZM5 7h14V5H5v2Zm3 10.25a1.25 1.25 0 1 0 0-2.5 1.25 1.25 0 0 0 0 2.5ZM17.25 12a1.25 1.25 0 1 1-2.5 0 1.25 1.25 0 0 1 2.5 0ZM12 13.25a1.25 1.25 0 1 0 0-2.5 1.25 1.25 0 0 0 0 2.5ZM9.25 12a1.25 1.25 0 1 1-2.5 0 1.25 1.25 0 0 1 2.5 0ZM12 17.25a1.25 1.25 0 1 0 0-2.5 1.25 1.25 0 0 0 0 2.5Z', | ||||
| }) | ||||
							
								
								
									
										5
									
								
								src/components/icons/ColorPalette.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/components/icons/ColorPalette.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| import {createSinglePathSVG} from './TEMPLATE' | ||||
| 
 | ||||
| export const ColorPalette_Stroke2_Corner0_Rounded = createSinglePathSVG({ | ||||
|   path: 'M4 12c0-4.09 3.527-7.5 8-7.5s8 3.41 8 7.5c0 1.579-.419 2.056-.708 2.236-.388.241-1.031.286-2.058.153-.33-.043-.652-.096-.991-.152a65.905 65.905 0 0 0-.531-.087c-.52-.081-1.077-.156-1.61-.164-1.065-.016-2.336.245-2.996 1.567-.418.834-.295 1.67-.078 2.314.18.534.47 1.055.683 1.437v.001l.097.175.01.018C7.432 19.407 4 16.033 4 12Zm8-9.5C6.532 2.5 2 6.7 2 12s4.532 9.5 10 9.5c.401 0 .812-.04 1.166-.193.41-.176.761-.517.866-1.028.085-.416-.03-.796-.118-1.029a5.981 5.981 0 0 0-.351-.73l-.12-.215c-.215-.392-.403-.73-.52-1.078-.13-.387-.111-.614-.029-.78.146-.291.404-.473 1.178-.461.385.005.825.06 1.329.14.15.023.308.05.47.077.36.059.742.122 1.105.17 1.021.132 2.325.213 3.373-.439C21.496 15.22 22 13.874 22 12c0-5.3-4.532-9.5-10-9.5Zm3.5 8.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM9 12.25a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0Zm1.5-2.75a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z', | ||||
| }) | ||||
							
								
								
									
										5
									
								
								src/components/icons/Globe.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/components/icons/Globe.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| import {createSinglePathSVG} from './TEMPLATE' | ||||
| 
 | ||||
| export const Globe_Stroke2_Corner0_Rounded = createSinglePathSVG({ | ||||
|   path: 'M4.062 11h2.961c.103-2.204.545-4.218 1.235-5.77.06-.136.123-.269.188-.399A8.007 8.007 0 0 0 4.062 11ZM12 2C6.477 2 2 6.477 2 12s4.477 10 10 10 10-4.477 10-10S17.523 2 12 2Zm0 2c-.227 0-.518.1-.868.432-.354.337-.719.872-1.047 1.61-.561 1.263-.958 2.991-1.06 4.958h5.95c-.102-1.967-.499-3.695-1.06-4.958-.328-.738-.693-1.273-1.047-1.61C12.518 4.099 12.227 4 12 4Zm4.977 7c-.103-2.204-.545-4.218-1.235-5.77a9.78 9.78 0 0 0-.188-.399A8.006 8.006 0 0 1 19.938 11h-2.961Zm-2.003 2H9.026c.101 1.966.498 3.695 1.06 4.958.327.738.692 1.273 1.046 1.61.35.333.641.432.868.432.227 0 .518-.1.868-.432.354-.337.719-.872 1.047-1.61.561-1.263.958-2.991 1.06-4.958Zm.58 6.169c.065-.13.128-.263.188-.399.69-1.552 1.132-3.566 1.235-5.77h2.961a8.006 8.006 0 0 1-4.384 6.169Zm-7.108 0a9.877 9.877 0 0 1-.188-.399c-.69-1.552-1.132-3.566-1.235-5.77H4.062a8.006 8.006 0 0 0 4.384 6.169Z', | ||||
| }) | ||||
							
								
								
									
										48
									
								
								src/components/icons/TEMPLATE.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								src/components/icons/TEMPLATE.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,48 @@ | |||
| import React from 'react' | ||||
| import Svg, {Path} from 'react-native-svg' | ||||
| 
 | ||||
| import {useCommonSVGProps, Props} from '#/components/icons/common' | ||||
| 
 | ||||
| export const IconTemplate_Stroke2_Corner0_Rounded = React.forwardRef( | ||||
|   function LogoImpl(props: Props, ref) { | ||||
|     const {fill, size, style, ...rest} = useCommonSVGProps(props) | ||||
| 
 | ||||
|     return ( | ||||
|       <Svg | ||||
|         fill="none" | ||||
|         {...rest} | ||||
|         // @ts-ignore it's fiiiiine
 | ||||
|         ref={ref} | ||||
|         viewBox="0 0 24 24" | ||||
|         width={size} | ||||
|         height={size} | ||||
|         style={[style]}> | ||||
|         <Path | ||||
|           fill={fill} | ||||
|           fillRule="evenodd" | ||||
|           clipRule="evenodd" | ||||
|           d="M4.062 11h2.961c.103-2.204.545-4.218 1.235-5.77.06-.136.123-.269.188-.399A8.007 8.007 0 0 0 4.062 11ZM12 2C6.477 2 2 6.477 2 12s4.477 10 10 10 10-4.477 10-10S17.523 2 12 2Zm0 2c-.227 0-.518.1-.868.432-.354.337-.719.872-1.047 1.61-.561 1.263-.958 2.991-1.06 4.958h5.95c-.102-1.967-.499-3.695-1.06-4.958-.328-.738-.693-1.273-1.047-1.61C12.518 4.099 12.227 4 12 4Zm4.977 7c-.103-2.204-.545-4.218-1.235-5.77a9.78 9.78 0 0 0-.188-.399A8.006 8.006 0 0 1 19.938 11h-2.961Zm-2.003 2H9.026c.101 1.966.498 3.695 1.06 4.958.327.738.692 1.273 1.046 1.61.35.333.641.432.868.432.227 0 .518-.1.868-.432.354-.337.719-.872 1.047-1.61.561-1.263.958-2.991 1.06-4.958Zm.58 6.169c.065-.13.128-.263.188-.399.69-1.552 1.132-3.566 1.235-5.77h2.961a8.006 8.006 0 0 1-4.384 6.169Zm-7.108 0a9.877 9.877 0 0 1-.188-.399c-.69-1.552-1.132-3.566-1.235-5.77H4.062a8.006 8.006 0 0 0 4.384 6.169Z" | ||||
|         /> | ||||
|       </Svg> | ||||
|     ) | ||||
|   }, | ||||
| ) | ||||
| 
 | ||||
| export function createSinglePathSVG({path}: {path: string}) { | ||||
|   return React.forwardRef<Svg, Props>(function LogoImpl(props, ref) { | ||||
|     const {fill, size, style, ...rest} = useCommonSVGProps(props) | ||||
| 
 | ||||
|     return ( | ||||
|       <Svg | ||||
|         fill="none" | ||||
|         {...rest} | ||||
|         ref={ref} | ||||
|         viewBox="0 0 24 24" | ||||
|         width={size} | ||||
|         height={size} | ||||
|         style={[style]}> | ||||
|         <Path fill={fill} fillRule="evenodd" clipRule="evenodd" d={path} /> | ||||
|       </Svg> | ||||
|     ) | ||||
|   }) | ||||
| } | ||||
							
								
								
									
										32
									
								
								src/components/icons/common.ts
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/components/icons/common.ts
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,32 @@ | |||
| import {StyleSheet, TextProps} from 'react-native' | ||||
| import type {SvgProps, PathProps} from 'react-native-svg' | ||||
| 
 | ||||
| import {tokens} from '#/alf' | ||||
| 
 | ||||
| export type Props = { | ||||
|   fill?: PathProps['fill'] | ||||
|   style?: TextProps['style'] | ||||
|   size?: keyof typeof sizes | ||||
| } & Omit<SvgProps, 'style' | 'size'> | ||||
| 
 | ||||
| export const sizes = { | ||||
|   xs: 12, | ||||
|   sm: 16, | ||||
|   md: 20, | ||||
|   lg: 24, | ||||
|   xl: 28, | ||||
| } | ||||
| 
 | ||||
| export function useCommonSVGProps(props: Props) { | ||||
|   const {fill, size, ...rest} = props | ||||
|   const style = StyleSheet.flatten(rest.style) | ||||
|   const _fill = fill || style?.color || tokens.color.blue_500 | ||||
|   const _size = Number(size ? sizes[size] : rest.width || sizes.md) | ||||
| 
 | ||||
|   return { | ||||
|     fill: _fill, | ||||
|     size: _size, | ||||
|     style, | ||||
|     ...rest, | ||||
|   } | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue