pygpt-net 2.4.41__py3-none-any.whl → 2.4.43__py3-none-any.whl

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 (146) hide show
  1. CHANGELOG.md +13 -0
  2. README.md +142 -70
  3. pygpt_net/CHANGELOG.txt +13 -0
  4. pygpt_net/__init__.py +3 -3
  5. pygpt_net/app.py +3 -1
  6. pygpt_net/controller/audio/__init__.py +2 -2
  7. pygpt_net/controller/camera.py +1 -10
  8. pygpt_net/controller/chat/attachment.py +36 -23
  9. pygpt_net/controller/chat/audio.py +2 -2
  10. pygpt_net/controller/config/placeholder.py +15 -1
  11. pygpt_net/controller/ui/mode.py +16 -21
  12. pygpt_net/core/attachments/__init__.py +1 -1
  13. pygpt_net/core/attachments/context.py +10 -8
  14. pygpt_net/core/audio/__init__.py +4 -1
  15. pygpt_net/core/audio/whisper.py +37 -0
  16. pygpt_net/core/bridge/worker.py +2 -2
  17. pygpt_net/core/db/__init__.py +2 -1
  18. pygpt_net/core/debug/events.py +22 -10
  19. pygpt_net/core/debug/tabs.py +6 -3
  20. pygpt_net/core/history.py +3 -2
  21. pygpt_net/core/idx/__init__.py +16 -4
  22. pygpt_net/core/idx/chat.py +15 -5
  23. pygpt_net/core/idx/indexing.py +24 -8
  24. pygpt_net/core/installer.py +2 -4
  25. pygpt_net/core/models.py +62 -17
  26. pygpt_net/core/modes.py +11 -13
  27. pygpt_net/core/notepad.py +4 -4
  28. pygpt_net/core/plugins.py +27 -16
  29. pygpt_net/core/presets.py +20 -9
  30. pygpt_net/core/profile.py +11 -3
  31. pygpt_net/core/render/web/parser.py +3 -1
  32. pygpt_net/core/settings.py +5 -5
  33. pygpt_net/core/tabs/tab.py +10 -2
  34. pygpt_net/core/tokens.py +8 -6
  35. pygpt_net/core/web/__init__.py +105 -0
  36. pygpt_net/core/{web.py → web/helpers.py} +93 -67
  37. pygpt_net/data/config/config.json +3 -3
  38. pygpt_net/data/config/models.json +3 -3
  39. pygpt_net/data/config/modes.json +3 -3
  40. pygpt_net/data/locale/locale.en.ini +1 -0
  41. pygpt_net/data/locale/plugin.cmd_web.en.ini +2 -0
  42. pygpt_net/data/locale/plugin.mailer.en.ini +21 -0
  43. pygpt_net/item/ctx.py +66 -3
  44. pygpt_net/migrations/Version20241215110000.py +25 -0
  45. pygpt_net/migrations/__init__.py +3 -1
  46. pygpt_net/plugin/agent/__init__.py +7 -2
  47. pygpt_net/plugin/audio_output/__init__.py +6 -1
  48. pygpt_net/plugin/base/plugin.py +58 -26
  49. pygpt_net/plugin/base/worker.py +20 -17
  50. pygpt_net/plugin/cmd_history/config.py +2 -2
  51. pygpt_net/plugin/cmd_web/__init__.py +3 -4
  52. pygpt_net/plugin/cmd_web/config.py +71 -3
  53. pygpt_net/plugin/cmd_web/websearch.py +20 -12
  54. pygpt_net/plugin/cmd_web/worker.py +67 -4
  55. pygpt_net/plugin/idx_llama_index/config.py +3 -3
  56. pygpt_net/plugin/mailer/__init__.py +123 -0
  57. pygpt_net/plugin/mailer/config.py +149 -0
  58. pygpt_net/plugin/mailer/runner.py +285 -0
  59. pygpt_net/plugin/mailer/worker.py +123 -0
  60. pygpt_net/provider/agents/base.py +5 -2
  61. pygpt_net/provider/agents/openai.py +4 -2
  62. pygpt_net/provider/agents/openai_assistant.py +4 -2
  63. pygpt_net/provider/agents/planner.py +4 -2
  64. pygpt_net/provider/agents/react.py +4 -2
  65. pygpt_net/provider/audio_output/openai_tts.py +5 -11
  66. pygpt_net/provider/core/assistant/base.py +5 -3
  67. pygpt_net/provider/core/assistant/json_file.py +8 -5
  68. pygpt_net/provider/core/assistant_file/base.py +4 -3
  69. pygpt_net/provider/core/assistant_file/db_sqlite/__init__.py +4 -3
  70. pygpt_net/provider/core/assistant_file/db_sqlite/storage.py +3 -2
  71. pygpt_net/provider/core/assistant_store/base.py +6 -4
  72. pygpt_net/provider/core/assistant_store/db_sqlite/__init__.py +5 -4
  73. pygpt_net/provider/core/assistant_store/db_sqlite/storage.py +5 -3
  74. pygpt_net/provider/core/attachment/base.py +5 -3
  75. pygpt_net/provider/core/attachment/json_file.py +4 -3
  76. pygpt_net/provider/core/calendar/base.py +5 -3
  77. pygpt_net/provider/core/calendar/db_sqlite/__init__.py +6 -5
  78. pygpt_net/provider/core/calendar/db_sqlite/storage.py +5 -4
  79. pygpt_net/provider/core/config/base.py +8 -6
  80. pygpt_net/provider/core/config/json_file.py +9 -7
  81. pygpt_net/provider/core/ctx/base.py +27 -25
  82. pygpt_net/provider/core/ctx/db_sqlite/__init__.py +51 -35
  83. pygpt_net/provider/core/ctx/db_sqlite/storage.py +92 -38
  84. pygpt_net/provider/core/ctx/db_sqlite/utils.py +37 -11
  85. pygpt_net/provider/core/index/base.py +129 -23
  86. pygpt_net/provider/core/index/db_sqlite/__init__.py +130 -23
  87. pygpt_net/provider/core/index/db_sqlite/storage.py +130 -23
  88. pygpt_net/provider/core/index/db_sqlite/utils.py +4 -2
  89. pygpt_net/provider/core/mode/base.py +5 -3
  90. pygpt_net/provider/core/mode/json_file.py +7 -6
  91. pygpt_net/provider/core/model/base.py +6 -4
  92. pygpt_net/provider/core/model/json_file.py +9 -7
  93. pygpt_net/provider/core/notepad/base.py +5 -3
  94. pygpt_net/provider/core/notepad/db_sqlite/__init__.py +5 -4
  95. pygpt_net/provider/core/notepad/db_sqlite/storage.py +4 -3
  96. pygpt_net/provider/core/plugin_preset/base.py +4 -2
  97. pygpt_net/provider/core/plugin_preset/json_file.py +5 -3
  98. pygpt_net/provider/core/preset/base.py +6 -4
  99. pygpt_net/provider/core/preset/json_file.py +9 -9
  100. pygpt_net/provider/core/prompt/base.py +6 -3
  101. pygpt_net/provider/core/prompt/json_file.py +11 -6
  102. pygpt_net/provider/gpt/assistants.py +15 -6
  103. pygpt_net/provider/gpt/audio.py +5 -5
  104. pygpt_net/provider/gpt/chat.py +7 -5
  105. pygpt_net/provider/gpt/completion.py +8 -4
  106. pygpt_net/provider/gpt/image.py +3 -3
  107. pygpt_net/provider/gpt/store.py +46 -12
  108. pygpt_net/provider/gpt/vision.py +16 -11
  109. pygpt_net/provider/llms/anthropic.py +7 -2
  110. pygpt_net/provider/llms/azure_openai.py +26 -5
  111. pygpt_net/provider/llms/base.py +47 -9
  112. pygpt_net/provider/llms/google.py +7 -2
  113. pygpt_net/provider/llms/hugging_face.py +13 -3
  114. pygpt_net/provider/llms/hugging_face_api.py +18 -4
  115. pygpt_net/provider/llms/local.py +7 -2
  116. pygpt_net/provider/llms/ollama.py +30 -6
  117. pygpt_net/provider/llms/openai.py +32 -6
  118. pygpt_net/provider/vector_stores/__init__.py +45 -14
  119. pygpt_net/provider/vector_stores/base.py +35 -8
  120. pygpt_net/provider/vector_stores/chroma.py +13 -3
  121. pygpt_net/provider/vector_stores/ctx_attachment.py +32 -13
  122. pygpt_net/provider/vector_stores/elasticsearch.py +12 -3
  123. pygpt_net/provider/vector_stores/pinecode.py +12 -3
  124. pygpt_net/provider/vector_stores/redis.py +12 -3
  125. pygpt_net/provider/vector_stores/simple.py +12 -3
  126. pygpt_net/provider/vector_stores/temp.py +16 -4
  127. pygpt_net/provider/web/base.py +10 -3
  128. pygpt_net/provider/web/google_custom_search.py +9 -3
  129. pygpt_net/provider/web/microsoft_bing.py +9 -3
  130. pygpt_net/tools/__init__.py +13 -5
  131. pygpt_net/tools/audio_transcriber/__init__.py +4 -3
  132. pygpt_net/tools/base.py +15 -8
  133. pygpt_net/tools/code_interpreter/__init__.py +4 -3
  134. pygpt_net/tools/html_canvas/__init__.py +4 -3
  135. pygpt_net/tools/image_viewer/__init__.py +10 -4
  136. pygpt_net/tools/indexer/__init__.py +8 -7
  137. pygpt_net/tools/media_player/__init__.py +4 -3
  138. pygpt_net/tools/text_editor/__init__.py +36 -10
  139. pygpt_net/ui/layout/chat/output.py +2 -2
  140. pygpt_net/ui/layout/ctx/ctx_list.py +1 -1
  141. pygpt_net/ui/menu/audio.py +12 -1
  142. {pygpt_net-2.4.41.dist-info → pygpt_net-2.4.43.dist-info}/METADATA +143 -71
  143. {pygpt_net-2.4.41.dist-info → pygpt_net-2.4.43.dist-info}/RECORD +146 -138
  144. {pygpt_net-2.4.41.dist-info → pygpt_net-2.4.43.dist-info}/LICENSE +0 -0
  145. {pygpt_net-2.4.41.dist-info → pygpt_net-2.4.43.dist-info}/WHEEL +0 -0
  146. {pygpt_net-2.4.41.dist-info → pygpt_net-2.4.43.dist-info}/entry_points.txt +0 -0
@@ -6,10 +6,11 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.11.14 05:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  import os.path
13
+ from typing import Optional
13
14
 
14
15
  from llama_index.core import StorageContext, load_index_from_storage
15
16
  from llama_index.core.indices.base import BaseIndex
@@ -64,7 +65,10 @@ class TempProvider(BaseStore):
64
65
  )
65
66
  return path
66
67
 
67
- def exists(self, id: str = None) -> bool:
68
+ def exists(
69
+ self,
70
+ id: Optional[str] = None
71
+ ) -> bool:
68
72
  """
69
73
  Check if index with id exists
70
74
 
@@ -100,7 +104,11 @@ class TempProvider(BaseStore):
100
104
  else:
101
105
  self.indexes[id] = self.index_from_empty()
102
106
 
103
- def get(self, id: str, service_context: ServiceContext = None) -> BaseIndex:
107
+ def get(
108
+ self,
109
+ id: str,
110
+ service_context: Optional[ServiceContext] = None
111
+ ) -> BaseIndex:
104
112
  """
105
113
  Get index
106
114
 
@@ -123,7 +131,11 @@ class TempProvider(BaseStore):
123
131
 
124
132
  return self.indexes[id]
125
133
 
126
- def store(self, id: str, index: BaseIndex = None):
134
+ def store(
135
+ self,
136
+ id: str,
137
+ index: Optional[BaseIndex] = None
138
+ ):
127
139
  """
128
140
  Store index
129
141
 
@@ -6,9 +6,11 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.11.18 21:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
+ from typing import List, Dict
13
+
12
14
  from pygpt_net.plugin.base.plugin import BasePlugin
13
15
 
14
16
 
@@ -45,7 +47,12 @@ class BaseProvider:
45
47
  """Initialize provider options (for plugin settings)"""
46
48
  pass
47
49
 
48
- def search(self, query, limit: int = 10, offset: int = 0):
50
+ def search(
51
+ self,
52
+ query,
53
+ limit: int = 10,
54
+ offset: int = 0
55
+ ) -> List[str]:
49
56
  """
50
57
  Execute search query and return list of urls
51
58
 
@@ -56,7 +63,7 @@ class BaseProvider:
56
63
  """
57
64
  pass
58
65
 
59
- def is_configured(self, cmds: list) -> bool:
66
+ def is_configured(self, cmds: List[Dict]) -> bool:
60
67
  """
61
68
  Check if provider is configured
62
69
 
@@ -6,10 +6,11 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.02.25 01:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  import json
13
+ from typing import List, Dict
13
14
  from urllib.parse import quote
14
15
  from .base import BaseProvider
15
16
 
@@ -63,7 +64,12 @@ class GoogleCustomSearch(BaseProvider):
63
64
  urls=url_cx,
64
65
  )
65
66
 
66
- def search(self, query: str, limit: int = 10, offset: int = 0) -> list:
67
+ def search(
68
+ self,
69
+ query: str,
70
+ limit: int = 10,
71
+ offset: int = 0
72
+ ) -> List[str]:
67
73
  """
68
74
  Execute search query and return list of urls
69
75
 
@@ -103,7 +109,7 @@ class GoogleCustomSearch(BaseProvider):
103
109
 
104
110
  return urls
105
111
 
106
- def is_configured(self, cmds: list) -> bool:
112
+ def is_configured(self, cmds: List[Dict]) -> bool:
107
113
  """
108
114
  Check if provider is configured (required API keys, etc.)
109
115
 
@@ -6,10 +6,11 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.02.25 01:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  import json
13
+ from typing import List, Dict
13
14
  from urllib.parse import quote
14
15
 
15
16
  import requests
@@ -60,7 +61,12 @@ class MicrosoftBingSearch(BaseProvider):
60
61
  tab="microsoft_bing",
61
62
  )
62
63
 
63
- def search(self, query: str, limit: int = 10, offset: int = 0) -> list:
64
+ def search(
65
+ self,
66
+ query: str,
67
+ limit: int = 10,
68
+ offset: int = 0
69
+ ) -> List[str]:
64
70
  """
65
71
  Execute search query and return list of urls
66
72
 
@@ -97,7 +103,7 @@ class MicrosoftBingSearch(BaseProvider):
97
103
  print('Error:', response.status_code, response.text)
98
104
  return urls
99
105
 
100
- def is_configured(self, cmds: list) -> bool:
106
+ def is_configured(self, cmds: List[Dict]) -> bool:
101
107
  """
102
108
  Check if provider is configured (required API keys, etc.)
103
109
 
@@ -6,9 +6,13 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.12.09 23:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
+ from typing import Dict, Optional
13
+
14
+ from PySide6.QtGui import QAction
15
+
12
16
  from pygpt_net.ui.widget.dialog.base import BaseDialog
13
17
  from .base import BaseTool
14
18
 
@@ -42,7 +46,7 @@ class Tools:
42
46
  if id in self.tools:
43
47
  return self.tools[id]
44
48
 
45
- def get_all(self) -> dict:
49
+ def get_all(self) -> Dict[str, BaseTool]:
46
50
  """
47
51
  Get all tools
48
52
 
@@ -83,7 +87,7 @@ class Tools:
83
87
  for id in self.tools:
84
88
  self.tools[id].on_reload()
85
89
 
86
- def setup_menu_actions(self) -> dict:
90
+ def setup_menu_actions(self) -> Dict[str, QAction]:
87
91
  """
88
92
  Setup Tools menu actions
89
93
 
@@ -110,7 +114,11 @@ class Tools:
110
114
  for id in self.tools:
111
115
  self.tools[id].setup_theme()
112
116
 
113
- def get_instance(self, type_id: str, dialog_id: str = None) -> BaseDialog:
117
+ def get_instance(
118
+ self,
119
+ type_id: str,
120
+ dialog_id: Optional[str] = None
121
+ ) -> Optional[BaseDialog]:
114
122
  """
115
123
  Spawn and return dialog instance
116
124
 
@@ -123,7 +131,7 @@ class Tools:
123
131
  if instance is not None:
124
132
  return instance
125
133
 
126
- def get_lang_mappings(self) -> dict:
134
+ def get_lang_mappings(self) -> Dict[str, dict]:
127
135
  """
128
136
  Get language mappings
129
137
 
@@ -6,10 +6,11 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.11.20 03:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  import os
13
+ from typing import Dict
13
14
 
14
15
  from PySide6.QtGui import QAction, QIcon
15
16
  from PySide6.QtWidgets import QFileDialog
@@ -255,7 +256,7 @@ class AudioTranscriber(BaseTool):
255
256
  self.window.ui.nodes['audio.transcribe.status'].setText("")
256
257
  self.store("")
257
258
 
258
- def setup_menu(self) -> dict:
259
+ def setup_menu(self) -> Dict[str, QAction]:
259
260
  """
260
261
  Setup main menu
261
262
 
@@ -278,7 +279,7 @@ class AudioTranscriber(BaseTool):
278
279
  self.dialog = AudioTranscribe(self.window)
279
280
  self.dialog.setup()
280
281
 
281
- def get_lang_mappings(self) -> dict:
282
+ def get_lang_mappings(self) -> Dict[str, Dict]:
282
283
  """
283
284
  Get language mappings
284
285
 
pygpt_net/tools/base.py CHANGED
@@ -6,10 +6,13 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.12.12 04:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
+ from typing import Optional, Dict
13
+
12
14
  from PySide6.QtCore import QObject
15
+ from PySide6.QtGui import QAction
13
16
  from PySide6.QtWidgets import QWidget
14
17
 
15
18
  from pygpt_net.core.tabs.tab import Tab
@@ -63,13 +66,13 @@ class BaseTool(QObject):
63
66
  """
64
67
  self.window = window
65
68
 
66
- def setup_menu(self) -> list:
69
+ def setup_menu(self) -> Dict[str, QAction]:
67
70
  """
68
71
  Setup main menu
69
72
 
70
- :return list with menu actions
73
+ :return dict with menu actions
71
74
  """
72
- return []
75
+ return {}
73
76
 
74
77
  def setup_dialogs(self):
75
78
  """Setup dialogs (static)"""
@@ -79,16 +82,20 @@ class BaseTool(QObject):
79
82
  """Setup theme"""
80
83
  pass
81
84
 
82
- def get_instance(self, id: str, dialog_id: str = None) -> BaseDialog or None:
85
+ def get_instance(
86
+ self,
87
+ type_id: str,
88
+ dialog_id: Optional[str] = None
89
+ ) -> Optional[BaseDialog]:
83
90
  """
84
91
  Spawn and return dialog instance
85
92
 
86
- :param id: dialog instance ID
93
+ :param type_id: dialog instance ID
87
94
  :param dialog_id: dialog instance ID
88
95
  """
89
96
  return None
90
97
 
91
- def as_tab(self, tab: Tab) -> QWidget or None:
98
+ def as_tab(self, tab: Tab) -> Optional[QWidget]:
92
99
  """
93
100
  Spawn and return tab instance
94
101
 
@@ -97,7 +104,7 @@ class BaseTool(QObject):
97
104
  """
98
105
  return None
99
106
 
100
- def get_lang_mappings(self) -> dict:
107
+ def get_lang_mappings(self) -> Dict[str, Dict]:
101
108
  """
102
109
  Get language mappings
103
110
 
@@ -6,10 +6,11 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.12.12 04:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  import os
13
+ from typing import Dict
13
14
 
14
15
  from PySide6.QtCore import QTimer
15
16
  from PySide6.QtGui import QTextCursor, QAction, QIcon
@@ -507,7 +508,7 @@ class CodeInterpreter(BaseTool):
507
508
  cur.movePosition(QTextCursor.End)
508
509
  self.get_widget_history().setTextCursor(cur)
509
510
 
510
- def setup_menu(self) -> dict:
511
+ def setup_menu(self) -> Dict[str, QAction]:
511
512
  """
512
513
  Setup main menu
513
514
 
@@ -549,7 +550,7 @@ class CodeInterpreter(BaseTool):
549
550
  """Setup theme"""
550
551
  self.get_widget_output().value = self.window.core.config.get('font_size')
551
552
 
552
- def get_lang_mappings(self) -> dict:
553
+ def get_lang_mappings(self) -> Dict[str, Dict]:
553
554
  """
554
555
  Get language mappings
555
556
 
@@ -6,10 +6,11 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.12.12 04:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  import os
13
+ from typing import Dict
13
14
 
14
15
  from PySide6.QtCore import QTimer, Slot
15
16
  from PySide6.QtGui import QAction, QIcon
@@ -265,7 +266,7 @@ class HtmlCanvas(BaseTool):
265
266
  # fix: QTimer required here to prevent crash if signal emitted from WebEngine window
266
267
  QTimer.singleShot(0, lambda: self.window.controller.chat.common.save_text(text, type))
267
268
 
268
- def setup_menu(self) -> dict:
269
+ def setup_menu(self) -> Dict[str, QAction]:
269
270
  """
270
271
  Setup main menu
271
272
 
@@ -306,7 +307,7 @@ class HtmlCanvas(BaseTool):
306
307
  """Setup theme"""
307
308
  pass
308
309
 
309
- def get_lang_mappings(self) -> dict:
310
+ def get_lang_mappings(self) -> Dict[str, Dict]:
310
311
  """
311
312
  Get language mappings
312
313
 
@@ -6,12 +6,13 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.11.20 21:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  import hashlib
13
13
  import os
14
14
  import shutil
15
+ from typing import Dict, Optional
15
16
 
16
17
  from PySide6 import QtGui, QtCore
17
18
  from PySide6.QtGui import QAction, QIcon
@@ -19,6 +20,7 @@ from PySide6.QtWidgets import QFileDialog
19
20
 
20
21
  from pygpt_net.tools.base import BaseTool
21
22
  from pygpt_net.tools.image_viewer.ui.dialogs import DialogSpawner
23
+ from pygpt_net.ui.widget.dialog.base import BaseDialog
22
24
  from pygpt_net.utils import trans
23
25
 
24
26
 
@@ -255,7 +257,7 @@ class ImageViewer(BaseTool):
255
257
  except Exception as e:
256
258
  self.window.core.debug.log(e)
257
259
 
258
- def setup_menu(self) -> dict:
260
+ def setup_menu(self) -> Dict[str, QAction]:
259
261
  """
260
262
  Setup main menu
261
263
 
@@ -273,7 +275,11 @@ class ImageViewer(BaseTool):
273
275
  )
274
276
  return actions
275
277
 
276
- def get_instance(self, type_id: str, dialog_id: str = None):
278
+ def get_instance(
279
+ self,
280
+ type_id: str,
281
+ dialog_id: Optional[str] = None
282
+ ) -> Optional[BaseDialog]:
277
283
  """
278
284
  Spawn and return dialog instance
279
285
 
@@ -284,7 +290,7 @@ class ImageViewer(BaseTool):
284
290
  if type_id == "image_viewer":
285
291
  return self.spawner.setup(dialog_id)
286
292
 
287
- def get_lang_mappings(self) -> dict:
293
+ def get_lang_mappings(self) -> Dict[str, Dict]:
288
294
  """
289
295
  Get language mappings
290
296
 
@@ -6,11 +6,12 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.08.20 19:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  import datetime
13
13
  import json
14
+ from typing import Dict, Any, List
14
15
 
15
16
  from PySide6.QtCore import Slot
16
17
  from PySide6.QtGui import QAction, QIcon, QTextCursor
@@ -200,7 +201,7 @@ class IndexerTool(BaseTool):
200
201
  last_str = datetime.datetime.fromtimestamp(last_ts).strftime('%Y-%m-%d %H:%M:%S')
201
202
  self.window.ui.nodes['tool.indexer.ctx.last_auto'].setText(last_str)
202
203
 
203
- def update_tab_files(self):
204
+ def update_tab_files(self) -> List[str]:
204
205
  """
205
206
  Update files tab
206
207
 
@@ -420,7 +421,7 @@ class IndexerTool(BaseTool):
420
421
  self.refresh()
421
422
 
422
423
  @Slot(object)
423
- def handle_log(self, data: any):
424
+ def handle_log(self, data: Any):
424
425
  """
425
426
  Handle log message
426
427
 
@@ -428,7 +429,7 @@ class IndexerTool(BaseTool):
428
429
  """
429
430
  self.log(data)
430
431
 
431
- def log(self, data: any):
432
+ def log(self, data: Any):
432
433
  """
433
434
  Log message to console or logger window
434
435
 
@@ -451,7 +452,7 @@ class IndexerTool(BaseTool):
451
452
  """Clear log"""
452
453
  self.window.ui.nodes["tool.indexer.status"].clear()
453
454
 
454
- def get_tables(self) -> dict:
455
+ def get_tables(self) -> Dict[str, Dict]:
455
456
  """
456
457
  Get tables configuration
457
458
 
@@ -513,7 +514,7 @@ class IndexerTool(BaseTool):
513
514
  }
514
515
  return tables
515
516
 
516
- def setup_menu(self) -> dict:
517
+ def setup_menu(self) -> Dict[str, QAction]:
517
518
  """
518
519
  Setup main menu (Tools)
519
520
 
@@ -536,7 +537,7 @@ class IndexerTool(BaseTool):
536
537
  self.dialog = DialogBuilder(self.window)
537
538
  self.dialog.setup()
538
539
 
539
- def get_lang_mappings(self) -> dict:
540
+ def get_lang_mappings(self) -> Dict[str, Dict]:
540
541
  """
541
542
  Get language mappings
542
543
 
@@ -6,12 +6,13 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.11.15 00:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  import datetime
13
13
  import os.path
14
14
  import shutil
15
+ from typing import Dict
15
16
 
16
17
  from PySide6.QtGui import QAction, QIcon
17
18
 
@@ -165,7 +166,7 @@ class MediaPlayer(BaseTool):
165
166
  else:
166
167
  self.close()
167
168
 
168
- def setup_menu(self) -> dict:
169
+ def setup_menu(self) -> Dict[str, QAction]:
169
170
  """
170
171
  Setup main menu
171
172
 
@@ -188,7 +189,7 @@ class MediaPlayer(BaseTool):
188
189
  self.dialog = VideoPlayer(self.window)
189
190
  self.dialog.setup()
190
191
 
191
- def get_lang_mappings(self) -> dict:
192
+ def get_lang_mappings(self) -> Dict[str, Dict]:
192
193
  """
193
194
  Get language mappings
194
195
 
@@ -6,17 +6,19 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.11.20 21:00:00 #
9
+ # Updated Date: 2024.12.14 22:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  import hashlib
13
13
  import os
14
+ from typing import Dict, Optional
14
15
 
15
16
  from PySide6.QtGui import QAction, QIcon
16
17
  from PySide6.QtWidgets import QFileDialog
17
18
 
18
19
  from pygpt_net.tools.base import BaseTool
19
20
  from pygpt_net.tools.text_editor.ui.dialogs import DialogSpawner
21
+ from pygpt_net.ui.widget.dialog.base import BaseDialog
20
22
  from pygpt_net.utils import trans
21
23
 
22
24
 
@@ -47,7 +49,13 @@ class TextEditor(BaseTool):
47
49
  """
48
50
  return 'file_editor_' + hashlib.md5(file.encode('utf-8')).hexdigest()
49
51
 
50
- def open_file(self, id: str, auto_close: bool = True, force: bool = False, save: bool = False):
52
+ def open_file(
53
+ self,
54
+ id: str,
55
+ auto_close: bool = True,
56
+ force: bool = False,
57
+ save: bool = False
58
+ ):
51
59
  """
52
60
  Open text file dialog
53
61
 
@@ -73,7 +81,12 @@ class TextEditor(BaseTool):
73
81
  if path:
74
82
  self.open(path, id, auto_close)
75
83
 
76
- def clear(self, id: str = None, force: bool = False, save: bool = False):
84
+ def clear(
85
+ self,
86
+ id: str = None,
87
+ force: bool = False,
88
+ save: bool = False
89
+ ):
77
90
  """
78
91
  Clear current instance
79
92
 
@@ -101,8 +114,8 @@ class TextEditor(BaseTool):
101
114
 
102
115
  def open(
103
116
  self,
104
- file: str = None,
105
- current_id: str = None,
117
+ file: Optional[str] = None,
118
+ current_id: Optional[str] = None,
106
119
  auto_close: bool = True,
107
120
  force: bool = False):
108
121
  """
@@ -153,7 +166,11 @@ class TextEditor(BaseTool):
153
166
  else:
154
167
  self.window.core.filesystem.editor.clear(id) # clear editor if no file
155
168
 
156
- def close(self, id: str, save: bool = False):
169
+ def close(
170
+ self,
171
+ id: str,
172
+ save: bool = False
173
+ ):
157
174
  """
158
175
  Close file editor
159
176
 
@@ -180,7 +197,12 @@ class TextEditor(BaseTool):
180
197
  id = self.save_as_file(id)
181
198
  return id
182
199
 
183
- def restore(self, id: str, force: bool = False, save: bool = False):
200
+ def restore(
201
+ self,
202
+ id: str,
203
+ force: bool = False,
204
+ save: bool = False
205
+ ):
184
206
  """
185
207
  Restore file content
186
208
 
@@ -225,7 +247,7 @@ class TextEditor(BaseTool):
225
247
  self.window.core.filesystem.editor.save(id, path)
226
248
  return id
227
249
 
228
- def setup_menu(self) -> dict:
250
+ def setup_menu(self) -> Dict[str, QAction]:
229
251
  """
230
252
  Setup main menu
231
253
 
@@ -243,7 +265,11 @@ class TextEditor(BaseTool):
243
265
  )
244
266
  return actions
245
267
 
246
- def get_instance(self, type_id: str, dialog_id: str = None):
268
+ def get_instance(
269
+ self,
270
+ type_id: str,
271
+ dialog_id: Optional[str] = None
272
+ ) -> Optional[BaseDialog]:
247
273
  """
248
274
  Spawn and return dialog instance
249
275
 
@@ -254,7 +280,7 @@ class TextEditor(BaseTool):
254
280
  if type_id == "text_editor":
255
281
  return self.spawner.setup(dialog_id)
256
282
 
257
- def get_lang_mappings(self) -> dict:
283
+ def get_lang_mappings(self) -> Dict[str, Dict]:
258
284
  """
259
285
  Get language mappings
260
286
 
@@ -6,7 +6,7 @@
6
6
  # GitHub: https://github.com/szczyglis-dev/py-gpt #
7
7
  # MIT License #
8
8
  # Created By : Marcin Szczygliński #
9
- # Updated Date: 2024.12.09 03:00:00 #
9
+ # Updated Date: 2024.12.14 19:00:00 #
10
10
  # ================================================== #
11
11
 
12
12
  from PySide6.QtCore import Qt
@@ -192,7 +192,7 @@ class Output:
192
192
  right_layout.addWidget(self.window.ui.nodes['prompt.context'])
193
193
  right_layout.addWidget(QLabel(" "))
194
194
  right_layout.addWidget(self.window.ui.nodes['input.counter'])
195
- right_layout.setContentsMargins(0, 0, 0, 0)
195
+ right_layout.setContentsMargins(0, 8, 20, 0)
196
196
 
197
197
  left_widget = QWidget()
198
198
  left_widget.setLayout(left_layout)
@@ -216,7 +216,7 @@ class CtxList:
216
216
  label = data.label
217
217
  if data.important:
218
218
  is_important = True
219
- if data.additional_ctx and len(data.additional_ctx) > 0:
219
+ if data.has_additional_ctx():
220
220
  is_attachment = True
221
221
  custom_data = {
222
222
  "label": label,