Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

More Form Enhancements #138

Merged
merged 2 commits into from
Dec 28, 2024
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
More Form Enhancements
This commit enhances audio form with the ability to disable deletion of text as well as configure clipboard operations'.

1. A new enum `clipboard_flags`:
We now have a new enum that offers 3 constants: `clipboard_flag_copy, clipboard_flag_cut_clipboard_paste`. This is internal, and the users don't need to use this.

2. 2 new methods for configuring whether or not you want to allow the users to use backspace or delete keys.
a. `bool audio_form::set_enable_delete(int control_index, bool enabled);`
b. `bool audio_form::set_delete_disabled_message(int control_index, string mesage);`

3. A new method for setting clipboard_flags: `bool audio_form::set_clipboard_flags(control_index, bool copy, bool cut, bool paste);`
  • Loading branch information
literary-programmer committed Nov 10, 2024
commit 010e9fb2a1a1f84ad91bfb35bf1cf39ac81f6093
81 changes: 76 additions & 5 deletions release/include/form.nvgt
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,12 @@ added event callback
*/

//constants
enum clipboard_flags
{
clipboard_flag_copy = 1 << 0,
clipboard_flag_cut = 1 << 1,
clipboard_flag_paste = 1 << 2
}
enum control_types {
ct_button = 0,
ct_input,
Expand Down Expand Up @@ -270,6 +276,8 @@ class audio_form {
c_form[control_counter].caption = caption.replace("&", "", true);
c_form[control_counter].visible = true;
c_form[control_counter].enabled = true;
c_form[control_counter].enable_delete = true;
set_clipboard_flags(control_counter, true, true, true);
c_form[control_counter].speech_output = speech_output;
if ((maximum_length > 0) && (default_text.length() > maximum_length)) {
default_text = default_text.substr(0, maximum_length);
Expand Down Expand Up @@ -1146,6 +1154,40 @@ class audio_form {
c_form[control_index].visible = visible;
return true;
}
bool set_enable_delete(int control_index, bool enabled) {
form_error = 0;
if (!active) {
form_error = form_error_no_window;
return false;
}
if ((control_index < 0) || (control_index > c_form.length() - 1)) {
form_error = form_error_invalid_control;
return false;
}
if (!c_form[control_index].active) {
form_error = form_error_invalid_control;
return false;
}
c_form[control_index].enable_delete = enabled;
return true;
}
bool set_delete_disabled_message(int control_index, string message) {
form_error = 0;
if (!active) {
form_error = form_error_no_window;
return false;
}
if ((control_index < 0) || (control_index > c_form.length() - 1)) {
form_error = form_error_invalid_control;
return false;
}
if (!c_form[control_index].active) {
form_error = form_error_invalid_control;
return false;
}
c_form[control_index].delete_disabled_message = message;
return true;
}
bool set_enable_go_to_index(int control_index, bool enabled) {
form_error = 0;
if (!active) {
Expand Down Expand Up @@ -2123,6 +2165,23 @@ class audio_form {
c_form[control_index].echo_flag = keyboard_echo;
return true;
}
bool set_clipboard_flags(int control_index, bool copy, bool cut, bool paste) {
form_error = 0;
if (!active) {
form_error = form_error_no_window;
return false;
}
if ((control_index < 0) || (control_index > c_form.length() - 1)) {
form_error = form_error_invalid_index;
return false;
}
if (!c_form[control_index].active) {
form_error = form_error_invalid_control;
return false;
}
c_form[control_index].clipboard_flags = ((copy ? clipboard_flag_copy : 0) | (cut ? clipboard_flag_cut : 0) | (paste ? clipboard_flag_paste : 0));
return true;
}
bool set_keyboard_echo(int control_index, int keyboard_echo) {
form_error = 0;
if (!active) {
Expand Down Expand Up @@ -2512,14 +2571,18 @@ class control {
string[] disallowed_chars;
bool use_only_disallowed_chars;
string char_disallowed_description;
bool enable_delete;
string delete_disabled_message;
bool enable_go_to_index; //This is mostly used on go to index field where it prevents the key from pressing again.
bool enable_search;
uint8 clipboard_flags;
control() {
progress_time.restart();
progress_time.pause();
multinav_timer.restart();
multinav_timer.pause();
caption = "";
custom_type = "";
text = "";
password_mask = "";
type = -1;
Expand Down Expand Up @@ -2657,19 +2720,27 @@ class control {
else
add(char);
}
if (((key_down(KEY_LCTRL)) || (key_down(KEY_RCTRL))) && (key_repeating(KEY_X)) && password_mask == "")
if ((clipboard_flags & clipboard_flag_cut > 0) && (keyboard_modifiers & KEYMOD_CTRL > 0) && (key_repeating(KEY_X)) && password_mask == "")
cut_highlighted();
if (((key_down(KEY_LCTRL)) || (key_down(KEY_RCTRL))) && (key_repeating(KEY_V)) || key_pressed(KEY_PASTE))
if ((clipboard_flags & clipboard_flag_paste > 0) && (keyboard_modifiers & KEYMOD_CTRL > 0) && (key_repeating(KEY_V)) || key_pressed(KEY_PASTE))
paste_text();
if (key_repeating(KEY_BACK)) {
if ((key_down(KEY_LCTRL) || key_down(KEY_RCTRL)) && (sel_start < 0 || sel_end < 0 || sel_start > sel_end)) {
if (false == enable_delete) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
if (false == enable_delete) {
if (!enable_delete) {

speak(delete_disabled_message);
Copy link
Contributor

@harrymkt harrymkt Nov 10, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
speak(delete_disabled_message);
if (delete_disabled_message != "") speak(delete_disabled_message);

return;
}
if ((keyboard_modifiers & KEYMOD_CTRL > 0) && (sel_start < 0 || sel_end < 0 || sel_start > sel_end)) {
delete_word_left();
return;
}
delete_highlighted();
}
if (key_repeating(KEY_DELETE)) {
if ((key_down(KEY_LCTRL) || key_down(KEY_RCTRL)) && (sel_start < 0 || sel_end < 0 || sel_start > sel_end)) {
if (false == enable_delete) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
if (false == enable_delete) {
if (!enable_delete) {

speak(delete_disabled_message);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
speak(delete_disabled_message);
if (delete_disabled_message != "") speak(delete_disabled_message);

return;
}
if ((keyboard_modifiers & KEYMOD_CTRL > 0) && (sel_start < 0 || sel_end < 0 || sel_start > sel_end)) {
delete_word_right();
return;
}
Expand All @@ -2680,7 +2751,7 @@ class control {
}
if (((key_down(KEY_LCTRL)) || (key_down(KEY_RCTRL))) && key_up(KEY_LSHIFT) && key_up(KEY_RSHIFT) && (key_repeating(KEY_A)))
highlight_all();
if (((key_down(KEY_LCTRL)) || (key_down(KEY_RCTRL))) && (key_repeating(KEY_C)) && (password_mask == ""))
if ((clipboard_flags & clipboard_flag_copy > 0) && (keyboard_modifiers & KEYMOD_CTRL > 0) && (key_repeating(KEY_C)) && (password_mask == ""))
copy_highlighted();
if (key_repeating(KEY_LEFT)) {
if ((key_down(KEY_LCTRL)) || (key_down(KEY_RCTRL))) {
Expand Down