@onetype/framework 2.0.40 → 2.0.42

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 (120) hide show
  1. package/addons/ai/agents/addon.js +23 -0
  2. package/addons/ai/agents/functions/parse.js +129 -0
  3. package/addons/ai/agents/item/functions/run.js +218 -0
  4. package/addons/ai/agents/load.js +8 -0
  5. package/addons/ai/orchestrator/addon.js +25 -0
  6. package/addons/ai/orchestrator/item/functions/run.js +277 -0
  7. package/addons/ai/orchestrator/item/functions/state/agent.js +41 -0
  8. package/addons/ai/orchestrator/item/functions/state/conclusion.js +27 -0
  9. package/addons/ai/orchestrator/item/functions/state/done.js +40 -0
  10. package/addons/ai/orchestrator/item/functions/state/execute.js +16 -0
  11. package/addons/ai/orchestrator/item/functions/state/goal.js +34 -0
  12. package/addons/ai/orchestrator/item/functions/state/input.js +55 -0
  13. package/addons/ai/orchestrator/item/functions/state/summary.js +26 -0
  14. package/addons/ai/orchestrator/items/agents/achievable.js +37 -0
  15. package/addons/ai/orchestrator/items/agents/agent.js +46 -0
  16. package/addons/ai/orchestrator/items/agents/conclusion.js +41 -0
  17. package/addons/ai/orchestrator/items/agents/done.js +40 -0
  18. package/addons/ai/orchestrator/items/agents/goal.js +58 -0
  19. package/addons/ai/orchestrator/items/agents/input.js +34 -0
  20. package/addons/ai/orchestrator/items/agents/planner.js +30 -0
  21. package/addons/ai/orchestrator/items/agents/summary.js +29 -0
  22. package/addons/ai/orchestrator/items/chat.js +10 -0
  23. package/addons/ai/orchestrator/load.js +25 -0
  24. package/addons/ai/providers/addon.js +16 -0
  25. package/addons/ai/providers/functions/default.js +14 -0
  26. package/addons/ai/providers/item/functions/request.js +62 -0
  27. package/addons/ai/providers/items/nue.js +98 -0
  28. package/addons/ai/providers/load.js +10 -0
  29. package/addons/render/elements/front/functions/runtime.js +25 -0
  30. package/addons/render/transforms/item/functions/run.js +6 -2
  31. package/lib/browser.js +1 -24
  32. package/lib/items/directives/160-slot.js +1 -1
  33. package/lib/items/directives/500-click-outside.js +43 -43
  34. package/lib/items/elements/ai/chat/chat.css +710 -0
  35. package/lib/items/elements/ai/chat/chat.js +429 -0
  36. package/lib/items/elements/cards/pricing/pricing.css +174 -0
  37. package/lib/items/elements/{sections → cards}/pricing/pricing.js +30 -11
  38. package/lib/items/elements/form/button/button.css +250 -0
  39. package/lib/items/elements/form/button/button.js +15 -20
  40. package/lib/items/elements/form/checkbox/checkbox.css +109 -0
  41. package/lib/items/elements/form/checkbox/checkbox.js +58 -54
  42. package/lib/items/elements/form/color/color.css +128 -0
  43. package/lib/items/elements/form/color/color.js +100 -0
  44. package/lib/items/elements/form/date/date.css +84 -0
  45. package/lib/items/elements/form/date/date.js +69 -0
  46. package/lib/items/elements/form/field/field.css +33 -57
  47. package/lib/items/elements/form/field/field.js +4 -4
  48. package/lib/items/elements/form/input/input.css +59 -84
  49. package/lib/items/elements/form/input/input.js +84 -75
  50. package/lib/items/elements/form/radio/radio.css +118 -0
  51. package/lib/items/elements/form/radio/radio.js +58 -54
  52. package/lib/items/elements/form/rating/rating.css +28 -66
  53. package/lib/items/elements/form/rating/rating.js +17 -21
  54. package/lib/items/elements/form/section/section.css +30 -73
  55. package/lib/items/elements/form/section/section.js +5 -5
  56. package/lib/items/elements/form/select/select.css +186 -0
  57. package/lib/items/elements/form/select/select.js +165 -0
  58. package/lib/items/elements/form/slider/slider.css +55 -176
  59. package/lib/items/elements/form/slider/slider.js +14 -10
  60. package/lib/items/elements/form/tags/tags.css +152 -0
  61. package/lib/items/elements/form/tags/tags.js +166 -0
  62. package/lib/items/elements/form/textarea/textarea.css +55 -92
  63. package/lib/items/elements/form/textarea/textarea.js +74 -66
  64. package/lib/items/elements/form/toggle/toggle.css +101 -0
  65. package/lib/items/elements/form/toggle/toggle.js +67 -0
  66. package/lib/items/elements/global/code/code.css +39 -8
  67. package/lib/items/elements/global/code/code.js +7 -2
  68. package/lib/items/elements/global/faq/faq.css +38 -16
  69. package/lib/items/elements/global/faq/faq.js +14 -2
  70. package/lib/items/elements/global/heading/heading.css +37 -14
  71. package/lib/items/elements/global/heading/heading.js +9 -4
  72. package/lib/items/elements/global/markdown/markdown.css +22 -15
  73. package/lib/items/elements/global/markdown/markdown.js +4 -4
  74. package/lib/items/elements/global/menu/menu.css +173 -0
  75. package/lib/items/elements/global/menu/menu.js +103 -0
  76. package/lib/items/elements/global/notice/notice.css +27 -61
  77. package/lib/items/elements/global/notice/notice.js +4 -4
  78. package/lib/items/elements/global/parameters/parameters.css +33 -14
  79. package/lib/items/elements/global/parameters/parameters.js +15 -6
  80. package/lib/items/elements/global/tags/tags.css +18 -5
  81. package/lib/items/elements/global/tags/tags.js +10 -2
  82. package/lib/items/elements/navigation/navbar/navbar.css +39 -17
  83. package/lib/items/elements/navigation/navbar/navbar.js +19 -9
  84. package/lib/items/elements/navigation/sidebar/sidebar.css +25 -39
  85. package/lib/items/elements/navigation/sidebar/sidebar.js +28 -6
  86. package/lib/items/elements/navigation/tabs/tabs.css +35 -16
  87. package/lib/items/elements/navigation/tabs/tabs.js +16 -2
  88. package/lib/items/elements/status/code/code.css +21 -12
  89. package/lib/items/elements/status/empty/empty.css +22 -17
  90. package/lib/items/elements/status/empty/empty.js +1 -1
  91. package/lib/items/elements/status/error/error.css +22 -12
  92. package/lib/items/elements/status/error/error.js +1 -1
  93. package/lib/items/elements/status/loading/loading.css +24 -14
  94. package/lib/items/elements/status/loading/loading.js +4 -4
  95. package/lib/load.js +14 -6
  96. package/lib/styles/reset.css +1 -1
  97. package/lists.md +586 -0
  98. package/orchestrator.md +288 -0
  99. package/package.json +9 -3
  100. package/lib/items/elements/form/button/styles/base.css +0 -176
  101. package/lib/items/elements/form/button/styles/sizes.css +0 -78
  102. package/lib/items/elements/form/button/styles/variants.css +0 -421
  103. package/lib/items/elements/form/checkbox/styles/base.css +0 -52
  104. package/lib/items/elements/form/checkbox/styles/sizes.css +0 -39
  105. package/lib/items/elements/form/checkbox/styles/variants.css +0 -121
  106. package/lib/items/elements/form/input/styles/base.css +0 -26
  107. package/lib/items/elements/form/input/styles/sizes.css +0 -15
  108. package/lib/items/elements/form/input/styles/variants.css +0 -98
  109. package/lib/items/elements/form/radio/styles/base.css +0 -48
  110. package/lib/items/elements/form/radio/styles/sizes.css +0 -36
  111. package/lib/items/elements/form/radio/styles/variants.css +0 -121
  112. package/lib/items/elements/global/card/card.css +0 -57
  113. package/lib/items/elements/global/card/card.js +0 -48
  114. package/lib/items/elements/sections/footer/footer.css +0 -205
  115. package/lib/items/elements/sections/footer/footer.js +0 -109
  116. package/lib/items/elements/sections/hero/hero.css +0 -100
  117. package/lib/items/elements/sections/hero/hero.js +0 -54
  118. package/lib/items/elements/sections/pricing/pricing.css +0 -148
  119. package/lib/items/elements/sections/stats/stats.css +0 -34
  120. package/lib/items/elements/sections/stats/stats.js +0 -74
@@ -1,16 +1,20 @@
1
+ /* Root */
2
+
1
3
  .e-e204b7e
2
4
  {
3
5
  display: flex;
4
6
  width: 100%;
5
7
  }
6
8
 
9
+ /* Holder */
10
+
7
11
  .e-e204b7e > .holder
8
12
  {
9
13
  display: flex;
10
14
  flex-direction: column;
11
15
  width: 100%;
12
- border: 1px solid var(--ot-bg-2-border);
13
- border-radius: 8px;
16
+ border: 1px solid transparent;
17
+ border-radius: var(--ot-radius-m);
14
18
  overflow: hidden;
15
19
  }
16
20
 
@@ -21,7 +25,7 @@
21
25
  display: flex;
22
26
  flex-direction: column;
23
27
  cursor: pointer;
24
- border-bottom: 1px solid var(--ot-bg-2-border);
28
+ border-bottom: 1px solid transparent;
25
29
  transition: background 0.15s ease;
26
30
  }
27
31
 
@@ -30,16 +34,6 @@
30
34
  border-bottom: none;
31
35
  }
32
36
 
33
- .e-e204b7e > .holder > .item:hover
34
- {
35
- background: var(--ot-bg-2);
36
- }
37
-
38
- .e-e204b7e > .holder > .item.active
39
- {
40
- background: var(--ot-bg-2);
41
- }
42
-
43
37
  /* Question */
44
38
 
45
39
  .e-e204b7e > .holder > .item > .question
@@ -48,7 +42,7 @@
48
42
  align-items: center;
49
43
  justify-content: space-between;
50
44
  gap: var(--ot-spacing-s);
51
- padding: var(--ot-spacing-s) var(--ot-spacing-m);
45
+ padding: var(--ot-spacing-m);
52
46
  }
53
47
 
54
48
  .e-e204b7e > .holder > .item > .question > .text
@@ -60,7 +54,7 @@
60
54
 
61
55
  .e-e204b7e > .holder > .item > .question > .icon
62
56
  {
63
- font-size: 20px;
57
+ font-size: var(--ot-size-l);
64
58
  color: var(--ot-text-2);
65
59
  flex-shrink: 0;
66
60
  }
@@ -69,8 +63,36 @@
69
63
 
70
64
  .e-e204b7e > .holder > .item > .answer
71
65
  {
72
- padding: 0 var(--ot-spacing-m) var(--ot-spacing-s);
66
+ padding: 0 var(--ot-spacing-m) var(--ot-spacing-m);
73
67
  font-size: var(--ot-size-m);
74
68
  color: var(--ot-text-2);
75
69
  line-height: 1.6;
76
70
  }
71
+
72
+ /* Background variants */
73
+
74
+ .e-e204b7e > .holder.bg-1 { background: var(--ot-bg-1); border-color: var(--ot-bg-1-border); }
75
+ .e-e204b7e > .holder.bg-1 > .item { border-bottom-color: var(--ot-bg-1-border); }
76
+ .e-e204b7e > .holder.bg-1 > .item:hover, .e-e204b7e > .holder.bg-1 > .item.active { background: var(--ot-bg-1-hover); }
77
+ .e-e204b7e > .holder.bg-2 { background: var(--ot-bg-2); border-color: var(--ot-bg-2-border); }
78
+ .e-e204b7e > .holder.bg-2 > .item { border-bottom-color: var(--ot-bg-2-border); }
79
+ .e-e204b7e > .holder.bg-2 > .item:hover, .e-e204b7e > .holder.bg-2 > .item.active { background: var(--ot-bg-2-hover); }
80
+ .e-e204b7e > .holder.bg-3 { background: var(--ot-bg-3); border-color: var(--ot-bg-3-border); }
81
+ .e-e204b7e > .holder.bg-3 > .item { border-bottom-color: var(--ot-bg-3-border); }
82
+ .e-e204b7e > .holder.bg-3 > .item:hover, .e-e204b7e > .holder.bg-3 > .item.active { background: var(--ot-bg-3-hover); }
83
+ .e-e204b7e > .holder.bg-4 { background: var(--ot-bg-4); border-color: var(--ot-bg-4-border); }
84
+ .e-e204b7e > .holder.bg-4 > .item { border-bottom-color: var(--ot-bg-4-border); }
85
+ .e-e204b7e > .holder.bg-4 > .item:hover, .e-e204b7e > .holder.bg-4 > .item.active { background: var(--ot-bg-4-hover); }
86
+
87
+ /* Size variants */
88
+
89
+ .e-e204b7e > .holder.size-s > .item > .question { padding: var(--ot-spacing-s); }
90
+ .e-e204b7e > .holder.size-s > .item > .answer { padding: 0 var(--ot-spacing-s) var(--ot-spacing-s); font-size: var(--ot-size-s); }
91
+ .e-e204b7e > .holder.size-m > .item > .question { padding: var(--ot-spacing-m); }
92
+ .e-e204b7e > .holder.size-m > .item > .answer { padding: 0 var(--ot-spacing-m) var(--ot-spacing-m); }
93
+ .e-e204b7e > .holder.size-l > .item > .question { padding: var(--ot-spacing-l); }
94
+ .e-e204b7e > .holder.size-l > .item > .answer { padding: 0 var(--ot-spacing-l) var(--ot-spacing-l); }
95
+
96
+ /* Border variant */
97
+
98
+ .e-e204b7e > .holder.border { border: 1px solid var(--ot-bg-2-border); }
@@ -10,7 +10,19 @@ onetype.AddonReady('elements', (elements) =>
10
10
  config: {
11
11
  items: {
12
12
  type: 'array',
13
- value: []
13
+ value: [],
14
+ each: {
15
+ type: 'object',
16
+ config: {
17
+ question: { type: 'string', value: '' },
18
+ answer: { type: 'string', value: '' }
19
+ }
20
+ }
21
+ },
22
+ variant: {
23
+ type: 'array',
24
+ value: ['bg-2'],
25
+ options: ['bg-1', 'bg-2', 'bg-3', 'bg-4', 'border', 'size-s', 'size-m', 'size-l']
14
26
  }
15
27
  },
16
28
  render: function()
@@ -29,7 +41,7 @@ onetype.AddonReady('elements', (elements) =>
29
41
  };
30
42
 
31
43
  return `
32
- <div class="holder">
44
+ <div :class="'holder ' + variant.join(' ')">
33
45
  <div ot-for="item, index in items" :class="'item' + (isOpen(index) ? ' active' : '')" ot-click="toggle(index)">
34
46
  <div class="question">
35
47
  <span class="text">{{ item.question }}</span>
@@ -8,40 +8,63 @@
8
8
  {
9
9
  width: 100%;
10
10
  display: flex;
11
- flex-direction: column;
12
- gap: var(--ot-spacing-x);
11
+ align-items: center;
12
+ justify-content: space-between;
13
+ gap: var(--ot-spacing-m);
13
14
  border-bottom: 1px solid var(--ot-bg-2-border);
14
15
  padding-bottom: var(--ot-spacing-m);
15
16
  }
16
17
 
17
- .e-49fb116e > .holder > .icon
18
+ .e-49fb116e > .holder > .text
19
+ {
20
+ display: flex;
21
+ flex-direction: column;
22
+ gap: var(--ot-spacing-x);
23
+ }
24
+
25
+ .e-49fb116e > .holder > .text > .icon
18
26
  {
19
27
  font-size: 36px;
20
28
  color: var(--ot-text-2);
21
29
  }
22
30
 
23
- .e-49fb116e > .holder > .title
31
+ .e-49fb116e > .holder > .text > .title
24
32
  {
25
33
  font-size: 18px;
26
34
  font-weight: 600;
27
35
  color: var(--ot-text-1);
28
36
  }
29
37
 
30
- .e-49fb116e > .holder > .description
38
+ .e-49fb116e > .holder > .text > .description
31
39
  {
32
40
  font-size: var(--ot-size-m);
33
41
  color: var(--ot-text-2);
34
42
  }
35
43
 
44
+ .e-49fb116e > .holder > .right
45
+ {
46
+ flex-shrink: 0;
47
+ }
48
+
49
+ .e-49fb116e > .holder > .right:empty
50
+ {
51
+ display: none;
52
+ }
53
+
36
54
  /* Alignment */
37
55
 
38
56
  .e-49fb116e > .holder.center
57
+ {
58
+ justify-content: center;
59
+ }
60
+
61
+ .e-49fb116e > .holder.center > .text
39
62
  {
40
63
  align-items: center;
41
64
  text-align: center;
42
65
  }
43
66
 
44
- .e-49fb116e > .holder.right
67
+ .e-49fb116e > .holder.right > .text
45
68
  {
46
69
  align-items: flex-end;
47
70
  text-align: right;
@@ -61,7 +84,7 @@
61
84
  padding-bottom: 0;
62
85
  }
63
86
 
64
- .e-49fb116e > .holder.page > .title
87
+ .e-49fb116e > .holder.page > .text > .title
65
88
  {
66
89
  font-size: 36px;
67
90
  font-weight: 800;
@@ -69,38 +92,38 @@
69
92
 
70
93
  /* Sizes */
71
94
 
72
- .e-49fb116e > .holder.size-s > .title
95
+ .e-49fb116e > .holder.size-s > .text > .title
73
96
  {
74
97
  font-size: 16px;
75
98
  }
76
99
 
77
- .e-49fb116e > .holder.size-s > .description
100
+ .e-49fb116e > .holder.size-s > .text > .description
78
101
  {
79
102
  font-size: var(--ot-size-s);
80
103
  }
81
104
 
82
- .e-49fb116e > .holder.size-m > .title
105
+ .e-49fb116e > .holder.size-m > .text > .title
83
106
  {
84
107
  font-size: 25px;
85
108
  font-weight: 700;
86
109
  }
87
110
 
88
- .e-49fb116e > .holder.size-m > .description
111
+ .e-49fb116e > .holder.size-m > .text > .description
89
112
  {
90
113
  font-size: var(--ot-size-m);
91
114
  line-height: 1.6;
92
115
  max-width: 500px;
93
116
  }
94
117
 
95
- .e-49fb116e > .holder.size-l > .title
118
+ .e-49fb116e > .holder.size-l > .text > .title
96
119
  {
97
120
  font-size: 36px;
98
121
  font-weight: 800;
99
122
  }
100
123
 
101
- .e-49fb116e > .holder.size-l > .description
124
+ .e-49fb116e > .holder.size-l > .text > .description
102
125
  {
103
126
  font-size: var(--ot-size-l);
104
127
  line-height: 1.6;
105
128
  max-width: 600px;
106
- }
129
+ }
@@ -41,10 +41,15 @@ onetype.AddonReady('elements', (elements) =>
41
41
 
42
42
  return `
43
43
  <div :class="classes">
44
- <i ot-if="icon" class="icon">{{ icon }}</i>
45
- <h2 ot-if="variant !== 'page'" class="title">{{ title }}</h2>
46
- <h1 ot-if="variant === 'page'" class="title">{{ title }}</h1>
47
- <p ot-if="description" class="description">{{ description }}</p>
44
+ <div class="text">
45
+ <i ot-if="icon" class="icon">{{ icon }}</i>
46
+ <h2 ot-if="variant !== 'page'" class="title">{{ title }}</h2>
47
+ <h1 ot-if="variant === 'page'" class="title">{{ title }}</h1>
48
+ <p ot-if="description" class="description">{{ description }}</p>
49
+ </div>
50
+ <div class="right">
51
+ <slot name="right"></slot>
52
+ </div>
48
53
  </div>
49
54
  `;
50
55
  }
@@ -1,9 +1,13 @@
1
+ /* Root */
2
+
1
3
  .e-4696d703
2
4
  {
3
5
  display: flex;
4
6
  width: 100%;
5
7
  }
6
8
 
9
+ /* Holder */
10
+
7
11
  .e-4696d703 > .holder
8
12
  {
9
13
  display: flex;
@@ -12,13 +16,16 @@
12
16
  width: 100%;
13
17
  }
14
18
 
15
- .e-4696d703 > .holder[variant="bg-2"]
16
- {
17
- background: var(--ot-bg-2);
18
- border: 1px solid var(--ot-bg-2-border);
19
- border-radius: var(--ot-radius-m);
20
- padding: var(--ot-spacing-m);
21
- }
19
+ /* Background variants */
20
+
21
+ .e-4696d703 > .holder.bg-1 { background: var(--ot-bg-1); border: 1px solid var(--ot-bg-1-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
22
+ .e-4696d703 > .holder.bg-2 { background: var(--ot-bg-2); border: 1px solid var(--ot-bg-2-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
23
+ .e-4696d703 > .holder.bg-3 { background: var(--ot-bg-3); border: 1px solid var(--ot-bg-3-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
24
+ .e-4696d703 > .holder.bg-4 { background: var(--ot-bg-4); border: 1px solid var(--ot-bg-4-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
25
+
26
+ /* Border variant */
27
+
28
+ .e-4696d703 > .holder.border { border: 1px solid var(--ot-bg-2-border); border-radius: var(--ot-radius-m); padding: var(--ot-spacing-m); }
22
29
 
23
30
  /* Line wrapper */
24
31
 
@@ -119,7 +126,7 @@
119
126
  display: flex;
120
127
  flex-direction: column;
121
128
  gap: var(--ot-spacing-x);
122
- padding-left: 24px;
129
+ padding-left: var(--ot-spacing-l);
123
130
  margin: 0;
124
131
  }
125
132
 
@@ -152,7 +159,7 @@
152
159
  border-left: 3px solid var(--ot-brand);
153
160
  padding: var(--ot-spacing-s) var(--ot-spacing-m);
154
161
  background: var(--ot-bg-2);
155
- border-radius: 0 8px 8px 0;
162
+ border-radius: 0 var(--ot-radius-m) var(--ot-radius-m) 0;
156
163
  margin: 0;
157
164
  font-size: var(--ot-size-m);
158
165
  color: var(--ot-text-2);
@@ -164,8 +171,8 @@
164
171
 
165
172
  .e-4696d703 > .holder code.inline
166
173
  {
167
- padding: 2px 7px;
168
- border-radius: 4px;
174
+ padding: var(--ot-spacing-x) var(--ot-spacing-s);
175
+ border-radius: var(--ot-radius-s);
169
176
  background: var(--ot-bg-2);
170
177
  border: 1px solid var(--ot-bg-2-border);
171
178
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
@@ -180,7 +187,7 @@
180
187
  position: relative;
181
188
  background: var(--ot-bg-2);
182
189
  border: 1px solid var(--ot-bg-2-border);
183
- border-radius: 8px;
190
+ border-radius: var(--ot-radius-m);
184
191
  padding: var(--ot-spacing-m);
185
192
  overflow-x: auto;
186
193
  margin: 0;
@@ -189,7 +196,7 @@
189
196
  .e-4696d703 > .holder .codeblock > code
190
197
  {
191
198
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
192
- font-size: 13px;
199
+ font-size: var(--ot-size-m);
193
200
  line-height: 1.7;
194
201
  color: var(--ot-text-1);
195
202
  tab-size: 4;
@@ -201,7 +208,7 @@
201
208
  {
202
209
  width: 100%;
203
210
  border-collapse: collapse;
204
- border-radius: 8px;
211
+ border-radius: var(--ot-radius-m);
205
212
  background-color: var(--ot-bg-2);
206
213
  overflow: hidden;
207
214
  }
@@ -251,6 +258,6 @@
251
258
  {
252
259
  max-width: 100%;
253
260
  height: auto;
254
- border-radius: 8px;
261
+ border-radius: var(--ot-radius-m);
255
262
  border: 1px solid var(--ot-bg-2-border);
256
263
  }
@@ -219,14 +219,14 @@ onetype.AddonReady('elements', (elements) =>
219
219
  value: ''
220
220
  },
221
221
  variant: {
222
- type: 'string',
223
- value: '',
224
- options: ['', 'bg-2']
222
+ type: 'array',
223
+ value: [],
224
+ options: ['bg-1', 'bg-2', 'bg-3', 'bg-4', 'border']
225
225
  }
226
226
  },
227
227
  render: function()
228
228
  {
229
- return `<div class="holder" :variant="variant">${parse(this.content)}</div>`;
229
+ return `<div :class="'holder ' + variant.join(' ')">${parse(this.content)}</div>`;
230
230
  }
231
231
  });
232
232
  });
@@ -0,0 +1,173 @@
1
+ /* Root */
2
+
3
+ .e-4a1a1973
4
+ {
5
+ display: flex;
6
+ width: 100%;
7
+ }
8
+
9
+ .e-4a1a1973 .e-4a1a1973
10
+ {
11
+ flex-direction: column;
12
+ padding-left: var(--ot-spacing-m);
13
+ }
14
+
15
+ /* Holder */
16
+
17
+ .e-4a1a1973 > .holder
18
+ {
19
+ display: flex;
20
+ flex-direction: column;
21
+ width: 100%;
22
+ padding: var(--ot-spacing-x) 0;
23
+ border: 1px solid transparent;
24
+ border-radius: var(--ot-radius-m);
25
+ overflow: hidden;
26
+ }
27
+
28
+ /* Entry */
29
+
30
+ .e-4a1a1973 .entry
31
+ {
32
+ display: flex;
33
+ flex-direction: column;
34
+ }
35
+
36
+ /* Content (clickable row) */
37
+
38
+ .e-4a1a1973 .entry > .content
39
+ {
40
+ display: flex;
41
+ align-items: center;
42
+ gap: var(--ot-spacing-s);
43
+ padding: 0 var(--ot-spacing-m);
44
+ padding-left: calc(var(--ot-spacing-m) + var(--ot-spacing-m) * var(--depth, 0));
45
+ height: var(--ot-height-m);
46
+ cursor: pointer;
47
+ user-select: none;
48
+ transition: background 0.1s ease;
49
+ }
50
+
51
+ .e-4a1a1973 .entry > .content:hover
52
+ {
53
+ background: var(--ot-bg-1-hover);
54
+ }
55
+
56
+ .e-4a1a1973 .entry.disabled > .content
57
+ {
58
+ opacity: 0.4;
59
+ cursor: not-allowed;
60
+ pointer-events: none;
61
+ }
62
+
63
+ /* Icon */
64
+
65
+ .e-4a1a1973 .entry > .content > .icon
66
+ {
67
+ font-size: var(--ot-size-m);
68
+ color: var(--ot-text-2);
69
+ width: 20px;
70
+ text-align: center;
71
+ flex-shrink: 0;
72
+ }
73
+
74
+ /* Label */
75
+
76
+ .e-4a1a1973 .entry > .content > .label
77
+ {
78
+ font-size: var(--ot-size-m);
79
+ color: var(--ot-text-1);
80
+ flex: 1;
81
+ white-space: nowrap;
82
+ overflow: hidden;
83
+ text-overflow: ellipsis;
84
+ }
85
+
86
+ /* Shortcut */
87
+
88
+ .e-4a1a1973 .entry > .content > .shortcut
89
+ {
90
+ font-size: var(--ot-size-s);
91
+ color: var(--ot-text-2);
92
+ opacity: 0.6;
93
+ flex-shrink: 0;
94
+ margin-left: var(--ot-spacing-l);
95
+ letter-spacing: 0.02em;
96
+ }
97
+
98
+ /* Arrow */
99
+
100
+ .e-4a1a1973 .entry > .content > .arrow
101
+ {
102
+ font-size: var(--ot-size-m);
103
+ color: var(--ot-text-2);
104
+ flex-shrink: 0;
105
+ margin-left: auto;
106
+ transition: color 0.15s ease;
107
+ }
108
+
109
+ .e-4a1a1973 .entry.open > .content > .arrow
110
+ {
111
+ color: var(--ot-text-1);
112
+ }
113
+
114
+ /* Separator */
115
+
116
+ .e-4a1a1973 .entry > .separator
117
+ {
118
+ height: 1px;
119
+ margin: var(--ot-spacing-x) var(--ot-spacing-m);
120
+ background: var(--ot-bg-2-border);
121
+ }
122
+
123
+ /* Header */
124
+
125
+ .e-4a1a1973 .entry > .header
126
+ {
127
+ font-size: var(--ot-size-s);
128
+ font-weight: 600;
129
+ color: var(--ot-text-2);
130
+ padding: var(--ot-spacing-s) var(--ot-spacing-m) var(--ot-spacing-x);
131
+ user-select: none;
132
+ text-transform: uppercase;
133
+ letter-spacing: 0.04em;
134
+ }
135
+
136
+ /* Background variants */
137
+
138
+ .e-4a1a1973 > .holder.bg-1 { background: var(--ot-bg-1); border-color: var(--ot-bg-1-border); }
139
+ .e-4a1a1973 > .holder.bg-1 .entry > .content:hover { background: var(--ot-bg-1-hover); }
140
+ .e-4a1a1973 > .holder.bg-1 .entry > .separator { background: var(--ot-bg-1-border); }
141
+
142
+ .e-4a1a1973 > .holder.bg-2 { background: var(--ot-bg-2); border-color: var(--ot-bg-2-border); }
143
+ .e-4a1a1973 > .holder.bg-2 .entry > .content:hover { background: var(--ot-bg-2-hover); }
144
+ .e-4a1a1973 > .holder.bg-2 .entry > .separator { background: var(--ot-bg-2-border); }
145
+
146
+ .e-4a1a1973 > .holder.bg-3 { background: var(--ot-bg-3); border-color: var(--ot-bg-3-border); }
147
+ .e-4a1a1973 > .holder.bg-3 .entry > .content:hover { background: var(--ot-bg-3-hover); }
148
+ .e-4a1a1973 > .holder.bg-3 .entry > .separator { background: var(--ot-bg-3-border); }
149
+
150
+ .e-4a1a1973 > .holder.bg-4 { background: var(--ot-bg-4); border-color: var(--ot-bg-4-border); }
151
+ .e-4a1a1973 > .holder.bg-4 .entry > .content:hover { background: var(--ot-bg-4-hover); }
152
+ .e-4a1a1973 > .holder.bg-4 .entry > .separator { background: var(--ot-bg-4-border); }
153
+
154
+ /* Border variant */
155
+
156
+ .e-4a1a1973 > .holder.border { border: 1px solid var(--ot-bg-2-border); }
157
+
158
+ /* Size variants */
159
+
160
+ .e-4a1a1973 > .holder.size-s .entry > .content { height: var(--ot-height-s); padding: 0 var(--ot-spacing-s); gap: var(--ot-spacing-x); }
161
+ .e-4a1a1973 > .holder.size-s .entry > .content > .icon { font-size: var(--ot-size-s); width: 16px; }
162
+ .e-4a1a1973 > .holder.size-s .entry > .content > .label { font-size: var(--ot-size-s); }
163
+ .e-4a1a1973 > .holder.size-s .entry > .content > .shortcut { font-size: 10px; }
164
+ .e-4a1a1973 > .holder.size-s .entry > .header { font-size: 10px; padding: var(--ot-spacing-x) var(--ot-spacing-s) 2px; }
165
+ .e-4a1a1973 > .holder.size-s .entry > .separator { margin: 2px var(--ot-spacing-s); }
166
+
167
+ .e-4a1a1973 > .holder.size-m .entry > .content { height: var(--ot-height-m); }
168
+
169
+ .e-4a1a1973 > .holder.size-l .entry > .content { height: var(--ot-height-l); padding: 0 var(--ot-spacing-l); gap: var(--ot-spacing-m); }
170
+ .e-4a1a1973 > .holder.size-l .entry > .content > .icon { font-size: var(--ot-size-l); width: 28px; }
171
+ .e-4a1a1973 > .holder.size-l .entry > .content > .label { font-size: var(--ot-size-m); }
172
+ .e-4a1a1973 > .holder.size-l .entry > .header { font-size: var(--ot-size-s); padding: var(--ot-spacing-m) var(--ot-spacing-l) var(--ot-spacing-x); }
173
+ .e-4a1a1973 > .holder.size-l .entry > .separator { margin: var(--ot-spacing-x) var(--ot-spacing-l); }
@@ -0,0 +1,103 @@
1
+ onetype.AddonReady('elements', (elements) =>
2
+ {
3
+ elements.ItemAdd({
4
+ id: 'global-menu',
5
+ icon: 'menu',
6
+ name: 'Menu',
7
+ description: 'Multi-level menu with icons, shortcuts, headers and separators.',
8
+ category: 'Global',
9
+ author: 'OneType',
10
+ config: {
11
+ items: {
12
+ type: 'array',
13
+ value: [],
14
+ each: {
15
+ type: 'object',
16
+ config: {
17
+ type: { type: 'string', value: 'action', options: ['action', 'separator', 'header'] },
18
+ icon: { type: 'string', value: '' },
19
+ label: { type: 'string', value: '' },
20
+ value: { type: 'string', value: '' },
21
+ shortcut: { type: 'string', value: '' },
22
+ disabled: { type: 'boolean', value: false },
23
+ items: { type: 'array', value: [] }
24
+ }
25
+ }
26
+ },
27
+ depth: {
28
+ type: 'number',
29
+ value: 0
30
+ },
31
+ variant: {
32
+ type: 'array',
33
+ value: ['bg-2', 'size-m'],
34
+ options: ['bg-1', 'bg-2', 'bg-3', 'bg-4', 'border', 'size-s', 'size-m', 'size-l']
35
+ },
36
+ _select: {
37
+ type: 'function'
38
+ }
39
+ },
40
+ render: function()
41
+ {
42
+ this.opened = {};
43
+
44
+ this.toggle = (index) =>
45
+ {
46
+ this.opened[index] = !this.opened[index];
47
+ this.Update();
48
+ };
49
+
50
+ this.isOpen = (index) =>
51
+ {
52
+ return !!this.opened[index];
53
+ };
54
+
55
+ this.select = (item) =>
56
+ {
57
+ if (item.disabled)
58
+ {
59
+ return;
60
+ }
61
+
62
+ if (this._select)
63
+ {
64
+ this._select(item.value || item.label);
65
+ }
66
+ };
67
+
68
+ this.hasChildren = (item) =>
69
+ {
70
+ return item.items && item.items.length > 0;
71
+ };
72
+
73
+ const items = `
74
+ <div ot-for="item, index in items" :class="'entry ' + item.type + (item.disabled ? ' disabled' : '') + (hasChildren(item) ? ' parent' : '') + (isOpen(index) ? ' open' : '')">
75
+ <div ot-if="item.type === 'separator'" class="separator"></div>
76
+ <div ot-if="item.type === 'header'" class="header">{{ item.label }}</div>
77
+ <div ot-if="item.type === 'action' && hasChildren(item)" class="content" ot-click="toggle(index)">
78
+ <i ot-if="item.icon" class="icon">{{ item.icon }}</i>
79
+ <span class="label">{{ item.label }}</span>
80
+ <i class="arrow">{{ isOpen(index) ? 'expand_less' : 'expand_more' }}</i>
81
+ </div>
82
+ <div ot-if="item.type === 'action' && !hasChildren(item)" class="content" ot-click="select(item)">
83
+ <i ot-if="item.icon" class="icon">{{ item.icon }}</i>
84
+ <span class="label">{{ item.label }}</span>
85
+ <span ot-if="item.shortcut" class="shortcut">{{ item.shortcut }}</span>
86
+ </div>
87
+ <e-global-menu ot-if="hasChildren(item) && isOpen(index)" :items="item.items" :depth="depth + 1" :_select="_select" :style="'--depth: ' + (depth + 1)"></e-global-menu>
88
+ </div>
89
+ `;
90
+
91
+ if (this.depth > 0)
92
+ {
93
+ return items;
94
+ }
95
+
96
+ return `
97
+ <div :class="'holder ' + variant.join(' ')">
98
+ ${items}
99
+ </div>
100
+ `;
101
+ }
102
+ });
103
+ });