@tamagui/create-menu 2.0.0-1

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 (162) hide show
  1. package/LICENSE +21 -0
  2. package/dist/cjs/MenuPredefined.cjs +182 -0
  3. package/dist/cjs/MenuPredefined.js +162 -0
  4. package/dist/cjs/MenuPredefined.js.map +6 -0
  5. package/dist/cjs/MenuPredefined.native.js +185 -0
  6. package/dist/cjs/MenuPredefined.native.js.map +1 -0
  7. package/dist/cjs/createBaseMenu.cjs +927 -0
  8. package/dist/cjs/createBaseMenu.js +724 -0
  9. package/dist/cjs/createBaseMenu.js.map +6 -0
  10. package/dist/cjs/createBaseMenu.native.js +1105 -0
  11. package/dist/cjs/createBaseMenu.native.js.map +1 -0
  12. package/dist/cjs/createNativeMenu/createNativeMenu.cjs +224 -0
  13. package/dist/cjs/createNativeMenu/createNativeMenu.js +172 -0
  14. package/dist/cjs/createNativeMenu/createNativeMenu.js.map +6 -0
  15. package/dist/cjs/createNativeMenu/createNativeMenu.native.js +287 -0
  16. package/dist/cjs/createNativeMenu/createNativeMenu.native.js.map +1 -0
  17. package/dist/cjs/createNativeMenu/createNativeMenuTypes.cjs +16 -0
  18. package/dist/cjs/createNativeMenu/createNativeMenuTypes.js +14 -0
  19. package/dist/cjs/createNativeMenu/createNativeMenuTypes.js.map +6 -0
  20. package/dist/cjs/createNativeMenu/createNativeMenuTypes.native.js +19 -0
  21. package/dist/cjs/createNativeMenu/createNativeMenuTypes.native.js.map +1 -0
  22. package/dist/cjs/createNativeMenu/index.cjs +19 -0
  23. package/dist/cjs/createNativeMenu/index.js +16 -0
  24. package/dist/cjs/createNativeMenu/index.js.map +6 -0
  25. package/dist/cjs/createNativeMenu/index.native.js +22 -0
  26. package/dist/cjs/createNativeMenu/index.native.js.map +1 -0
  27. package/dist/cjs/createNativeMenu/utils.cjs +68 -0
  28. package/dist/cjs/createNativeMenu/utils.js +66 -0
  29. package/dist/cjs/createNativeMenu/utils.js.map +6 -0
  30. package/dist/cjs/createNativeMenu/utils.native.js +94 -0
  31. package/dist/cjs/createNativeMenu/utils.native.js.map +1 -0
  32. package/dist/cjs/createNativeMenu/withNativeMenu.cjs +37 -0
  33. package/dist/cjs/createNativeMenu/withNativeMenu.js +30 -0
  34. package/dist/cjs/createNativeMenu/withNativeMenu.js.map +6 -0
  35. package/dist/cjs/createNativeMenu/withNativeMenu.native.js +43 -0
  36. package/dist/cjs/createNativeMenu/withNativeMenu.native.js.map +1 -0
  37. package/dist/cjs/index.cjs +30 -0
  38. package/dist/cjs/index.js +24 -0
  39. package/dist/cjs/index.js.map +6 -0
  40. package/dist/cjs/index.native.js +33 -0
  41. package/dist/cjs/index.native.js.map +1 -0
  42. package/dist/esm/MenuPredefined.js +147 -0
  43. package/dist/esm/MenuPredefined.js.map +6 -0
  44. package/dist/esm/MenuPredefined.mjs +159 -0
  45. package/dist/esm/MenuPredefined.mjs.map +1 -0
  46. package/dist/esm/MenuPredefined.native.js +159 -0
  47. package/dist/esm/MenuPredefined.native.js.map +1 -0
  48. package/dist/esm/createBaseMenu.js +729 -0
  49. package/dist/esm/createBaseMenu.js.map +6 -0
  50. package/dist/esm/createBaseMenu.mjs +893 -0
  51. package/dist/esm/createBaseMenu.mjs.map +1 -0
  52. package/dist/esm/createBaseMenu.native.js +1068 -0
  53. package/dist/esm/createBaseMenu.native.js.map +1 -0
  54. package/dist/esm/createNativeMenu/createNativeMenu.js +150 -0
  55. package/dist/esm/createNativeMenu/createNativeMenu.js.map +6 -0
  56. package/dist/esm/createNativeMenu/createNativeMenu.mjs +190 -0
  57. package/dist/esm/createNativeMenu/createNativeMenu.mjs.map +1 -0
  58. package/dist/esm/createNativeMenu/createNativeMenu.native.js +250 -0
  59. package/dist/esm/createNativeMenu/createNativeMenu.native.js.map +1 -0
  60. package/dist/esm/createNativeMenu/createNativeMenuTypes.js +1 -0
  61. package/dist/esm/createNativeMenu/createNativeMenuTypes.js.map +6 -0
  62. package/dist/esm/createNativeMenu/createNativeMenuTypes.mjs +2 -0
  63. package/dist/esm/createNativeMenu/createNativeMenuTypes.mjs.map +1 -0
  64. package/dist/esm/createNativeMenu/createNativeMenuTypes.native.js +2 -0
  65. package/dist/esm/createNativeMenu/createNativeMenuTypes.native.js.map +1 -0
  66. package/dist/esm/createNativeMenu/index.js +3 -0
  67. package/dist/esm/createNativeMenu/index.js.map +6 -0
  68. package/dist/esm/createNativeMenu/index.mjs +3 -0
  69. package/dist/esm/createNativeMenu/index.mjs.map +1 -0
  70. package/dist/esm/createNativeMenu/index.native.js +3 -0
  71. package/dist/esm/createNativeMenu/index.native.js.map +1 -0
  72. package/dist/esm/createNativeMenu/utils.js +47 -0
  73. package/dist/esm/createNativeMenu/utils.js.map +6 -0
  74. package/dist/esm/createNativeMenu/utils.mjs +29 -0
  75. package/dist/esm/createNativeMenu/utils.mjs.map +1 -0
  76. package/dist/esm/createNativeMenu/utils.native.js +52 -0
  77. package/dist/esm/createNativeMenu/utils.native.js.map +1 -0
  78. package/dist/esm/createNativeMenu/withNativeMenu.js +15 -0
  79. package/dist/esm/createNativeMenu/withNativeMenu.js.map +6 -0
  80. package/dist/esm/createNativeMenu/withNativeMenu.mjs +14 -0
  81. package/dist/esm/createNativeMenu/withNativeMenu.mjs.map +1 -0
  82. package/dist/esm/createNativeMenu/withNativeMenu.native.js +17 -0
  83. package/dist/esm/createNativeMenu/withNativeMenu.native.js.map +1 -0
  84. package/dist/esm/index.js +8 -0
  85. package/dist/esm/index.js.map +6 -0
  86. package/dist/esm/index.mjs +6 -0
  87. package/dist/esm/index.mjs.map +1 -0
  88. package/dist/esm/index.native.js +6 -0
  89. package/dist/esm/index.native.js.map +1 -0
  90. package/dist/jsx/MenuPredefined.js +147 -0
  91. package/dist/jsx/MenuPredefined.js.map +6 -0
  92. package/dist/jsx/MenuPredefined.mjs +159 -0
  93. package/dist/jsx/MenuPredefined.mjs.map +1 -0
  94. package/dist/jsx/MenuPredefined.native.js +185 -0
  95. package/dist/jsx/MenuPredefined.native.js.map +1 -0
  96. package/dist/jsx/createBaseMenu.js +729 -0
  97. package/dist/jsx/createBaseMenu.js.map +6 -0
  98. package/dist/jsx/createBaseMenu.mjs +893 -0
  99. package/dist/jsx/createBaseMenu.mjs.map +1 -0
  100. package/dist/jsx/createBaseMenu.native.js +1105 -0
  101. package/dist/jsx/createBaseMenu.native.js.map +1 -0
  102. package/dist/jsx/createNativeMenu/createNativeMenu.js +150 -0
  103. package/dist/jsx/createNativeMenu/createNativeMenu.js.map +6 -0
  104. package/dist/jsx/createNativeMenu/createNativeMenu.mjs +190 -0
  105. package/dist/jsx/createNativeMenu/createNativeMenu.mjs.map +1 -0
  106. package/dist/jsx/createNativeMenu/createNativeMenu.native.js +287 -0
  107. package/dist/jsx/createNativeMenu/createNativeMenu.native.js.map +1 -0
  108. package/dist/jsx/createNativeMenu/createNativeMenuTypes.js +1 -0
  109. package/dist/jsx/createNativeMenu/createNativeMenuTypes.js.map +6 -0
  110. package/dist/jsx/createNativeMenu/createNativeMenuTypes.mjs +2 -0
  111. package/dist/jsx/createNativeMenu/createNativeMenuTypes.mjs.map +1 -0
  112. package/dist/jsx/createNativeMenu/createNativeMenuTypes.native.js +19 -0
  113. package/dist/jsx/createNativeMenu/createNativeMenuTypes.native.js.map +1 -0
  114. package/dist/jsx/createNativeMenu/index.js +3 -0
  115. package/dist/jsx/createNativeMenu/index.js.map +6 -0
  116. package/dist/jsx/createNativeMenu/index.mjs +3 -0
  117. package/dist/jsx/createNativeMenu/index.mjs.map +1 -0
  118. package/dist/jsx/createNativeMenu/index.native.js +22 -0
  119. package/dist/jsx/createNativeMenu/index.native.js.map +1 -0
  120. package/dist/jsx/createNativeMenu/utils.js +47 -0
  121. package/dist/jsx/createNativeMenu/utils.js.map +6 -0
  122. package/dist/jsx/createNativeMenu/utils.mjs +29 -0
  123. package/dist/jsx/createNativeMenu/utils.mjs.map +1 -0
  124. package/dist/jsx/createNativeMenu/utils.native.js +94 -0
  125. package/dist/jsx/createNativeMenu/utils.native.js.map +1 -0
  126. package/dist/jsx/createNativeMenu/withNativeMenu.js +15 -0
  127. package/dist/jsx/createNativeMenu/withNativeMenu.js.map +6 -0
  128. package/dist/jsx/createNativeMenu/withNativeMenu.mjs +14 -0
  129. package/dist/jsx/createNativeMenu/withNativeMenu.mjs.map +1 -0
  130. package/dist/jsx/createNativeMenu/withNativeMenu.native.js +43 -0
  131. package/dist/jsx/createNativeMenu/withNativeMenu.native.js.map +1 -0
  132. package/dist/jsx/index.js +8 -0
  133. package/dist/jsx/index.js.map +6 -0
  134. package/dist/jsx/index.mjs +6 -0
  135. package/dist/jsx/index.mjs.map +1 -0
  136. package/dist/jsx/index.native.js +33 -0
  137. package/dist/jsx/index.native.js.map +1 -0
  138. package/package.json +80 -0
  139. package/src/MenuPredefined.tsx +195 -0
  140. package/src/createBaseMenu.tsx +1703 -0
  141. package/src/createNativeMenu/createNativeMenu.tsx +372 -0
  142. package/src/createNativeMenu/createNativeMenuTypes.ts +214 -0
  143. package/src/createNativeMenu/index.tsx +7 -0
  144. package/src/createNativeMenu/utils.tsx +150 -0
  145. package/src/createNativeMenu/withNativeMenu.tsx +38 -0
  146. package/src/index.tsx +9 -0
  147. package/types/MenuPredefined.d.ts +28 -0
  148. package/types/MenuPredefined.d.ts.map +1 -0
  149. package/types/createBaseMenu.d.ts +207 -0
  150. package/types/createBaseMenu.d.ts.map +1 -0
  151. package/types/createNativeMenu/createNativeMenu.d.ts +42 -0
  152. package/types/createNativeMenu/createNativeMenu.d.ts.map +1 -0
  153. package/types/createNativeMenu/createNativeMenuTypes.d.ts +188 -0
  154. package/types/createNativeMenu/createNativeMenuTypes.d.ts.map +1 -0
  155. package/types/createNativeMenu/index.d.ts +4 -0
  156. package/types/createNativeMenu/index.d.ts.map +1 -0
  157. package/types/createNativeMenu/utils.d.ts +38 -0
  158. package/types/createNativeMenu/utils.d.ts.map +1 -0
  159. package/types/createNativeMenu/withNativeMenu.d.ts +9 -0
  160. package/types/createNativeMenu/withNativeMenu.d.ts.map +1 -0
  161. package/types/index.d.ts +6 -0
  162. package/types/index.d.ts.map +1 -0
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all) __defProp(target, name, {
9
+ get: all[name],
10
+ enumerable: !0
11
+ });
12
+ },
13
+ __copyProps = (to, from, except, desc) => {
14
+ if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
15
+ get: () => from[key],
16
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
17
+ });
18
+ return to;
19
+ };
20
+ var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
21
+ value: !0
22
+ }), mod);
23
+ var withNativeMenu_exports = {};
24
+ __export(withNativeMenu_exports, {
25
+ withNativeMenu: () => withNativeMenu
26
+ });
27
+ module.exports = __toCommonJS(withNativeMenu_exports);
28
+ var import_jsx_runtime = require("react/jsx-runtime"),
29
+ import_web = require("@tamagui/web");
30
+ function withNativeMenu(param) {
31
+ var {
32
+ Component,
33
+ NativeComponent
34
+ } = param;
35
+ if (import_web.isWeb) return Component;
36
+ var Menu = function (props) {
37
+ return /* @__PURE__ */(0, import_jsx_runtime.jsx)(NativeComponent, {
38
+ ...props
39
+ });
40
+ };
41
+ return Menu.displayName = NativeComponent.displayName || Component.displayName, Menu;
42
+ }
43
+ //# sourceMappingURL=withNativeMenu.native.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["__defProp","Object","defineProperty","__getOwnPropDesc","getOwnPropertyDescriptor","__getOwnPropNames","getOwnPropertyNames","__hasOwnProp","prototype","hasOwnProperty","__export","target","all","name","get","enumerable","__copyProps","to","from","except","desc","key"],"sources":["../../../src/createNativeMenu/withNativeMenu.tsx"],"sourcesContent":[null],"mappings":"AAAA,YAAS;;AA8BE,IAAAA,SAAA,GAAAC,MAAA,CAAAC,cAAA;AApBJ,IAAAC,gBAAS,GAAAF,MAGd,CAAAG,wBAAA;AAAA,IACAC,iBAAA,GAAAJ,MAAA,CAAAK,mBAAA;AAAA,IACAC,YAAA,GAAAN,MAAA,CAAAO,SAAA,CAAAC,cAAA;AACF,IAKkCC,QAAA,GAAAA,CAAAC,MAAA,EAAAC,GAAA;IAGhC,KAAI,IAAAC,IAAA,IAAAD,GAAA,EACFZ,SAAO,CAAAW,MAAA,EAAAE,IAAA;MAAAC,GAAA,EAAAF,GAAA,CAAAC,IAAA;MAAAE,UAAA;IAAA;EAIT;EAAAC,WAAM,GAAyBA,CAAAC,EAAA,EAAAC,IACtB,EAAAC,MAAA,EAAAC,IAAA;IAIT,IAAAF,IAAA,IAAK,OAAAA,IAAA,IAAc,mBAAgBA,IAAA,cAAe,EAGpD,SAAAG,GAAA,IAAAhB,iBAAA,CAAAa,IAAA,G","ignoreList":[]}
@@ -0,0 +1,8 @@
1
+ import "@tamagui/polyfill-dev";
2
+ export * from "./createBaseMenu";
3
+ export * from "./createNativeMenu/index";
4
+ import { MenuPredefined } from "./MenuPredefined";
5
+ export {
6
+ MenuPredefined
7
+ };
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,6 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../src/index.tsx"],
4
+ "mappings": "AAAA,OAAO;AAEP,cAAc;AACd,cAAc;AAKd,SAAS,sBAAsB;",
5
+ "names": []
6
+ }
@@ -0,0 +1,6 @@
1
+ import "@tamagui/polyfill-dev";
2
+ export * from "./createBaseMenu.mjs";
3
+ export * from "./createNativeMenu/index.mjs";
4
+ import { MenuPredefined } from "./MenuPredefined.mjs";
5
+ export { MenuPredefined };
6
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["MenuPredefined"],"sources":["../../src/index.tsx"],"sourcesContent":[null],"mappings":"AAAA,OAAO;AAEP,cAAc;AACd,cAAc;AAKd,SAASA,cAAA,QAAsB","ignoreList":[]}
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all) __defProp(target, name, {
9
+ get: all[name],
10
+ enumerable: !0
11
+ });
12
+ },
13
+ __copyProps = (to, from, except, desc) => {
14
+ if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
15
+ get: () => from[key],
16
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
17
+ });
18
+ return to;
19
+ },
20
+ __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
21
+ var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
22
+ value: !0
23
+ }), mod);
24
+ var index_exports = {};
25
+ __export(index_exports, {
26
+ MenuPredefined: () => import_MenuPredefined.MenuPredefined
27
+ });
28
+ module.exports = __toCommonJS(index_exports);
29
+ var import_polyfill_dev = require("@tamagui/polyfill-dev");
30
+ __reExport(index_exports, require("./createBaseMenu.native.js"), module.exports);
31
+ __reExport(index_exports, require("./createNativeMenu/index.native.js"), module.exports);
32
+ var import_MenuPredefined = require("./MenuPredefined.native.js");
33
+ //# sourceMappingURL=index.native.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["__defProp","Object","defineProperty","__getOwnPropDesc","getOwnPropertyDescriptor","__getOwnPropNames","getOwnPropertyNames"],"sources":["../../src/index.tsx"],"sourcesContent":[null],"mappings":"AAAA,YAAO;;AAEP,IAAAA,SAAA,GAAcC,MAAA,CAAAC,cAAA;AACd,IAAAC,gBAAc,GAAAF,MAAA,CAAAG,wBAAA;AAKd,IAAAC,iBAAS,GAAAJ,MAAA,CAAsBK,mBAAA","ignoreList":[]}
package/package.json ADDED
@@ -0,0 +1,80 @@
1
+ {
2
+ "name": "@tamagui/create-menu",
3
+ "version": "2.0.0-001",
4
+ "type": "module",
5
+ "sideEffects": [
6
+ "*.css"
7
+ ],
8
+ "source": "src/index.tsx",
9
+ "types": "./types/index.d.ts",
10
+ "main": "dist/cjs",
11
+ "module": "dist/esm",
12
+ "module:jsx": "dist/jsx",
13
+ "files": [
14
+ "src",
15
+ "types",
16
+ "dist"
17
+ ],
18
+ "exports": {
19
+ "./package.json": "./package.json",
20
+ ".": {
21
+ "react-native": {
22
+ "import": "./dist/esm/index.native.js",
23
+ "require": "./dist/cjs/index.native.js"
24
+ },
25
+ "types": "./types/index.d.ts",
26
+ "import": "./dist/esm/index.mjs",
27
+ "require": "./dist/cjs/index.cjs",
28
+ "default": "./dist/cjs/index.native.js"
29
+ }
30
+ },
31
+ "scripts": {
32
+ "build": "tamagui-build",
33
+ "watch": "tamagui-build --watch",
34
+ "lint": "biome check src",
35
+ "lint:fix": "biome check --write src",
36
+ "clean": "tamagui-build clean",
37
+ "clean:build": "tamagui-build clean:build"
38
+ },
39
+ "dependencies": {
40
+ "@tamagui/animate": "2.0.0-001",
41
+ "@tamagui/animate-presence": "2.0.0-001",
42
+ "@tamagui/collection": "2.0.0-001",
43
+ "@tamagui/core": "2.0.0-001",
44
+ "@tamagui/dismissable": "2.0.0-001",
45
+ "@tamagui/focus-guard": "2.0.0-001",
46
+ "@tamagui/focus-scope": "2.0.0-001",
47
+ "@tamagui/helpers": "2.0.0-001",
48
+ "@tamagui/image": "2.0.0-001",
49
+ "@tamagui/popover": "2.0.0-001",
50
+ "@tamagui/popper": "2.0.0-001",
51
+ "@tamagui/portal": "2.0.0-001",
52
+ "@tamagui/remove-scroll": "2.0.0-001",
53
+ "@tamagui/roving-focus": "2.0.0-001",
54
+ "@tamagui/use-callback-ref": "2.0.0-001",
55
+ "@tamagui/use-controllable-state": "2.0.0-001",
56
+ "@tamagui/use-direction": "2.0.0-001",
57
+ "@tamagui/web": "2.0.0-001",
58
+ "tamagui": "2.0.0-001"
59
+ },
60
+ "optionalDependencies": {
61
+ "@react-native-menu/menu": "^2.0.0",
62
+ "react-native-ios-context-menu": "^3.2.1",
63
+ "react-native-ios-utilities": "^5.2.0",
64
+ "sf-symbols-typescript": "*",
65
+ "zeego": "^3.0.0"
66
+ },
67
+ "devDependencies": {
68
+ "@tamagui/build": "2.0.0-001",
69
+ "react": "*",
70
+ "react-native": "0.81.5"
71
+ },
72
+ "publishConfig": {
73
+ "access": "public"
74
+ },
75
+ "gitHead": "a49cc7ea6b93ba384e77a4880ae48ac4a5635c14",
76
+ "peerDependencies": {
77
+ "react": "*",
78
+ "react-native": "0.81.5"
79
+ }
80
+ }
@@ -0,0 +1,195 @@
1
+ import { Image } from '@tamagui/image'
2
+ import { styled, Text, View } from '@tamagui/web'
3
+
4
+ /* -------------------------------------------------------------------------------------------------
5
+ * MenuGroup
6
+ * -----------------------------------------------------------------------------------------------*/
7
+
8
+ const GROUP_NAME = 'MenuGroup'
9
+
10
+ const MenuGroup = styled(View, {
11
+ name: GROUP_NAME,
12
+ variants: {
13
+ unstyled: {
14
+ false: {
15
+ role: 'group',
16
+ width: '100%',
17
+ borderRadius: 0,
18
+ borderWidth: 0,
19
+ borderColor: '$borderColor',
20
+ overflow: 'hidden',
21
+ backgroundColor: '$background',
22
+ },
23
+ },
24
+ } as const,
25
+
26
+ defaultVariants: {
27
+ unstyled: process.env.TAMAGUI_HEADLESS === '1',
28
+ },
29
+ })
30
+
31
+ /* -------------------------------------------------------------------------------------------------
32
+ * MenuLabel
33
+ * -----------------------------------------------------------------------------------------------*/
34
+
35
+ const LABEL_NAME = 'MenuLabel'
36
+
37
+ const MenuLabel = styled(Text, {
38
+ name: LABEL_NAME,
39
+
40
+ variants: {
41
+ unstyled: {
42
+ false: {
43
+ cursor: 'default',
44
+ fontSize: 18,
45
+ fontWeight: '600',
46
+ paddingHorizontal: 16,
47
+ paddingVertical: 18,
48
+ },
49
+ },
50
+ } as const,
51
+
52
+ defaultVariants: {
53
+ unstyled: process.env.TAMAGUI_HEADLESS === '1',
54
+ },
55
+ })
56
+
57
+ /* -------------------------------------------------------------------------------------------------
58
+ MenuSeparator
59
+ * -----------------------------------------------------------------------------------------------*/
60
+
61
+ const SEPARATOR_NAME = 'MenuSeparator'
62
+
63
+ const MenuSeparator = styled(View, {
64
+ name: SEPARATOR_NAME,
65
+ role: 'separator',
66
+ // @ts-ignore
67
+ 'aria-orientation': 'horizontal',
68
+
69
+ variants: {
70
+ unstyled: {
71
+ false: {
72
+ borderColor: '$borderColor',
73
+ flexShrink: 0,
74
+ borderWidth: 0,
75
+ flex: 1,
76
+ height: 0,
77
+ gap: 5,
78
+ marginVertical: 8,
79
+ borderBottomWidth: 1,
80
+ width: '100%',
81
+ },
82
+ },
83
+ } as const,
84
+
85
+ defaultVariants: {
86
+ unstyled: process.env.TAMAGUI_HEADLESS === '1',
87
+ },
88
+ })
89
+
90
+ const MenuIcon = styled(View, {
91
+ name: 'MenuIcon',
92
+
93
+ variants: {
94
+ unstyled: {
95
+ false: {
96
+ marginLeft: 'auto',
97
+ },
98
+ },
99
+ } as const,
100
+
101
+ defaultVariants: {
102
+ unstyled: process.env.TAMAGUI_HEADLESS === '1',
103
+ },
104
+ })
105
+
106
+ const MenuImage = styled(Image, { name: 'MenuImage' })
107
+
108
+ const MenuIndicator = styled(View, {
109
+ name: 'MenuIndicator',
110
+
111
+ variants: {
112
+ unstyled: {
113
+ false: {
114
+ justifyContent: 'center',
115
+ alignItems: 'center',
116
+ marginLeft: 'auto',
117
+ },
118
+ },
119
+ } as const,
120
+
121
+ defaultVariants: {
122
+ unstyled: process.env.TAMAGUI_HEADLESS === '1',
123
+ },
124
+ })
125
+
126
+ const MenuItem = styled(View, {
127
+ name: 'MenuItem',
128
+
129
+ variants: {
130
+ unstyled: {
131
+ false: {
132
+ flexDirection: 'row',
133
+ maxWidth: '100%',
134
+ justifyContent: 'space-between',
135
+ paddingVertical: 20,
136
+ alignItems: 'center',
137
+ gap: 12,
138
+ cursor: 'pointer',
139
+ },
140
+ },
141
+ } as const,
142
+
143
+ defaultVariants: {
144
+ unstyled: process.env.TAMAGUI_HEADLESS === '1',
145
+ },
146
+ })
147
+
148
+ const Title = styled(Text, {
149
+ name: 'MenuTitle',
150
+
151
+ variants: {
152
+ unstyled: {
153
+ false: {
154
+ cursor: 'default',
155
+ fontSize: 16,
156
+ fontWeight: '500',
157
+ color: '$color',
158
+ },
159
+ },
160
+ } as const,
161
+
162
+ defaultVariants: {
163
+ unstyled: process.env.TAMAGUI_HEADLESS === '1',
164
+ },
165
+ })
166
+
167
+ const SubTitle = styled(Text, {
168
+ name: 'MenuSubTitle',
169
+
170
+ variants: {
171
+ unstyled: {
172
+ false: {
173
+ cursor: 'default',
174
+ fontSize: 14,
175
+ color: '$colorFaint',
176
+ },
177
+ },
178
+ } as const,
179
+
180
+ defaultVariants: {
181
+ unstyled: process.env.TAMAGUI_HEADLESS === '1',
182
+ },
183
+ })
184
+
185
+ export const MenuPredefined = {
186
+ MenuIcon,
187
+ MenuImage,
188
+ MenuIndicator,
189
+ MenuItem,
190
+ Title,
191
+ SubTitle,
192
+ MenuGroup,
193
+ MenuSeparator,
194
+ MenuLabel,
195
+ }