leva 0.1.8 → 0.1.9.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.
- checksums.yaml +4 -4
- data/README.md +1 -1
- data/app/views/layouts/leva/application.html.erb +1 -1
- data/app/views/leva/workbench/new.html.erb +74 -3
- data/lib/leva/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e84cd5316b32e9ce352eb79cab83629db28c658ab39883d6c6af9fdec16d3735
|
4
|
+
data.tar.gz: d81584c99f7306bd9b238cf35dfa596927b1df4a1c5630b2462b88e058b7cef1
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 52b642176baa9374085b6625022cbf7a9e283b6772d14ef67abd36d0e1984c49d229d823c8a30a975e8ad26605827a394a093569a4efd4da3909d2dd84d9648f
|
7
|
+
data.tar.gz: a59024a95bf2ed8cc26fe303361001a0b512d0f7f5a2b77d1480dbad5a146aad774f3c1d356821f76c128601be2ecd597e835f4c5ce088d9e6e288cdc273c2e2
|
data/README.md
CHANGED
@@ -33,9 +33,30 @@
|
|
33
33
|
<%= form.label :user_prompt, class: "block text-sm font-semibold mb-2 text-indigo-300" %>
|
34
34
|
<%= form.text_area :user_prompt, rows: 5, class: "w-full bg-gray-700 text-white p-3 rounded-lg focus:ring-2 focus:ring-indigo-500 focus:outline-none" %>
|
35
35
|
</div>
|
36
|
-
<div class="mb-4 hidden" data-prompt-selector-target="promptPreview">
|
36
|
+
<div class="mb-4 hidden" data-prompt-selector-target="promptPreview" id="prompt-preview">
|
37
37
|
<h3 class="text-lg font-semibold mb-2 text-indigo-300">Prompt Preview</h3>
|
38
|
-
<div
|
38
|
+
<div
|
39
|
+
class="bg-gray-700 text-white p-3 rounded-lg whitespace-pre-wrap"
|
40
|
+
data-prompt-selector-target="previewContent"
|
41
|
+
id="preview-content"
|
42
|
+
></div>
|
43
|
+
|
44
|
+
<!-- show-full button, hidden until overflow is detected -->
|
45
|
+
<button
|
46
|
+
id="show-full-preview"
|
47
|
+
type="button"
|
48
|
+
class="mt-2 text-indigo-400 underline hidden"
|
49
|
+
>Show full</button>
|
50
|
+
|
51
|
+
<!-- HTML5 dialog for full text -->
|
52
|
+
<dialog id="full-preview-dialog" class="p-0 m-0">
|
53
|
+
<div class="bg-gray-800 text-white p-4 rounded-lg max-h-[80vh] overflow-auto whitespace-pre-wrap">
|
54
|
+
<div id="dialog-content"></div>
|
55
|
+
<div class="text-right mt-4">
|
56
|
+
<button id="close-full-preview" class="px-4 py-2 bg-indigo-600 rounded text-white">Close</button>
|
57
|
+
</div>
|
58
|
+
</div>
|
59
|
+
</dialog>
|
39
60
|
</div>
|
40
61
|
<div class="flex items-center justify-end space-x-4">
|
41
62
|
<%= link_to "Cancel", workbench_index_path, class: "px-3 py-2 rounded-md text-sm font-medium text-gray-300 hover:bg-gray-800 hover:text-white transition-colors duration-150 ease-in-out" %>
|
@@ -76,6 +97,56 @@
|
|
76
97
|
}
|
77
98
|
})
|
78
99
|
})()
|
100
|
+
|
101
|
+
// Prompt preview scrollbar and dialog functionality
|
102
|
+
document.addEventListener('DOMContentLoaded', () => {
|
103
|
+
const wrapper = document.getElementById('prompt-preview');
|
104
|
+
const preview = document.getElementById('preview-content');
|
105
|
+
const showBtn = document.getElementById('show-full-preview');
|
106
|
+
const dialog = document.getElementById('full-preview-dialog');
|
107
|
+
const dialogBody = document.getElementById('dialog-content');
|
108
|
+
const closeBtn = document.getElementById('close-full-preview');
|
109
|
+
|
110
|
+
if (!preview) return;
|
111
|
+
|
112
|
+
// Check if the preview content is already populated by Stimulus
|
113
|
+
const checkPreviewContent = () => {
|
114
|
+
if (preview.textContent.trim().length > 0) {
|
115
|
+
// Detect overflow
|
116
|
+
if (preview.scrollHeight > preview.clientHeight || preview.scrollWidth > preview.clientWidth) {
|
117
|
+
preview.style.maxHeight = '12em';
|
118
|
+
preview.style.overflow = 'auto';
|
119
|
+
showBtn.classList.remove('hidden');
|
120
|
+
}
|
121
|
+
} else {
|
122
|
+
// If not populated yet, check again after a short delay
|
123
|
+
setTimeout(checkPreviewContent, 100);
|
124
|
+
}
|
125
|
+
};
|
126
|
+
|
127
|
+
// Start checking once the wrapper is visible
|
128
|
+
const observer = new MutationObserver((mutations) => {
|
129
|
+
mutations.forEach((mutation) => {
|
130
|
+
if (mutation.type === 'attributes' && mutation.attributeName === 'class') {
|
131
|
+
if (!wrapper.classList.contains('hidden')) {
|
132
|
+
checkPreviewContent();
|
133
|
+
observer.disconnect(); // Stop observing once we've detected the change
|
134
|
+
}
|
135
|
+
}
|
136
|
+
});
|
137
|
+
});
|
138
|
+
|
139
|
+
observer.observe(wrapper, { attributes: true });
|
140
|
+
|
141
|
+
// Show full in dialog
|
142
|
+
showBtn.addEventListener('click', () => {
|
143
|
+
dialogBody.textContent = preview.textContent;
|
144
|
+
dialog.showModal();
|
145
|
+
});
|
146
|
+
|
147
|
+
// Close dialog
|
148
|
+
closeBtn.addEventListener('click', () => dialog.close());
|
149
|
+
});
|
79
150
|
</script>
|
80
151
|
<!-- Include marked.js for Markdown parsing -->
|
81
|
-
<script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
|
152
|
+
<script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
|
data/lib/leva/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: leva
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.9.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Kieran Klaassen
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2025-
|
11
|
+
date: 2025-04-25 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|