@os-design/core 1.0.228 → 1.0.230

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (176) hide show
  1. package/dist/cjs/Alert/index.js +2 -2
  2. package/dist/cjs/Alert/index.js.map +1 -1
  3. package/dist/cjs/Avatar/index.js +2 -2
  4. package/dist/cjs/Avatar/index.js.map +1 -1
  5. package/dist/cjs/AvatarSkeleton/index.js +2 -2
  6. package/dist/cjs/AvatarSkeleton/index.js.map +1 -1
  7. package/dist/cjs/Breadcrumb/index.js +2 -2
  8. package/dist/cjs/Breadcrumb/index.js.map +1 -1
  9. package/dist/cjs/BreadcrumbItem/index.js +2 -2
  10. package/dist/cjs/BreadcrumbItem/index.js.map +1 -1
  11. package/dist/cjs/Button/ButtonContent.js +1 -1
  12. package/dist/cjs/Button/ButtonContent.js.map +1 -1
  13. package/dist/cjs/Button/index.js +4 -4
  14. package/dist/cjs/Button/index.js.map +1 -1
  15. package/dist/cjs/Button/utils/useButtonColors.js +1 -1
  16. package/dist/cjs/Button/utils/useButtonColors.js.map +1 -1
  17. package/dist/cjs/ButtonLink/index.js +89 -0
  18. package/dist/cjs/ButtonLink/index.js.map +1 -0
  19. package/dist/cjs/Checkbox/index.js +2 -2
  20. package/dist/cjs/Checkbox/index.js.map +1 -1
  21. package/dist/cjs/CheckboxSkeleton/index.js +2 -2
  22. package/dist/cjs/CheckboxSkeleton/index.js.map +1 -1
  23. package/dist/cjs/DatePicker/DatePickerCalendar.js +2 -2
  24. package/dist/cjs/DatePicker/DatePickerCalendar.js.map +1 -1
  25. package/dist/cjs/DatePicker/index.js +2 -2
  26. package/dist/cjs/DatePicker/index.js.map +1 -1
  27. package/dist/cjs/Drawer/index.js +2 -2
  28. package/dist/cjs/Drawer/index.js.map +1 -1
  29. package/dist/cjs/Form/index.js +2 -2
  30. package/dist/cjs/Form/index.js.map +1 -1
  31. package/dist/cjs/FormDivider/index.js +2 -2
  32. package/dist/cjs/FormDivider/index.js.map +1 -1
  33. package/dist/cjs/FormItem/index.js +2 -2
  34. package/dist/cjs/FormItem/index.js.map +1 -1
  35. package/dist/cjs/Gallery/index.js +2 -2
  36. package/dist/cjs/Gallery/index.js.map +1 -1
  37. package/dist/cjs/HeaderSkeleton/index.js +2 -2
  38. package/dist/cjs/HeaderSkeleton/index.js.map +1 -1
  39. package/dist/cjs/Image/index.js +2 -2
  40. package/dist/cjs/Image/index.js.map +1 -1
  41. package/dist/cjs/ImageSkeleton/index.js +2 -2
  42. package/dist/cjs/ImageSkeleton/index.js.map +1 -1
  43. package/dist/cjs/Input/index.js +2 -2
  44. package/dist/cjs/Input/index.js.map +1 -1
  45. package/dist/cjs/InputNumber/index.js +2 -2
  46. package/dist/cjs/InputNumber/index.js.map +1 -1
  47. package/dist/cjs/InputPassword/index.js +2 -2
  48. package/dist/cjs/InputPassword/index.js.map +1 -1
  49. package/dist/cjs/InputSearch/index.js +2 -2
  50. package/dist/cjs/InputSearch/index.js.map +1 -1
  51. package/dist/cjs/InputSkeleton/index.js +2 -2
  52. package/dist/cjs/InputSkeleton/index.js.map +1 -1
  53. package/dist/cjs/Layout/index.js +2 -2
  54. package/dist/cjs/Layout/index.js.map +1 -1
  55. package/dist/cjs/Link/index.js +5 -16
  56. package/dist/cjs/Link/index.js.map +1 -1
  57. package/dist/cjs/LinkButton/index.js +19 -60
  58. package/dist/cjs/LinkButton/index.js.map +1 -1
  59. package/dist/cjs/List/WindowScroller.js +2 -2
  60. package/dist/cjs/List/WindowScroller.js.map +1 -1
  61. package/dist/cjs/List/index.js +2 -2
  62. package/dist/cjs/List/index.js.map +1 -1
  63. package/dist/cjs/ListItem/index.js +2 -2
  64. package/dist/cjs/ListItem/index.js.map +1 -1
  65. package/dist/cjs/ListItemActions/index.js +2 -2
  66. package/dist/cjs/ListItemActions/index.js.map +1 -1
  67. package/dist/cjs/ListItemLink/index.js +2 -2
  68. package/dist/cjs/ListItemLink/index.js.map +1 -1
  69. package/dist/cjs/ListSkeleton/index.js +2 -2
  70. package/dist/cjs/ListSkeleton/index.js.map +1 -1
  71. package/dist/cjs/LogoLink/index.js +2 -2
  72. package/dist/cjs/LogoLink/index.js.map +1 -1
  73. package/dist/cjs/Menu/index.js +2 -2
  74. package/dist/cjs/Menu/index.js.map +1 -1
  75. package/dist/cjs/MenuDivider/index.js +2 -2
  76. package/dist/cjs/MenuDivider/index.js.map +1 -1
  77. package/dist/cjs/MenuGroup/index.js +2 -2
  78. package/dist/cjs/MenuGroup/index.js.map +1 -1
  79. package/dist/cjs/MenuItem/index.js +2 -2
  80. package/dist/cjs/MenuItem/index.js.map +1 -1
  81. package/dist/cjs/Modal/index.js +2 -2
  82. package/dist/cjs/Modal/index.js.map +1 -1
  83. package/dist/cjs/Navigation/index.js +2 -2
  84. package/dist/cjs/Navigation/index.js.map +1 -1
  85. package/dist/cjs/NavigationItem/index.js +2 -2
  86. package/dist/cjs/NavigationItem/index.js.map +1 -1
  87. package/dist/cjs/PageContent/index.js +2 -2
  88. package/dist/cjs/PageContent/index.js.map +1 -1
  89. package/dist/cjs/PageHeader/index.js +2 -2
  90. package/dist/cjs/PageHeader/index.js.map +1 -1
  91. package/dist/cjs/PageHeaderInputSearch/index.js +2 -2
  92. package/dist/cjs/PageHeaderInputSearch/index.js.map +1 -1
  93. package/dist/cjs/PageHeaderSkeleton/index.js +2 -2
  94. package/dist/cjs/PageHeaderSkeleton/index.js.map +1 -1
  95. package/dist/cjs/ParagraphSkeleton/index.js +2 -2
  96. package/dist/cjs/ParagraphSkeleton/index.js.map +1 -1
  97. package/dist/cjs/Popover/index.js +2 -2
  98. package/dist/cjs/Popover/index.js.map +1 -1
  99. package/dist/cjs/Progress/index.js +2 -2
  100. package/dist/cjs/Progress/index.js.map +1 -1
  101. package/dist/cjs/RadioGroup/index.js +2 -2
  102. package/dist/cjs/RadioGroup/index.js.map +1 -1
  103. package/dist/cjs/RadioGroupSkeleton/index.js +2 -2
  104. package/dist/cjs/RadioGroupSkeleton/index.js.map +1 -1
  105. package/dist/cjs/Result/index.js +2 -2
  106. package/dist/cjs/Result/index.js.map +1 -1
  107. package/dist/cjs/ScrollButton/index.js +2 -2
  108. package/dist/cjs/ScrollButton/index.js.map +1 -1
  109. package/dist/cjs/Select/index.js +9 -4
  110. package/dist/cjs/Select/index.js.map +1 -1
  111. package/dist/cjs/Skeleton/index.js +2 -2
  112. package/dist/cjs/Skeleton/index.js.map +1 -1
  113. package/dist/cjs/Switch/index.js +2 -2
  114. package/dist/cjs/Switch/index.js.map +1 -1
  115. package/dist/cjs/SwitchSkeleton/index.js +2 -2
  116. package/dist/cjs/SwitchSkeleton/index.js.map +1 -1
  117. package/dist/cjs/Tag/index.js +2 -2
  118. package/dist/cjs/Tag/index.js.map +1 -1
  119. package/dist/cjs/TagLink/index.js +2 -2
  120. package/dist/cjs/TagLink/index.js.map +1 -1
  121. package/dist/cjs/TagList/index.js +2 -2
  122. package/dist/cjs/TagList/index.js.map +1 -1
  123. package/dist/cjs/TagListSkeleton/index.js +2 -2
  124. package/dist/cjs/TagListSkeleton/index.js.map +1 -1
  125. package/dist/cjs/TagSkeleton/index.js +2 -2
  126. package/dist/cjs/TagSkeleton/index.js.map +1 -1
  127. package/dist/cjs/TextArea/index.js +2 -2
  128. package/dist/cjs/TextArea/index.js.map +1 -1
  129. package/dist/cjs/TextAreaSkeleton/index.js +2 -2
  130. package/dist/cjs/TextAreaSkeleton/index.js.map +1 -1
  131. package/dist/cjs/ThemeSwitcher/index.js +2 -2
  132. package/dist/cjs/ThemeSwitcher/index.js.map +1 -1
  133. package/dist/cjs/TimePicker/index.js +2 -2
  134. package/dist/cjs/TimePicker/index.js.map +1 -1
  135. package/dist/cjs/Video/index.js +2 -2
  136. package/dist/cjs/Video/index.js.map +1 -1
  137. package/dist/cjs/index.js +21 -2
  138. package/dist/cjs/index.js.map +1 -1
  139. package/dist/cjs/message/Message.js +2 -2
  140. package/dist/cjs/message/Message.js.map +1 -1
  141. package/dist/cjs/message/index.js +2 -2
  142. package/dist/cjs/message/index.js.map +1 -1
  143. package/dist/esm/Button/ButtonContent.js +1 -1
  144. package/dist/esm/Button/ButtonContent.js.map +1 -1
  145. package/dist/esm/Button/index.js +2 -2
  146. package/dist/esm/Button/index.js.map +1 -1
  147. package/dist/esm/Button/utils/useButtonColors.js +1 -1
  148. package/dist/esm/Button/utils/useButtonColors.js.map +1 -1
  149. package/dist/esm/ButtonLink/index.js +73 -0
  150. package/dist/esm/ButtonLink/index.js.map +1 -0
  151. package/dist/esm/Link/index.js +2 -13
  152. package/dist/esm/Link/index.js.map +1 -1
  153. package/dist/esm/LinkButton/index.js +25 -59
  154. package/dist/esm/LinkButton/index.js.map +1 -1
  155. package/dist/esm/Select/index.js +7 -2
  156. package/dist/esm/Select/index.js.map +1 -1
  157. package/dist/esm/index.js +2 -0
  158. package/dist/esm/index.js.map +1 -1
  159. package/dist/types/ButtonLink/index.d.ts +286 -0
  160. package/dist/types/ButtonLink/index.d.ts.map +1 -0
  161. package/dist/types/Link/index.d.ts +2 -0
  162. package/dist/types/Link/index.d.ts.map +1 -1
  163. package/dist/types/LinkButton/index.d.ts +6 -283
  164. package/dist/types/LinkButton/index.d.ts.map +1 -1
  165. package/dist/types/Select/index.d.ts.map +1 -1
  166. package/dist/types/index.d.ts +2 -0
  167. package/dist/types/index.d.ts.map +1 -1
  168. package/package.json +8 -8
  169. package/src/Button/ButtonContent.tsx +1 -1
  170. package/src/Button/index.tsx +2 -2
  171. package/src/Button/utils/useButtonColors.ts +1 -1
  172. package/src/ButtonLink/index.tsx +96 -0
  173. package/src/Link/index.tsx +2 -11
  174. package/src/LinkButton/index.tsx +38 -81
  175. package/src/Select/index.tsx +7 -2
  176. package/src/index.ts +2 -0
@@ -1,94 +1,51 @@
1
- import { css } from '@emotion/react';
2
1
  import styled from '@emotion/styled';
2
+ import { resetButtonStyles, sizeStyles, WithSize } from '@os-design/styles';
3
+ import { clr } from '@os-design/theming';
3
4
  import { omitEmotionProps } from '@os-design/utils';
4
5
  import React, { forwardRef } from 'react';
5
- import { ButtonProps, StyledButton } from '../Button';
6
- import ButtonContent from '../Button/ButtonContent';
7
- import useButtonColors from '../Button/utils/useButtonColors';
8
- import { LinkProps, ReactRouterLinkProps } from '../Link';
6
+ import { underlineAlwaysStyles, underlineHoverStyles } from '../Link';
9
7
 
10
- type JsxAProps = Omit<JSX.IntrinsicElements['a'], 'type' | 'ref'>;
11
- export type LinkButtonProps = JsxAProps &
12
- ReactRouterLinkProps &
13
- Pick<LinkProps, 'as'> &
14
- ButtonProps;
8
+ type JsxButtonProps = Omit<JSX.IntrinsicElements['button'], 'ref'>;
15
9
 
16
- const disabledStyles = (p) =>
17
- p.disabled &&
18
- css`
19
- pointer-events: none;
20
- `;
10
+ export interface LinkButtonProps extends JsxButtonProps, WithSize {
11
+ /**
12
+ * Type of the underline styles.
13
+ * @default hover
14
+ */
15
+ underline?: 'hover' | 'always' | 'never';
16
+ }
21
17
 
22
- const StyledLinkButton = styled(
23
- StyledButton.withComponent('a'),
24
- omitEmotionProps('as', 'disabled')
25
- )`
26
- text-decoration: none;
27
- display: inline-flex;
28
- ${disabledStyles};
18
+ const StyledButton = styled(
19
+ 'button',
20
+ omitEmotionProps('size', 'underline')
21
+ )<LinkButtonProps>`
22
+ ${resetButtonStyles};
23
+
24
+ cursor: pointer;
25
+ text-align: left;
26
+ line-height: 1.2;
27
+ color: ${(p) => clr(p.theme.linkColor)};
28
+
29
+ ${underlineHoverStyles};
30
+ ${underlineAlwaysStyles};
31
+ ${sizeStyles};
29
32
  `;
30
33
 
31
34
  /**
32
- * The button that is rendered as the a tag.
35
+ * The link component that is rendered as a button.
33
36
  */
34
- const LinkButton = forwardRef<HTMLAnchorElement, LinkButtonProps>(
35
- (
36
- {
37
- type = 'primary',
38
- danger = false,
39
- left,
40
- right,
41
- wide = 'default',
42
- loading = false,
43
- disabled = false,
44
- size,
45
- as,
46
- onMouseDown = () => {},
47
- onKeyDown = () => {},
48
- children,
49
- ...rest
50
- },
51
- ref
52
- ) => {
53
- const { buttonColors, loadingColors } = useButtonColors({
54
- type,
55
- danger,
56
- disabled,
57
- });
58
-
59
- return (
60
- <StyledLinkButton
61
- btnType={type}
62
- colors={buttonColors}
63
- wide={wide}
64
- loading={loading}
65
- disabled={disabled || loading}
66
- size={size}
67
- as={as}
68
- onMouseDown={(e) => {
69
- onMouseDown(e);
70
- e.preventDefault();
71
- }}
72
- onKeyDown={(e) => {
73
- onKeyDown(e);
74
- if (disabled || loading) e.preventDefault();
75
- }}
76
- aria-disabled={disabled || loading}
77
- aria-busy={loading}
78
- {...rest}
79
- ref={ref}
80
- >
81
- <ButtonContent
82
- left={left}
83
- right={right}
84
- loading={loading}
85
- loadingColors={loadingColors}
86
- >
87
- {children}
88
- </ButtonContent>
89
- </StyledLinkButton>
90
- );
91
- }
37
+ const LinkButton = forwardRef<HTMLButtonElement, LinkButtonProps>(
38
+ ({ underline = 'hover', onMouseDown = () => {}, ...rest }, ref) => (
39
+ <StyledButton
40
+ underline={underline}
41
+ onMouseDown={(e) => {
42
+ onMouseDown(e);
43
+ e.preventDefault();
44
+ }}
45
+ {...rest}
46
+ ref={ref}
47
+ />
48
+ )
92
49
  );
93
50
 
94
51
  LinkButton.displayName = 'LinkButton';
@@ -331,7 +331,7 @@ export const Placeholder = styled.span`
331
331
  ${ellipsisStyles};
332
332
  `;
333
333
 
334
- const titleUnborderedTitleStyles = (p) =>
334
+ const titleUnborderedStyles = (p) =>
335
335
  p.unbordered &&
336
336
  css`
337
337
  font-weight: 500;
@@ -350,7 +350,7 @@ export const Title = styled(
350
350
  omitEmotionProps('disabled', 'unbordered')
351
351
  )<TitleProps>`
352
352
  color: ${(p) => clr(p.theme.colorText)};
353
- ${titleUnborderedTitleStyles};
353
+ ${titleUnborderedStyles};
354
354
  ${titleDisabledStyles};
355
355
  ${ellipsisStyles};
356
356
  `;
@@ -517,7 +517,12 @@ const Select = forwardRef<HTMLDivElement, SelectProps>(
517
517
  onCloseRef.current = onClose;
518
518
  }, [onClose]);
519
519
 
520
+ const initRef = useRef(false);
520
521
  useEffect(() => {
522
+ if (!initRef.current) {
523
+ initRef.current = true;
524
+ return;
525
+ }
521
526
  if (!opened) onCloseRef.current();
522
527
  }, [opened]);
523
528
 
package/src/index.ts CHANGED
@@ -4,6 +4,7 @@ export { default as AvatarSkeleton } from './AvatarSkeleton';
4
4
  export { default as Breadcrumb } from './Breadcrumb';
5
5
  export { default as BreadcrumbItem } from './BreadcrumbItem';
6
6
  export { default as Button } from './Button';
7
+ export { default as ButtonLink } from './ButtonLink';
7
8
  export { default as Checkbox } from './Checkbox';
8
9
  export { default as CheckboxSkeleton } from './CheckboxSkeleton';
9
10
  export { default as DatePicker } from './DatePicker';
@@ -68,6 +69,7 @@ export * from './AvatarSkeleton';
68
69
  export * from './Breadcrumb';
69
70
  export * from './BreadcrumbItem';
70
71
  export * from './Button';
72
+ export * from './ButtonLink';
71
73
  export * from './Checkbox';
72
74
  export * from './CheckboxSkeleton';
73
75
  export * from './DatePicker';