summaryrefslogtreecommitdiff
path: root/internal_rewrite/ui_itemlist_def.h
diff options
context:
space:
mode:
Diffstat (limited to 'internal_rewrite/ui_itemlist_def.h')
-rw-r--r--internal_rewrite/ui_itemlist_def.h61
1 files changed, 61 insertions, 0 deletions
diff --git a/internal_rewrite/ui_itemlist_def.h b/internal_rewrite/ui_itemlist_def.h
new file mode 100644
index 0000000..fd64f12
--- /dev/null
+++ b/internal_rewrite/ui_itemlist_def.h
@@ -0,0 +1,61 @@
+#include "ui_itemlist.h"
+#include <windows.h>
+
+namespace ui
+{
+ template < typename t, size_t size >
+ void c_itemlist< t, size >::text_input( ) {
+ if( is_textbox_hovered( ) && g_input.is_key_pressed( KEYS_MOUSE1 ) ) {
+ if( !m_was_held ) {
+ m_box_active ^= 1;
+ }
+ m_was_held = true;
+ }
+ else {
+ m_was_held = false;
+ }
+
+ if( m_box_active ) {
+ if( !is_textbox_hovered( ) && g_input.is_key_pressed( KEYS_MOUSE1 ) ) {
+ m_box_active = false;
+ }
+
+ float current_time = GetTickCount( ) * 0.001f;
+ size_t length = strlen( m_search_text );
+
+ for( size_t i{ }; i < 0xfe; ++i ) {
+ if( g_input.is_key_pressed( i ) ) {
+ float delta_time = current_time - m_last_key_input[ i ];
+ if( fabs( delta_time ) > 0.2f ) {
+ if( i == KEYS_BACK ) {
+ m_search_text[ length - 1 ] = 0;
+ m_last_key_input[ i ] = current_time;
+ continue;
+ }
+
+ m_key_states[ i ] = 0xf0;
+ wchar_t pressed_char;
+ const auto scan = MapVirtualKeyA( i, 2 );
+ auto ret = ToAscii( i, scan, ( BYTE* )m_key_states, ( LPWORD )&pressed_char, 1 );
+
+ if( ret == 1 ) {
+ if( length < size ) {
+ m_search_text[ length ] = ( char )( pressed_char );
+ m_search_text[ length + 1 ] = 0;
+ }
+ }
+ m_last_key_input[ i ] = current_time;
+ }
+ }
+ else {
+ m_last_key_input[ i ] = 0.f;
+ m_key_states[ i ] = 0;
+ }
+ }
+
+ if( g_input.is_key_pressed( KEYS_RETURN ) ) {
+ m_box_active = false;
+ }
+ }
+ }
+} \ No newline at end of file