@opengovsg/oui 0.0.27 → 0.0.29

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 (129) hide show
  1. package/dist/cjs/badge/badge.cjs +4 -4
  2. package/dist/cjs/badge/use-badge.cjs +6 -6
  3. package/dist/cjs/banner/banner.cjs +3 -3
  4. package/dist/cjs/button/button.cjs +3 -3
  5. package/dist/cjs/calendar/calendar-bottom-content.cjs +3 -3
  6. package/dist/cjs/calendar/calendar-header.cjs +2 -2
  7. package/dist/cjs/calendar/calendar-month-day-selector.cjs +2 -2
  8. package/dist/cjs/calendar/calendar.cjs +4 -4
  9. package/dist/cjs/calendar/hooks/use-calendar-selectors.cjs +4 -4
  10. package/dist/cjs/calendar/utils.cjs +3 -3
  11. package/dist/cjs/combo-box/combo-box-fuzzy.cjs +6 -6
  12. package/dist/cjs/combo-box/combo-box-item.cjs +2 -2
  13. package/dist/cjs/combo-box/combo-box.cjs +3 -3
  14. package/dist/cjs/date-field/date-field.cjs +3 -3
  15. package/dist/cjs/date-picker/date-picker.cjs +2 -2
  16. package/dist/cjs/date-range-picker/date-range-picker.cjs +3 -3
  17. package/dist/cjs/field/field.cjs +2 -2
  18. package/dist/cjs/file-dropzone/file-dropzone.cjs +10 -10
  19. package/dist/cjs/file-dropzone/file-info.cjs +3 -3
  20. package/dist/cjs/govt-banner/govt-banner.cjs +3 -3
  21. package/dist/cjs/hooks/use-callback-ref.cjs +4 -4
  22. package/dist/cjs/hooks/use-controllable-state.cjs +2 -2
  23. package/dist/cjs/hooks/use-draggable.cjs +8 -8
  24. package/dist/cjs/index.cjs +30 -11
  25. package/dist/cjs/input/input.cjs +2 -2
  26. package/dist/cjs/menu/menu.cjs +7 -7
  27. package/dist/cjs/modal/modal-body.cjs +2 -2
  28. package/dist/cjs/modal/modal-content.cjs +3 -3
  29. package/dist/cjs/modal/modal-footer.cjs +2 -2
  30. package/dist/cjs/modal/modal-header.cjs +2 -2
  31. package/dist/cjs/modal/modal.cjs +3 -3
  32. package/dist/cjs/navbar/index.cjs +25 -0
  33. package/dist/cjs/navbar/navbar-brand.cjs +28 -0
  34. package/dist/cjs/navbar/navbar-content.cjs +33 -0
  35. package/dist/cjs/navbar/navbar-context.cjs +14 -0
  36. package/dist/cjs/navbar/navbar-item.cjs +29 -0
  37. package/dist/cjs/navbar/navbar-menu/i18n.cjs +23 -0
  38. package/dist/cjs/navbar/navbar-menu/item.cjs +44 -0
  39. package/dist/cjs/navbar/navbar-menu/menu.cjs +62 -0
  40. package/dist/cjs/navbar/navbar-menu/toggle.cjs +94 -0
  41. package/dist/cjs/navbar/navbar.cjs +26 -0
  42. package/dist/cjs/navbar/use-navbar.cjs +116 -0
  43. package/dist/cjs/node_modules/.pnpm/@react-aria_overlays@3.30.0_react-dom@19.2.3_react@19.2.3__react@19.2.3/node_modules/@react-aria/overlays/dist/Overlay.cjs +55 -0
  44. package/dist/cjs/node_modules/.pnpm/@react-aria_overlays@3.30.0_react-dom@19.2.3_react@19.2.3__react@19.2.3/node_modules/@react-aria/overlays/dist/PortalProvider.cjs +23 -0
  45. package/dist/cjs/node_modules/.pnpm/@react-aria_overlays@3.30.0_react-dom@19.2.3_react@19.2.3__react@19.2.3/node_modules/@react-aria/overlays/dist/usePreventScroll.cjs +208 -0
  46. package/dist/cjs/node_modules/.pnpm/@react-aria_ssr@3.9.10_react@19.2.3/node_modules/@react-aria/ssr/dist/SSRProvider.cjs +104 -0
  47. package/dist/cjs/node_modules/.pnpm/lucide-react@0.475.0_react@19.2.3/node_modules/lucide-react/dist/esm/Icon.cjs +4 -4
  48. package/dist/cjs/node_modules/.pnpm/lucide-react@0.475.0_react@19.2.3/node_modules/lucide-react/dist/esm/createLucideIcon.cjs +3 -3
  49. package/dist/cjs/number-field/number-field.cjs +1 -1
  50. package/dist/cjs/pagination/hooks/use-pagination.cjs +7 -7
  51. package/dist/cjs/pagination/pagination.cjs +6 -6
  52. package/dist/cjs/pagination/use-pagination-item.cjs +3 -3
  53. package/dist/cjs/pagination/use-pagination.cjs +8 -8
  54. package/dist/cjs/range-calendar/range-calendar.cjs +6 -6
  55. package/dist/cjs/ripple/use-ripple.cjs +4 -4
  56. package/dist/cjs/select/select.cjs +2 -2
  57. package/dist/cjs/spinner/use-spinner.cjs +3 -3
  58. package/dist/cjs/system/react-utils/children.cjs +26 -0
  59. package/dist/cjs/system/react-utils/context.cjs +3 -3
  60. package/dist/cjs/system/react-utils/refs.cjs +3 -3
  61. package/dist/cjs/system/utils.cjs +2 -2
  62. package/dist/cjs/tabs/tabs.cjs +2 -2
  63. package/dist/cjs/tag-field/tag-field-item.cjs +2 -2
  64. package/dist/cjs/tag-field/tag-field-list.cjs +4 -4
  65. package/dist/cjs/tag-field/tag-field-root.cjs +14 -14
  66. package/dist/cjs/tag-field/tag-field-state-context.cjs +2 -2
  67. package/dist/cjs/tag-field/tag-field-tag-list.cjs +3 -3
  68. package/dist/cjs/tag-field/tag-field-trigger.cjs +2 -2
  69. package/dist/cjs/tag-field/tag-field.cjs +3 -3
  70. package/dist/cjs/tag-field/use-tag-field-state.cjs +6 -6
  71. package/dist/cjs/tag-field/use-tag-field.cjs +4 -4
  72. package/dist/cjs/text-area/text-area.cjs +2 -2
  73. package/dist/cjs/toast/toast.cjs +1 -0
  74. package/dist/cjs/toggle/toggle.cjs +3 -3
  75. package/dist/esm/index.js +14 -5
  76. package/dist/esm/menu/menu.js +1 -1
  77. package/dist/esm/navbar/index.js +10 -0
  78. package/dist/esm/navbar/navbar-brand.js +26 -0
  79. package/dist/esm/navbar/navbar-content.js +31 -0
  80. package/dist/esm/navbar/navbar-context.js +11 -0
  81. package/dist/esm/navbar/navbar-item.js +27 -0
  82. package/dist/esm/navbar/navbar-menu/i18n.js +21 -0
  83. package/dist/esm/navbar/navbar-menu/item.js +42 -0
  84. package/dist/esm/navbar/navbar-menu/menu.js +60 -0
  85. package/dist/esm/navbar/navbar-menu/toggle.js +92 -0
  86. package/dist/esm/navbar/navbar.js +24 -0
  87. package/dist/esm/navbar/use-navbar.js +114 -0
  88. package/dist/esm/node_modules/.pnpm/@react-aria_overlays@3.30.0_react-dom@19.2.3_react@19.2.3__react@19.2.3/node_modules/@react-aria/overlays/dist/Overlay.js +52 -0
  89. package/dist/esm/node_modules/.pnpm/@react-aria_overlays@3.30.0_react-dom@19.2.3_react@19.2.3__react@19.2.3/node_modules/@react-aria/overlays/dist/PortalProvider.js +20 -0
  90. package/dist/esm/node_modules/.pnpm/@react-aria_overlays@3.30.0_react-dom@19.2.3_react@19.2.3__react@19.2.3/node_modules/@react-aria/overlays/dist/usePreventScroll.js +206 -0
  91. package/dist/esm/node_modules/.pnpm/@react-aria_ssr@3.9.10_react@19.2.3/node_modules/@react-aria/ssr/dist/SSRProvider.js +102 -0
  92. package/dist/esm/number-field/number-field.js +1 -1
  93. package/dist/esm/pagination/use-pagination-item.js +1 -1
  94. package/dist/esm/system/react-utils/children.js +23 -0
  95. package/dist/esm/tag-field/tag-field.js +1 -1
  96. package/dist/esm/toast/toast.js +1 -0
  97. package/dist/types/index.d.mts +1 -0
  98. package/dist/types/index.d.ts +1 -0
  99. package/dist/types/index.d.ts.map +1 -1
  100. package/dist/types/navbar/index.d.ts +17 -0
  101. package/dist/types/navbar/index.d.ts.map +1 -0
  102. package/dist/types/navbar/navbar-brand.d.ts +6 -0
  103. package/dist/types/navbar/navbar-brand.d.ts.map +1 -0
  104. package/dist/types/navbar/navbar-content.d.ts +14 -0
  105. package/dist/types/navbar/navbar-content.d.ts.map +1 -0
  106. package/dist/types/navbar/navbar-context.d.ts +174 -0
  107. package/dist/types/navbar/navbar-context.d.ts.map +1 -0
  108. package/dist/types/navbar/navbar-item.d.ts +11 -0
  109. package/dist/types/navbar/navbar-item.d.ts.map +1 -0
  110. package/dist/types/navbar/navbar-menu/i18n.d.ts +3 -0
  111. package/dist/types/navbar/navbar-menu/i18n.d.ts.map +1 -0
  112. package/dist/types/navbar/navbar-menu/item.d.ts +16 -0
  113. package/dist/types/navbar/navbar-menu/item.d.ts.map +1 -0
  114. package/dist/types/navbar/navbar-menu/menu.d.ts +11 -0
  115. package/dist/types/navbar/navbar-menu/menu.d.ts.map +1 -0
  116. package/dist/types/navbar/navbar-menu/toggle.d.ts +12 -0
  117. package/dist/types/navbar/navbar-menu/toggle.d.ts.map +1 -0
  118. package/dist/types/navbar/navbar.d.ts +6 -0
  119. package/dist/types/navbar/navbar.d.ts.map +1 -0
  120. package/dist/types/navbar/use-navbar.d.ts +131 -0
  121. package/dist/types/navbar/use-navbar.d.ts.map +1 -0
  122. package/dist/types/system/react-utils/children.d.ts +10 -0
  123. package/dist/types/system/react-utils/children.d.ts.map +1 -0
  124. package/dist/types/system/react-utils/index.d.ts +5 -3
  125. package/dist/types/system/react-utils/index.d.ts.map +1 -1
  126. package/dist/types/toast/index.d.ts +2 -1
  127. package/dist/types/toast/index.d.ts.map +1 -1
  128. package/dist/types/toast/toast.d.ts.map +1 -1
  129. package/package.json +3 -3
@@ -2,15 +2,15 @@
2
2
  "use client";
3
3
  'use strict';
4
4
 
5
- var react = require('react');
5
+ var $670gB$react = require('react');
6
6
  var interactions = require('@react-aria/interactions');
7
7
 
8
8
  function useDraggable(props) {
9
9
  const { targetRef, isDisabled = false, canOverflow = false } = props;
10
- const boundary = react.useRef({ minLeft: 0, minTop: 0, maxLeft: 0, maxTop: 0 });
11
- const isDragging = react.useRef(false);
10
+ const boundary = $670gB$react.useRef({ minLeft: 0, minTop: 0, maxLeft: 0, maxTop: 0 });
11
+ const isDragging = $670gB$react.useRef(false);
12
12
  let transform = { offsetX: 0, offsetY: 0 };
13
- const onMoveStart = react.useCallback(() => {
13
+ const onMoveStart = $670gB$react.useCallback(() => {
14
14
  isDragging.current = true;
15
15
  const { offsetX, offsetY } = transform;
16
16
  const targetRect = targetRef?.current?.getBoundingClientRect();
@@ -31,7 +31,7 @@ function useDraggable(props) {
31
31
  maxTop
32
32
  };
33
33
  }, [transform, targetRef?.current]);
34
- const onMove = react.useCallback(
34
+ const onMove = $670gB$react.useCallback(
35
35
  (e) => {
36
36
  if (isDisabled) {
37
37
  return;
@@ -54,7 +54,7 @@ function useDraggable(props) {
54
54
  },
55
55
  [isDisabled, transform, boundary.current, canOverflow, targetRef?.current]
56
56
  );
57
- const onMoveEnd = react.useCallback(() => {
57
+ const onMoveEnd = $670gB$react.useCallback(() => {
58
58
  isDragging.current = false;
59
59
  }, []);
60
60
  const { moveProps } = interactions.useMove({
@@ -62,12 +62,12 @@ function useDraggable(props) {
62
62
  onMove,
63
63
  onMoveEnd
64
64
  });
65
- const preventDefault = react.useCallback((e) => {
65
+ const preventDefault = $670gB$react.useCallback((e) => {
66
66
  if (isDragging.current) {
67
67
  e.preventDefault();
68
68
  }
69
69
  }, []);
70
- react.useEffect(() => {
70
+ $670gB$react.useEffect(() => {
71
71
  if (!isDisabled) {
72
72
  document.body.addEventListener("touchmove", preventDefault, {
73
73
  passive: false
@@ -3,12 +3,14 @@
3
3
 
4
4
  var useControllableState = require('./hooks/use-controllable-state.cjs');
5
5
  var useDraggable = require('./hooks/use-draggable.cjs');
6
+ var govtBanner = require('./govt-banner/govt-banner.cjs');
6
7
  var ripple = require('./ripple/ripple.cjs');
7
8
  var useRipple = require('./ripple/use-ripple.cjs');
8
9
  var spinner = require('./spinner/spinner.cjs');
9
10
  var useSpinner = require('./spinner/use-spinner.cjs');
10
11
  var toggle = require('./toggle/toggle.cjs');
11
12
  var skipNavLink = require('./skip-nav-link/skip-nav-link.cjs');
13
+ var input = require('./input/input.cjs');
12
14
  var textField = require('./text-field/text-field.cjs');
13
15
  var textArea = require('./text-area/text-area.cjs');
14
16
  var textAreaField = require('./text-area-field/text-area-field.cjs');
@@ -26,6 +28,9 @@ var paginationCursor = require('./pagination/pagination-cursor.cjs');
26
28
  var paginationItem = require('./pagination/pagination-item.cjs');
27
29
  var usePagination = require('./pagination/hooks/use-pagination.cjs');
28
30
  var usePagination$1 = require('./pagination/use-pagination.cjs');
31
+ var fileDropzone = require('./file-dropzone/file-dropzone.cjs');
32
+ var fileInfo = require('./file-dropzone/file-info.cjs');
33
+ var utils$1 = require('./file-dropzone/utils.cjs');
29
34
  var numberField = require('./number-field/number-field.cjs');
30
35
  var modal = require('./modal/modal.cjs');
31
36
  var modalContent = require('./modal/modal-content.cjs');
@@ -34,9 +39,16 @@ var modalBody = require('./modal/modal-body.cjs');
34
39
  var modalHeader = require('./modal/modal-header.cjs');
35
40
  var modalVariantContext = require('./modal/modal-variant-context.cjs');
36
41
  var toast = require('./toast/toast.cjs');
42
+ var navbar = require('./navbar/navbar.cjs');
43
+ var navbarBrand = require('./navbar/navbar-brand.cjs');
44
+ var navbarContent = require('./navbar/navbar-content.cjs');
45
+ var menu$1 = require('./navbar/navbar-menu/menu.cjs');
46
+ var item = require('./navbar/navbar-menu/item.cjs');
47
+ var toggle$1 = require('./navbar/navbar-menu/toggle.cjs');
48
+ var navbarItem = require('./navbar/navbar-item.cjs');
49
+ var useNavbar = require('./navbar/use-navbar.cjs');
50
+ var navbarContext = require('./navbar/navbar-context.cjs');
37
51
  var button = require('./button/button.cjs');
38
- var govtBanner = require('./govt-banner/govt-banner.cjs');
39
- var input = require('./input/input.cjs');
40
52
  var field = require('./field/field.cjs');
41
53
  var comboBox = require('./combo-box/combo-box.cjs');
42
54
  var comboBoxFuzzy = require('./combo-box/combo-box-fuzzy.cjs');
@@ -53,21 +65,20 @@ var datePicker = require('./date-picker/date-picker.cjs');
53
65
  var dateRangePicker = require('./date-range-picker/date-range-picker.cjs');
54
66
  var checkbox = require('./checkbox/checkbox.cjs');
55
67
  var checkboxGroupStyleContext = require('./checkbox/checkbox-group-style-context.cjs');
56
- var fileDropzone = require('./file-dropzone/file-dropzone.cjs');
57
- var fileInfo = require('./file-dropzone/file-info.cjs');
58
- var utils$1 = require('./file-dropzone/utils.cjs');
59
68
  var sonner = require('sonner');
60
69
 
61
70
 
62
71
 
63
72
  exports.useControllableState = useControllableState.useControllableState;
64
73
  exports.useDraggable = useDraggable.useDraggable;
74
+ exports.GovtBanner = govtBanner.GovtBanner;
65
75
  exports.Ripple = ripple.Ripple;
66
76
  exports.useRipple = useRipple.useRipple;
67
77
  exports.Spinner = spinner.Spinner;
68
78
  exports.useSpinner = useSpinner.useSpinner;
69
79
  exports.Toggle = toggle.Toggle;
70
80
  exports.SkipNavLink = skipNavLink.SkipNavLink;
81
+ exports.Input = input.Input;
71
82
  exports.TextField = textField.TextField;
72
83
  exports.TextArea = textArea.TextArea;
73
84
  exports.TextAreaField = textAreaField.TextAreaField;
@@ -101,6 +112,10 @@ exports.PaginationItem = paginationItem.PaginationItem;
101
112
  exports.PaginationItemType = usePagination.PaginationItemType;
102
113
  exports.CURSOR_TRANSITION_TIMEOUT = usePagination$1.CURSOR_TRANSITION_TIMEOUT;
103
114
  exports.usePagination = usePagination$1.usePagination;
115
+ exports.FileDropzone = fileDropzone.FileDropzone;
116
+ exports.FileInfo = fileInfo.FileInfo;
117
+ exports.formatBytes = utils$1.formatBytes;
118
+ exports.formatErrorMessage = utils$1.formatErrorMessage;
104
119
  exports.NumberField = numberField.NumberField;
105
120
  exports.Modal = modal.Modal;
106
121
  exports.ModalContent = modalContent.ModalContent;
@@ -110,9 +125,17 @@ exports.ModalHeader = modalHeader.ModalHeader;
110
125
  exports.ModalVariantContext = modalVariantContext.ModalVariantContext;
111
126
  exports.useModalVariantContext = modalVariantContext.useModalVariantContext;
112
127
  exports.Toaster = toast.Toaster;
128
+ exports.Navbar = navbar.Navbar;
129
+ exports.NavbarBrand = navbarBrand.NavbarBrand;
130
+ exports.NavbarContent = navbarContent.NavbarContent;
131
+ exports.NavbarMenu = menu$1.NavbarMenu;
132
+ exports.NavbarMenuItem = item.NavbarMenuItem;
133
+ exports.NavbarMenuToggle = toggle$1.NavbarMenuToggle;
134
+ exports.NavbarItem = navbarItem.NavbarItem;
135
+ exports.useNavbar = useNavbar.useNavbar;
136
+ exports.NavbarProvider = navbarContext.NavbarProvider;
137
+ exports.useNavbarContext = navbarContext.useNavbarContext;
113
138
  exports.Button = button.Button;
114
- exports.GovtBanner = govtBanner.GovtBanner;
115
- exports.Input = input.Input;
116
139
  exports.Description = field.Description;
117
140
  exports.FieldError = field.FieldError;
118
141
  exports.FieldErrorIcon = field.FieldErrorIcon;
@@ -146,10 +169,6 @@ exports.Checkbox = checkbox.Checkbox;
146
169
  exports.CheckboxGroup = checkbox.CheckboxGroup;
147
170
  exports.CheckboxGroupStyleContext = checkboxGroupStyleContext.CheckboxGroupStyleContext;
148
171
  exports.useCheckboxGroupStyleContext = checkboxGroupStyleContext.useCheckboxGroupStyleContext;
149
- exports.FileDropzone = fileDropzone.FileDropzone;
150
- exports.FileInfo = fileInfo.FileInfo;
151
- exports.formatBytes = utils$1.formatBytes;
152
- exports.formatErrorMessage = utils$1.formatErrorMessage;
153
172
  Object.defineProperty(exports, "toast", {
154
173
  enumerable: true,
155
174
  get: function () { return sonner.toast; }
@@ -3,11 +3,11 @@
3
3
  'use strict';
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var react = require('react');
6
+ var $670gB$react = require('react');
7
7
  var reactAriaComponents = require('react-aria-components');
8
8
  var ouiTheme = require('@opengovsg/oui-theme');
9
9
 
10
- const Input = react.forwardRef(
10
+ const Input = $670gB$react.forwardRef(
11
11
  ({ size, variant, isDisabled, ...props }, ref) => {
12
12
  return /* @__PURE__ */ jsxRuntime.jsx(
13
13
  reactAriaComponents.Input,
@@ -3,14 +3,14 @@
3
3
  'use strict';
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var react = require('react');
6
+ var $670gB$react = require('react');
7
7
  var reactAriaComponents = require('react-aria-components');
8
8
  var ouiTheme = require('@opengovsg/oui-theme');
9
9
  var popover = require('../popover/popover.cjs');
10
10
  var utils = require('../system/utils.cjs');
11
+ var context = require('../system/react-utils/context.cjs');
11
12
  var check = require('../node_modules/.pnpm/lucide-react@0.475.0_react@19.2.3/node_modules/lucide-react/dist/esm/icons/check.cjs');
12
13
  var chevronRight = require('../node_modules/.pnpm/lucide-react@0.475.0_react@19.2.3/node_modules/lucide-react/dist/esm/icons/chevron-right.cjs');
13
- var context = require('../system/react-utils/context.cjs');
14
14
 
15
15
  const [MenuVariantContext, useMenuVariantContext] = context.createContext({
16
16
  name: "MenuVariantContext",
@@ -51,7 +51,7 @@ function MenuInner(originalProps, ref) {
51
51
  ) });
52
52
  }
53
53
  const Menu = utils.forwardRefGeneric(MenuInner);
54
- const MenuItem = react.forwardRef(function MenuItem2(originalProps, ref) {
54
+ const MenuItem = $670gB$react.forwardRef(function MenuItem2(originalProps, ref) {
55
55
  [originalProps, ref] = reactAriaComponents.useContextProps(
56
56
  originalProps,
57
57
  ref,
@@ -70,7 +70,7 @@ const MenuItem = react.forwardRef(function MenuItem2(originalProps, ref) {
70
70
  variantProps
71
71
  ] = utils.mapPropsVariants(originalProps, ouiTheme.listBoxItemStyles.variantKeys);
72
72
  const styles = ouiTheme.menuItemStyles(variantProps);
73
- const multipleSelectionIcon = react.useMemo(() => {
73
+ const multipleSelectionIcon = $670gB$react.useMemo(() => {
74
74
  if (multipleSelectionIconProp !== void 0) {
75
75
  return multipleSelectionIconProp;
76
76
  }
@@ -82,7 +82,7 @@ const MenuItem = react.forwardRef(function MenuItem2(originalProps, ref) {
82
82
  }
83
83
  );
84
84
  }, [classNames?.icon, multipleSelectionIconProp, styles]);
85
- const singleSelectionIcon = react.useMemo(() => {
85
+ const singleSelectionIcon = $670gB$react.useMemo(() => {
86
86
  if (singleSelectionIconProp !== void 0) {
87
87
  return singleSelectionIconProp;
88
88
  }
@@ -94,7 +94,7 @@ const MenuItem = react.forwardRef(function MenuItem2(originalProps, ref) {
94
94
  }
95
95
  );
96
96
  }, [classNames?.icon, singleSelectionIconProp, styles]);
97
- const showIconContainer = react.useCallback(
97
+ const showIconContainer = $670gB$react.useCallback(
98
98
  (selectionMode) => {
99
99
  switch (selectionMode) {
100
100
  case "none":
@@ -107,7 +107,7 @@ const MenuItem = react.forwardRef(function MenuItem2(originalProps, ref) {
107
107
  },
108
108
  [multipleSelectionIcon, singleSelectionIcon]
109
109
  );
110
- const defaultTextValue = react.useMemo(() => {
110
+ const defaultTextValue = $670gB$react.useMemo(() => {
111
111
  if (props.textValue) {
112
112
  return props.textValue;
113
113
  }
@@ -3,13 +3,13 @@
3
3
  'use strict';
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var react = require('react');
6
+ var $670gB$react = require('react');
7
7
  var ouiTheme = require('@opengovsg/oui-theme');
8
8
  var utils = require('../system/utils.cjs');
9
9
  var modalVariantContext = require('./modal-variant-context.cjs');
10
10
 
11
11
  const ModalBody = utils.forwardRef(function ModalBody2({ as, ...props }, ref) {
12
- const { slots, classNames } = react.useContext(modalVariantContext.ModalVariantContext);
12
+ const { slots, classNames } = $670gB$react.useContext(modalVariantContext.ModalVariantContext);
13
13
  const Component = as || "div";
14
14
  return /* @__PURE__ */ jsxRuntime.jsx(
15
15
  Component,
@@ -3,7 +3,7 @@
3
3
  'use strict';
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var react = require('react');
6
+ var $670gB$react = require('react');
7
7
  var reactAria = require('react-aria');
8
8
  var reactAriaComponents = require('react-aria-components');
9
9
  var ouiTheme = require('@opengovsg/oui-theme');
@@ -18,9 +18,9 @@ function ModalContent({
18
18
  closeButtonProps,
19
19
  ...props
20
20
  }) {
21
- const { slots, classNames, buttonSize } = react.useContext(modalVariantContext.ModalVariantContext);
21
+ const { slots, classNames, buttonSize } = $670gB$react.useContext(modalVariantContext.ModalVariantContext);
22
22
  const formatMessage = reactAria.useMessageFormatter(i18n.i18nStrings);
23
- const closeButtonContent = react.isValidElement(closeButtonContentProp) ? closeButtonContentProp : /* @__PURE__ */ jsxRuntime.jsx(x.default, {});
23
+ const closeButtonContent = $670gB$react.isValidElement(closeButtonContentProp) ? closeButtonContentProp : /* @__PURE__ */ jsxRuntime.jsx(x.default, {});
24
24
  return /* @__PURE__ */ jsxRuntime.jsx(
25
25
  reactAriaComponents.Dialog,
26
26
  {
@@ -3,13 +3,13 @@
3
3
  'use strict';
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var react = require('react');
6
+ var $670gB$react = require('react');
7
7
  var ouiTheme = require('@opengovsg/oui-theme');
8
8
  var utils = require('../system/utils.cjs');
9
9
  var modalVariantContext = require('./modal-variant-context.cjs');
10
10
 
11
11
  const ModalFooter = utils.forwardRef(function ModalFooter2({ as, ...props }, ref) {
12
- const { slots, classNames } = react.useContext(modalVariantContext.ModalVariantContext);
12
+ const { slots, classNames } = $670gB$react.useContext(modalVariantContext.ModalVariantContext);
13
13
  const Component = as || "footer";
14
14
  return /* @__PURE__ */ jsxRuntime.jsx(
15
15
  Component,
@@ -3,13 +3,13 @@
3
3
  'use strict';
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var react = require('react');
6
+ var $670gB$react = require('react');
7
7
  var reactAriaComponents = require('react-aria-components');
8
8
  var ouiTheme = require('@opengovsg/oui-theme');
9
9
  var modalVariantContext = require('./modal-variant-context.cjs');
10
10
 
11
11
  function ModalHeader(props) {
12
- const { slots, classNames } = react.useContext(modalVariantContext.ModalVariantContext);
12
+ const { slots, classNames } = $670gB$react.useContext(modalVariantContext.ModalVariantContext);
13
13
  return /* @__PURE__ */ jsxRuntime.jsx(
14
14
  reactAriaComponents.Heading,
15
15
  {
@@ -3,20 +3,20 @@
3
3
  'use strict';
4
4
 
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
- var react = require('react');
6
+ var $670gB$react = require('react');
7
7
  var reactAriaComponents = require('react-aria-components');
8
8
  var ouiTheme = require('@opengovsg/oui-theme');
9
9
  var utils = require('../system/utils.cjs');
10
10
  var modalVariantContext = require('./modal-variant-context.cjs');
11
11
 
12
- const Modal = react.forwardRef(function Modal2(originalProps, ref) {
12
+ const Modal = $670gB$react.forwardRef(function Modal2(originalProps, ref) {
13
13
  const [{ classNames, ...props }, variantProps] = utils.mapPropsVariants(
14
14
  originalProps,
15
15
  ouiTheme.modalStyles.variantKeys
16
16
  );
17
17
  const { isDismissable = true } = props;
18
18
  const slots = ouiTheme.modalStyles(variantProps);
19
- const buttonSize = react.useMemo(() => {
19
+ const buttonSize = $670gB$react.useMemo(() => {
20
20
  switch (variantProps.size) {
21
21
  case "mobile":
22
22
  return "md";
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ 'use strict';
3
+
4
+ var navbar = require('./navbar.cjs');
5
+ var navbarBrand = require('./navbar-brand.cjs');
6
+ var navbarContent = require('./navbar-content.cjs');
7
+ var menu = require('./navbar-menu/menu.cjs');
8
+ var item = require('./navbar-menu/item.cjs');
9
+ var toggle = require('./navbar-menu/toggle.cjs');
10
+ var navbarItem = require('./navbar-item.cjs');
11
+ var useNavbar = require('./use-navbar.cjs');
12
+ var navbarContext = require('./navbar-context.cjs');
13
+
14
+
15
+
16
+ exports.Navbar = navbar.Navbar;
17
+ exports.NavbarBrand = navbarBrand.NavbarBrand;
18
+ exports.NavbarContent = navbarContent.NavbarContent;
19
+ exports.NavbarMenu = menu.NavbarMenu;
20
+ exports.NavbarMenuItem = item.NavbarMenuItem;
21
+ exports.NavbarMenuToggle = toggle.NavbarMenuToggle;
22
+ exports.NavbarItem = navbarItem.NavbarItem;
23
+ exports.useNavbar = useNavbar.useNavbar;
24
+ exports.NavbarProvider = navbarContext.NavbarProvider;
25
+ exports.useNavbarContext = navbarContext.useNavbarContext;
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ "use client";
3
+ 'use strict';
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var ouiTheme = require('@opengovsg/oui-theme');
7
+ var utils = require('../system/utils.cjs');
8
+ var navbarContext = require('./navbar-context.cjs');
9
+ var refs = require('../system/react-utils/refs.cjs');
10
+
11
+ const NavbarBrand = utils.forwardRef((props, ref) => {
12
+ const { as, className, children, ...otherProps } = props;
13
+ const Component = as || "div";
14
+ const domRef = refs.useDomRef(ref);
15
+ const { slots, classNames } = navbarContext.useNavbarContext();
16
+ return /* @__PURE__ */ jsxRuntime.jsx(
17
+ Component,
18
+ {
19
+ ref: domRef,
20
+ className: slots.brand?.({ className: ouiTheme.cn(classNames?.brand, className) }),
21
+ ...otherProps,
22
+ children
23
+ }
24
+ );
25
+ });
26
+ NavbarBrand.displayName = "NavbarBrand";
27
+
28
+ exports.NavbarBrand = NavbarBrand;
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ "use client";
3
+ 'use strict';
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var ouiTheme = require('@opengovsg/oui-theme');
7
+ var utils = require('../system/utils.cjs');
8
+ var navbarContext = require('./navbar-context.cjs');
9
+ var refs = require('../system/react-utils/refs.cjs');
10
+
11
+ const NavbarContent = utils.forwardRef(
12
+ (props, ref) => {
13
+ const { as, className, children, justify = "start", ...otherProps } = props;
14
+ const Component = as || "div";
15
+ const domRef = refs.useDomRef(ref);
16
+ const { slots, classNames } = navbarContext.useNavbarContext();
17
+ return /* @__PURE__ */ jsxRuntime.jsx(
18
+ Component,
19
+ {
20
+ ref: domRef,
21
+ className: slots.content?.({
22
+ className: ouiTheme.cn(classNames?.content, className)
23
+ }),
24
+ "data-justify": justify,
25
+ ...otherProps,
26
+ children
27
+ }
28
+ );
29
+ }
30
+ );
31
+ NavbarContent.displayName = "NavbarContent";
32
+
33
+ exports.NavbarContent = NavbarContent;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ "use client";
3
+ 'use strict';
4
+
5
+ var context = require('../system/react-utils/context.cjs');
6
+
7
+ const [NavbarProvider, useNavbarContext] = context.createContext({
8
+ name: "NavbarContext",
9
+ strict: true,
10
+ errorMessage: "useNavbarContext: `context` is undefined. Seems you forgot to wrap component within <Navbar />"
11
+ });
12
+
13
+ exports.NavbarProvider = NavbarProvider;
14
+ exports.useNavbarContext = useNavbarContext;
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ "use client";
3
+ 'use strict';
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var ouiTheme = require('@opengovsg/oui-theme');
7
+ var utils = require('../system/utils.cjs');
8
+ var navbarContext = require('./navbar-context.cjs');
9
+ var refs = require('../system/react-utils/refs.cjs');
10
+
11
+ const NavbarItem = utils.forwardRef((props, ref) => {
12
+ const { as, className, children, isActive, ...otherProps } = props;
13
+ const Component = as || "div";
14
+ const domRef = refs.useDomRef(ref);
15
+ const { slots, classNames } = navbarContext.useNavbarContext();
16
+ return /* @__PURE__ */ jsxRuntime.jsx(
17
+ Component,
18
+ {
19
+ ref: domRef,
20
+ className: slots.item({ className: ouiTheme.cn(classNames?.item, className) }),
21
+ "data-active": ouiTheme.dataAttr(isActive),
22
+ ...otherProps,
23
+ children
24
+ }
25
+ );
26
+ });
27
+ NavbarItem.displayName = "NavbarItem";
28
+
29
+ exports.NavbarItem = NavbarItem;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ 'use strict';
3
+
4
+ const i18nStrings = {
5
+ "en-SG": {
6
+ openMenu: "Open navigation menu",
7
+ closeMenu: "Close navigation menu"
8
+ },
9
+ "zh-SG": {
10
+ openMenu: "\u6253\u5F00\u5BFC\u822A\u83DC\u5355",
11
+ closeMenu: "\u5173\u95ED\u5BFC\u822A\u83DC\u5355"
12
+ },
13
+ "ms-SG": {
14
+ openMenu: "Buka menu navigasi",
15
+ closeMenu: "Tutup menu navigasi"
16
+ },
17
+ "ta-SG": {
18
+ openMenu: "\u0BA8\u0BC7\u0BB5\u0BBF\u0B95\u0BC7\u0BB7\u0BA9\u0BCD \u0BAE\u0BC6\u0BA9\u0BC1\u0BB5\u0BC8\u0BA4\u0BCD \u0BA4\u0BBF\u0BB1",
19
+ closeMenu: "\u0BA8\u0BC7\u0BB5\u0BBF\u0B95\u0BC7\u0BB7\u0BA9\u0BCD \u0BAE\u0BC6\u0BA9\u0BC1\u0BB5\u0BC8 \u0BAE\u0BC2\u0B9F\u0BC1"
20
+ }
21
+ };
22
+
23
+ exports.i18nStrings = i18nStrings;
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ "use client";
3
+ 'use strict';
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var reactAriaComponents = require('react-aria-components');
7
+ var ouiTheme = require('@opengovsg/oui-theme');
8
+ var utils = require('../../system/utils.cjs');
9
+ var navbarContext = require('../navbar-context.cjs');
10
+ var refs = require('../../system/react-utils/refs.cjs');
11
+
12
+ const NavbarMenuItem = utils.forwardRef(
13
+ (props, ref) => {
14
+ const { className, children, isActive, ...otherProps } = props;
15
+ const domRef = refs.useDomRef(ref);
16
+ const { isMenuOpen, classNames } = navbarContext.useNavbarContext();
17
+ const renderProps = reactAriaComponents.useRenderProps({
18
+ className: reactAriaComponents.composeRenderProps(
19
+ className,
20
+ (className2, renderProps2) => ouiTheme.navbarMenuItemStyles({
21
+ className: ouiTheme.cn(classNames?.menuItem, className2),
22
+ ...renderProps2
23
+ })
24
+ ),
25
+ values: {
26
+ isActive: !!isActive
27
+ }
28
+ });
29
+ return /* @__PURE__ */ jsxRuntime.jsx(
30
+ "li",
31
+ {
32
+ ref: domRef,
33
+ className: renderProps.className,
34
+ "data-active": ouiTheme.dataAttr(isActive),
35
+ "data-open": ouiTheme.dataAttr(isMenuOpen),
36
+ ...otherProps,
37
+ children
38
+ }
39
+ );
40
+ }
41
+ );
42
+ NavbarMenuItem.displayName = "NavbarMenuItem";
43
+
44
+ exports.NavbarMenuItem = NavbarMenuItem;
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ "use client";
3
+ 'use strict';
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var Overlay = require('../../node_modules/.pnpm/@react-aria_overlays@3.30.0_react-dom@19.2.3_react@19.2.3__react@19.2.3/node_modules/@react-aria/overlays/dist/Overlay.cjs');
7
+ var reactAria = require('react-aria');
8
+ var ouiTheme = require('@opengovsg/oui-theme');
9
+ var utils = require('../../system/utils.cjs');
10
+ var navbarContext = require('../navbar-context.cjs');
11
+ var refs = require('../../system/react-utils/refs.cjs');
12
+
13
+ const NavbarMenu = utils.forwardRef(
14
+ ({ className, children, portalContainer, style, onKeyDown, ...props }, ref) => {
15
+ const domRef = refs.useDomRef(ref);
16
+ const {
17
+ slots,
18
+ isMenuOpen,
19
+ height,
20
+ classNames,
21
+ setIsMenuOpen,
22
+ domRef: parentRef,
23
+ menuRef
24
+ } = navbarContext.useNavbarContext();
25
+ const handleKeyDown = (e) => {
26
+ if (e.key === "Escape") {
27
+ e.stopPropagation();
28
+ setIsMenuOpen(false);
29
+ menuRef.current?.focus();
30
+ }
31
+ };
32
+ if (!isMenuOpen) return null;
33
+ return /* @__PURE__ */ jsxRuntime.jsx(
34
+ Overlay.Overlay,
35
+ {
36
+ disableFocusManagement: true,
37
+ portalContainer: portalContainer ?? parentRef.current ?? void 0,
38
+ children: /* @__PURE__ */ jsxRuntime.jsx(
39
+ "ul",
40
+ {
41
+ ref: domRef,
42
+ className: slots.menu?.({
43
+ className: ouiTheme.cn(classNames?.menu, className)
44
+ }),
45
+ "data-open": ouiTheme.dataAttr(isMenuOpen),
46
+ style: {
47
+ ...style,
48
+ // @ts-expect-error due to not having any type declaration for CSS variables in React style prop
49
+ "--navbar-height": typeof height === "number" ? `${height}px` : height
50
+ },
51
+ onKeyDown: reactAria.chain(handleKeyDown, onKeyDown),
52
+ ...props,
53
+ children
54
+ }
55
+ )
56
+ }
57
+ );
58
+ }
59
+ );
60
+ NavbarMenu.displayName = "NavbarMenu";
61
+
62
+ exports.NavbarMenu = NavbarMenu;