NagisaNao commited on
Commit
b4e8d6d
·
verified ·
1 Parent(s): af36f95

✨ file download update

Browse files

- Automatically get an extension for a custom file name

files_cells/notebooks/en/auto_cleaner_en.ipynb CHANGED
@@ -23,8 +23,7 @@
23
  "\n",
24
  "import os\n",
25
  "import time\n",
26
- "import ipywidgets as widgets\n",
27
- "from ipywidgets import Label, Button, VBox, HBox\n",
28
  "from IPython.display import display, HTML, Javascript\n",
29
  "\n",
30
  "\n",
@@ -53,7 +52,7 @@
53
  "}\n",
54
  "\n",
55
  "\"\"\" functions \"\"\"\n",
56
- "def clean_directory(directory):\n",
57
  " deleted_files = 0\n",
58
  "\n",
59
  " for root, dirs, files in os.walk(directory):\n",
@@ -62,7 +61,7 @@
62
  "\n",
63
  " if file.endswith(\".txt\"):\n",
64
  " continue\n",
65
- " if file.endswith((\".safetensors\", \".pt\", \".png\", \".jpg\", \".jpeg\")):\n",
66
  " deleted_files += 1\n",
67
  "\n",
68
  " os.remove(file_path)\n",
@@ -84,7 +83,7 @@
84
  "\n",
85
  " for option in selected_cleaners:\n",
86
  " if option in directories:\n",
87
- " deleted_files_dict[option] = clean_directory(directories[option])\n",
88
  "\n",
89
  " output.clear_output()\n",
90
  "\n",
@@ -132,9 +131,9 @@
132
  "auto_cleaner_widget = widgets.SelectMultiple(options=AutoCleaner_options, layout=widgets.Layout(width='auto')).add_class(\"custom-select-multiple_AC\")\n",
133
  "output = widgets.Output().add_class(\"output_AC\")\n",
134
  "# ---\n",
135
- "execute_button = Button(description='Execute Cleaning').add_class(\"button_execute_AC\").add_class(\"button_AC\")\n",
136
  "execute_button.on_click(on_execute_button_press)\n",
137
- "clear_button = Button(description='Hide Widget').add_class(\"button_clear_AC\").add_class(\"button_AC\")\n",
138
  "clear_button.on_click(on_clear_button_press)\n",
139
  "# ---\n",
140
  "storage_info = widgets.HTML(f'''\n",
@@ -144,7 +143,7 @@
144
  "buttons = widgets.HBox([execute_button, clear_button])\n",
145
  "lower_information_panel = widgets.HBox([buttons, storage_info]).add_class(\"lower_information_panel_AC\")\n",
146
  "\n",
147
- "container = VBox([instruction_label, widgets.HTML('<hr>'), auto_cleaner_widget, output, widgets.HTML('<hr>'), lower_information_panel]).add_class(\"container_AC\")\n",
148
  "\n",
149
  "display(container)"
150
  ],
 
23
  "\n",
24
  "import os\n",
25
  "import time\n",
26
+ "from ipywidgets import widgets\n",
 
27
  "from IPython.display import display, HTML, Javascript\n",
28
  "\n",
29
  "\n",
 
52
  "}\n",
53
  "\n",
54
  "\"\"\" functions \"\"\"\n",
55
+ "def clean_directory(directory, directory_type):\n",
56
  " deleted_files = 0\n",
57
  "\n",
58
  " for root, dirs, files in os.walk(directory):\n",
 
61
  "\n",
62
  " if file.endswith(\".txt\"):\n",
63
  " continue\n",
64
+ " if file.endswith((\".safetensors\", \".pt\")) or directory_type == \"Images\":\n",
65
  " deleted_files += 1\n",
66
  "\n",
67
  " os.remove(file_path)\n",
 
83
  "\n",
84
  " for option in selected_cleaners:\n",
85
  " if option in directories:\n",
86
+ " deleted_files_dict[option] = clean_directory(directories[option], option)\n",
87
  "\n",
88
  " output.clear_output()\n",
89
  "\n",
 
131
  "auto_cleaner_widget = widgets.SelectMultiple(options=AutoCleaner_options, layout=widgets.Layout(width='auto')).add_class(\"custom-select-multiple_AC\")\n",
132
  "output = widgets.Output().add_class(\"output_AC\")\n",
133
  "# ---\n",
134
+ "execute_button = widgets.Button(description='Execute Cleaning').add_class(\"button_execute_AC\").add_class(\"button_AC\")\n",
135
  "execute_button.on_click(on_execute_button_press)\n",
136
+ "clear_button = widgets.Button(description='Hide Widget').add_class(\"button_clear_AC\").add_class(\"button_AC\")\n",
137
  "clear_button.on_click(on_clear_button_press)\n",
138
  "# ---\n",
139
  "storage_info = widgets.HTML(f'''\n",
 
143
  "buttons = widgets.HBox([execute_button, clear_button])\n",
144
  "lower_information_panel = widgets.HBox([buttons, storage_info]).add_class(\"lower_information_panel_AC\")\n",
145
  "\n",
146
+ "container = widgets.VBox([instruction_label, widgets.HTML('<hr>'), auto_cleaner_widget, output, widgets.HTML('<hr>'), lower_information_panel]).add_class(\"container_AC\")\n",
147
  "\n",
148
  "display(container)"
149
  ],
files_cells/notebooks/en/downloading_en.ipynb CHANGED
@@ -39,6 +39,7 @@
39
  "\n",
40
  "os.chdir(root_path)\n",
41
  "\n",
 
42
  "# ============ loading settings V4 =============\n",
43
  "def load_settings(path):\n",
44
  " if os.path.exists(path):\n",
@@ -94,11 +95,10 @@
94
  " subprocess.run(install_cmd, shell=True, capture_output=True)\n",
95
  "\n",
96
  " # Additional specific packages\n",
97
- " with capture.capture_output() as cap:\n",
98
  " !curl -s -OL https://github.com/DEX-1101/sd-webui-notebook/raw/main/res/new_tunnel --output-dir {root_path}\n",
99
  " !curl -s -Lo /usr/bin/cl https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 && chmod +x /usr/bin/cl\n",
100
  " !curl -sLO https://github.com/openziti/zrok/releases/download/v0.4.32/zrok_0.4.32_linux_amd64.tar.gz && tar -xzf zrok_0.4.32_linux_amd64.tar.gz -C /usr/bin && rm -f zrok_0.4.32_linux_amd64.tar.gz\n",
101
- " del cap\n",
102
  "\n",
103
  " clear_output()\n",
104
  "\n",
@@ -113,23 +113,33 @@
113
  "\n",
114
  "# =================== OTHER ====================\n",
115
  "# Setup Timer\n",
116
- "if \"START_COLAB\" in os.environ:\n",
117
- " start_colab = int(os.environ[\"START_COLAB\"])\n",
118
- "else:\n",
119
- " start_colab = int(time.time()) - 5\n",
120
- " os.environ[\"START_COLAB\"] = str(start_colab)\n",
121
- "\n",
122
- "# remove directory func\n",
123
- "def _remove_dir(directory_path):\n",
 
 
 
 
 
 
 
 
 
 
 
 
124
  " if directory_path and os.path.exists(directory_path):\n",
125
  " try:\n",
126
  " shutil.rmtree(directory_path)\n",
127
  " except Exception:\n",
128
  " !rm -rf {directory_path}\n",
129
  "\n",
130
- "# Save files temporarily\n",
131
- "temporarily_dir = f'{root_path}/temp_dir'\n",
132
- "\n",
133
  "def copy_items_with_replace(src_base, dst_base):\n",
134
  " items_to_copy = [\n",
135
  " 'embeddings',\n",
@@ -140,14 +150,13 @@
140
  " ]\n",
141
  "\n",
142
  " print(\"⌚ Moving files...\", end='')\n",
143
- " time.sleep(1)\n",
144
  " for item in items_to_copy:\n",
145
  " src = os.path.join(src_base, item)\n",
146
  " dst = os.path.join(dst_base, item)\n",
147
  "\n",
148
  " if os.path.exists(src):\n",
149
  " if os.path.exists(dst):\n",
150
- " _remove_dir(dst)\n",
151
  " os.makedirs(os.path.dirname(dst), exist_ok=True)\n",
152
  " shutil.move(src, dst)\n",
153
  " print(\"\\r🔥 Files moved!\" + \" \"*15)\n",
@@ -166,40 +175,39 @@
166
  " start_install = time.time()\n",
167
  " print(f\"⌚ Unpacking Stable Diffusion{' (Forge)' if UI == 'Forge' else ''}...\", end='')\n",
168
  "\n",
169
- " with capture.capture_output() as cap:\n",
170
  " download_url = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO.zip\"\n",
171
  " if UI == 'Forge':\n",
172
  " download_url = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO_forge.zip\"\n",
173
  "\n",
174
- " aria2_args = \"--console-log-level=error -c -x 16 -s 16 -k 1M\"\n",
175
  " zip_path = f\"{root_path}/repo.zip\"\n",
176
- " !aria2c {aria2_args} {download_url} -d {root_path} -o repo.zip\n",
177
  " !unzip -q -o {zip_path} -d {webui_path}\n",
178
  " !rm -rf {zip_path}\n",
179
  "\n",
180
- " get_ipython().system(f'echo -n {start_colab} > {webui_path}/static/colabTimer.txt')\n",
181
- " del cap\n",
182
  "\n",
183
  " install_time = time.time() - start_install\n",
184
  " minutes, seconds = divmod(int(install_time), 60)\n",
185
  " print(f\"\\r🚀 Unpacking complete! For {minutes:02}:{seconds:02} ⚡\" + \" \"*15)\n",
186
  "\n",
187
- " if os.path.exists(temporarily_dir):\n",
188
- " copy_items_with_replace(temporarily_dir, webui_path)\n",
189
- " _remove_dir(temporarily_dir)\n",
190
  "\n",
191
  "# ================= MAIN CODE ==================\n",
192
  "if os.path.exists(webui_path):\n",
193
  " if UI != OLD_UI:\n",
194
  " print(f'Switching the WebUI from \\033[33m{OLD_UI}\\033[0m to \\033[33m{UI}\\033[0m:')\n",
195
- " copy_items_with_replace(webui_path, temporarily_dir)\n",
196
- " _remove_dir(webui_path)\n",
197
  " os.environ['SDW_OLD_UI'] = UI\n",
198
  " time.sleep(2)\n",
199
  " clear_output()\n",
200
  "\n",
201
  "if not os.path.exists(webui_path):\n",
202
  " unpack_webui()\n",
 
203
  "else:\n",
204
  " print(\"🚀 All unpacked... Skip. ⚡\")\n",
205
  " timer_colab = handle_colab_timer(webui_path, start_colab)\n",
@@ -211,7 +219,7 @@
211
  "if latest_webui or latest_exstensions:\n",
212
  " action = \"WebUI and Extensions\" if latest_webui and latest_exstensions else (\"WebUI\" if latest_webui else \"Extensions\")\n",
213
  " print(f\"⌚️ Updating {action}...\", end='')\n",
214
- " with capture.capture_output() as cap:\n",
215
  " !git config --global user.email \"you@example.com\"\n",
216
  " !git config --global user.name \"Your Name\"\n",
217
  "\n",
@@ -224,30 +232,26 @@
224
  " ## Update extensions\n",
225
  " if latest_exstensions:\n",
226
  " !{'for dir in ' + webui_path + '/extensions/*/; do cd \\\"$dir\\\" && git reset --hard && git pull; done'}\n",
227
- " del cap\n",
228
  " print(f\"\\r✨ Updating {action} Completed!\")\n",
229
  "\n",
230
  "\n",
231
  "# === FIXING EXTENSIONS ===\n",
232
  "anxety_repos = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main\"\n",
233
- "\n",
234
- "with capture.capture_output() as cap:\n",
235
  " # --- Umi-Wildcard ---\n",
236
  " !sed -i '521s/open=\\(False\\|True\\)/open=False/' {webui_path}/extensions/Umi-AI-Wildcards/scripts/wildcard_recursive.py # Closed accordion by default\n",
237
  " # --- Encrypt-Image ---\n",
238
  " !sed -i '9,37d' {webui_path}/extensions/Encrypt-Image/javascript/encrypt_images_info.js # Removes the weird text in webui\n",
239
- "del cap\n",
240
  "\n",
241
  "\n",
242
  "## Version switching\n",
243
  "if commit_hash:\n",
244
  " print('⏳ Time machine activation...', end=\"\")\n",
245
- " with capture.capture_output() as cap:\n",
246
  " %cd {webui_path}\n",
247
  " !git config --global user.email \"you@example.com\"\n",
248
  " !git config --global user.name \"Your Name\"\n",
249
  " !git reset --hard {commit_hash}\n",
250
- " del cap\n",
251
  " print(f\"\\r⌛️ The time machine has been activated! Current commit: \\033[34m{commit_hash}\\033[0m\")\n",
252
  "\n",
253
  "\n",
@@ -326,6 +330,12 @@
326
  " model_type = data['files'][1]['type']\n",
327
  " model_name = data['files'][1]['name']\n",
328
  "\n",
 
 
 
 
 
 
329
  " return model_type, model_name\n",
330
  "\n",
331
  " def get_download_url(data, model_type):\n",
@@ -348,7 +358,6 @@
348
  " return None, None\n",
349
  "\n",
350
  " model_type, model_name = get_model_info(url, data)\n",
351
- " model_name = file_name or model_name\n",
352
  " download_url = get_download_url(data, model_type)\n",
353
  " image_url, image_name = get_image_info(data, model_type, model_name)\n",
354
  "\n",
@@ -417,8 +426,12 @@
417
  " command = [\"aria2c\"] + aria2_args.split() + [\"-d\", dst_dir, \"-o\", image_name, image_url]\n",
418
  " subprocess.run(command, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)\n",
419
  "\n",
420
- " elif 'github' in url or \"huggingface.co\" in url:\n",
421
- " file_name = clean_url.split(\"/\")[-1] if file_name is None else file_name\n",
 
 
 
 
422
  "\n",
423
  " \"\"\" Formatted info output \"\"\"\n",
424
  " try:\n",
@@ -575,9 +588,8 @@
575
  " download(url)\n",
576
  " print(\"\\n\\033[33m# =============================== #\\n\\033[0m\")\n",
577
  "else:\n",
578
- " with capture.capture_output() as cap:\n",
579
  " download(url)\n",
580
- " del cap\n",
581
  "\n",
582
  "print(\"\\r🏁 Download Complete!\" + \" \"*15)\n",
583
  "\n",
@@ -589,7 +601,7 @@
589
  "## Install of Custom extensions\n",
590
  "if len(extension_repo) > 0:\n",
591
  " print(\"✨ Installing custom extensions...\", end='')\n",
592
- " with capture.capture_output() as cap:\n",
593
  " for repo, repo_name in extension_repo:\n",
594
  " if not repo_name:\n",
595
  " repo_name = repo.split('/')[-1]\n",
@@ -597,7 +609,6 @@
597
  " && git clone {repo} {repo_name} \\\n",
598
  " && cd {repo_name} \\\n",
599
  " && git fetch\n",
600
- " del cap\n",
601
  " print(f\"\\r📦 Installed '{len(extension_repo)}', Custom extensions!\")\n",
602
  "\n",
603
  "\n",
 
39
  "\n",
40
  "os.chdir(root_path)\n",
41
  "\n",
42
+ "\n",
43
  "# ============ loading settings V4 =============\n",
44
  "def load_settings(path):\n",
45
  " if os.path.exists(path):\n",
 
95
  " subprocess.run(install_cmd, shell=True, capture_output=True)\n",
96
  "\n",
97
  " # Additional specific packages\n",
98
+ " with capture.capture_output():\n",
99
  " !curl -s -OL https://github.com/DEX-1101/sd-webui-notebook/raw/main/res/new_tunnel --output-dir {root_path}\n",
100
  " !curl -s -Lo /usr/bin/cl https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 && chmod +x /usr/bin/cl\n",
101
  " !curl -sLO https://github.com/openziti/zrok/releases/download/v0.4.32/zrok_0.4.32_linux_amd64.tar.gz && tar -xzf zrok_0.4.32_linux_amd64.tar.gz -C /usr/bin && rm -f zrok_0.4.32_linux_amd64.tar.gz\n",
 
102
  "\n",
103
  " clear_output()\n",
104
  "\n",
 
113
  "\n",
114
  "# =================== OTHER ====================\n",
115
  "# Setup Timer\n",
116
+ "start_colab = int(os.environ.get(\"START_COLAB\", time.time() - 5))\n",
117
+ "os.environ[\"START_COLAB\"] = str(start_colab)\n",
118
+ "\n",
119
+ "def download_cfg_files(file_paths, destination_path):\n",
120
+ " base_url = \"https://huggingface.co/NagisaNao/SD-CONFIGS/resolve/main\"\n",
121
+ " for filename in file_paths:\n",
122
+ " file_name = filename.split('/')[-1]\n",
123
+ " !wget -O {destination_path}/{file_name} {base_url}/{filename}\n",
124
+ "\n",
125
+ "def cfg_download():\n",
126
+ " common_files = [\"styles.csv\"]\n",
127
+ " a1111_files = [\"A1111/config.json\", \"A1111/ui-config.json\"]\n",
128
+ " forge_files = [\"reForge/config.json\", \"reForge/ui-config.json\"]\n",
129
+ "\n",
130
+ " with capture.capture_output():\n",
131
+ " download_cfg_files(common_files, webui_path)\n",
132
+ " ui_files = a1111_files if UI == 'A1111' else forge_files\n",
133
+ " download_cfg_files(ui_files, webui_path)\n",
134
+ "\n",
135
+ "def remove_dir(directory_path):\n",
136
  " if directory_path and os.path.exists(directory_path):\n",
137
  " try:\n",
138
  " shutil.rmtree(directory_path)\n",
139
  " except Exception:\n",
140
  " !rm -rf {directory_path}\n",
141
  "\n",
142
+ "TEMPORARY_DIR = f'{root_path}/temp_dir'\n",
 
 
143
  "def copy_items_with_replace(src_base, dst_base):\n",
144
  " items_to_copy = [\n",
145
  " 'embeddings',\n",
 
150
  " ]\n",
151
  "\n",
152
  " print(\"⌚ Moving files...\", end='')\n",
 
153
  " for item in items_to_copy:\n",
154
  " src = os.path.join(src_base, item)\n",
155
  " dst = os.path.join(dst_base, item)\n",
156
  "\n",
157
  " if os.path.exists(src):\n",
158
  " if os.path.exists(dst):\n",
159
+ " remove_dir(dst)\n",
160
  " os.makedirs(os.path.dirname(dst), exist_ok=True)\n",
161
  " shutil.move(src, dst)\n",
162
  " print(\"\\r🔥 Files moved!\" + \" \"*15)\n",
 
175
  " start_install = time.time()\n",
176
  " print(f\"⌚ Unpacking Stable Diffusion{' (Forge)' if UI == 'Forge' else ''}...\", end='')\n",
177
  "\n",
178
+ " with capture.capture_output():\n",
179
  " download_url = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO.zip\"\n",
180
  " if UI == 'Forge':\n",
181
  " download_url = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO_forge.zip\"\n",
182
  "\n",
 
183
  " zip_path = f\"{root_path}/repo.zip\"\n",
184
+ " !aria2c --console-log-level=error -c -x 16 -s 16 -k 1M {download_url} -d {root_path} -o repo.zip\n",
185
  " !unzip -q -o {zip_path} -d {webui_path}\n",
186
  " !rm -rf {zip_path}\n",
187
  "\n",
188
+ " !echo -n {start_colab} > {webui_path}/static/colabTimer.txt\n",
 
189
  "\n",
190
  " install_time = time.time() - start_install\n",
191
  " minutes, seconds = divmod(int(install_time), 60)\n",
192
  " print(f\"\\r🚀 Unpacking complete! For {minutes:02}:{seconds:02} ⚡\" + \" \"*15)\n",
193
  "\n",
194
+ " if os.path.exists(TEMPORARY_DIR):\n",
195
+ " copy_items_with_replace(TEMPORARY_DIR, webui_path)\n",
196
+ " remove_dir(TEMPORARY_DIR)\n",
197
  "\n",
198
  "# ================= MAIN CODE ==================\n",
199
  "if os.path.exists(webui_path):\n",
200
  " if UI != OLD_UI:\n",
201
  " print(f'Switching the WebUI from \\033[33m{OLD_UI}\\033[0m to \\033[33m{UI}\\033[0m:')\n",
202
+ " copy_items_with_replace(webui_path, TEMPORARY_DIR)\n",
203
+ " remove_dir(webui_path)\n",
204
  " os.environ['SDW_OLD_UI'] = UI\n",
205
  " time.sleep(2)\n",
206
  " clear_output()\n",
207
  "\n",
208
  "if not os.path.exists(webui_path):\n",
209
  " unpack_webui()\n",
210
+ " cfg_download()\n",
211
  "else:\n",
212
  " print(\"🚀 All unpacked... Skip. ⚡\")\n",
213
  " timer_colab = handle_colab_timer(webui_path, start_colab)\n",
 
219
  "if latest_webui or latest_exstensions:\n",
220
  " action = \"WebUI and Extensions\" if latest_webui and latest_exstensions else (\"WebUI\" if latest_webui else \"Extensions\")\n",
221
  " print(f\"⌚️ Updating {action}...\", end='')\n",
222
+ " with capture.capture_output():\n",
223
  " !git config --global user.email \"you@example.com\"\n",
224
  " !git config --global user.name \"Your Name\"\n",
225
  "\n",
 
232
  " ## Update extensions\n",
233
  " if latest_exstensions:\n",
234
  " !{'for dir in ' + webui_path + '/extensions/*/; do cd \\\"$dir\\\" && git reset --hard && git pull; done'}\n",
 
235
  " print(f\"\\r✨ Updating {action} Completed!\")\n",
236
  "\n",
237
  "\n",
238
  "# === FIXING EXTENSIONS ===\n",
239
  "anxety_repos = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main\"\n",
240
+ "with capture.capture_output():\n",
 
241
  " # --- Umi-Wildcard ---\n",
242
  " !sed -i '521s/open=\\(False\\|True\\)/open=False/' {webui_path}/extensions/Umi-AI-Wildcards/scripts/wildcard_recursive.py # Closed accordion by default\n",
243
  " # --- Encrypt-Image ---\n",
244
  " !sed -i '9,37d' {webui_path}/extensions/Encrypt-Image/javascript/encrypt_images_info.js # Removes the weird text in webui\n",
 
245
  "\n",
246
  "\n",
247
  "## Version switching\n",
248
  "if commit_hash:\n",
249
  " print('⏳ Time machine activation...', end=\"\")\n",
250
+ " with capture.capture_output():\n",
251
  " %cd {webui_path}\n",
252
  " !git config --global user.email \"you@example.com\"\n",
253
  " !git config --global user.name \"Your Name\"\n",
254
  " !git reset --hard {commit_hash}\n",
 
255
  " print(f\"\\r⌛️ The time machine has been activated! Current commit: \\033[34m{commit_hash}\\033[0m\")\n",
256
  "\n",
257
  "\n",
 
330
  " model_type = data['files'][1]['type']\n",
331
  " model_name = data['files'][1]['name']\n",
332
  "\n",
333
+ " if file_name and '.' not in file_name:\n",
334
+ " file_extension = model_name.split('.')[-1]\n",
335
+ " model_name = f\"{file_name}.{file_extension}\"\n",
336
+ " elif file_name:\n",
337
+ " model_name = file_name\n",
338
+ "\n",
339
  " return model_type, model_name\n",
340
  "\n",
341
  " def get_download_url(data, model_type):\n",
 
358
  " return None, None\n",
359
  "\n",
360
  " model_type, model_name = get_model_info(url, data)\n",
 
361
  " download_url = get_download_url(data, model_type)\n",
362
  " image_url, image_name = get_image_info(data, model_type, model_name)\n",
363
  "\n",
 
426
  " command = [\"aria2c\"] + aria2_args.split() + [\"-d\", dst_dir, \"-o\", image_name, image_url]\n",
427
  " subprocess.run(command, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)\n",
428
  "\n",
429
+ " elif 'github' in url or 'huggingface.co' in url:\n",
430
+ " if file_name and '.' not in file_name:\n",
431
+ " file_extension = f\"{clean_url.split('/')[-1].split('.', 1)[1]}\"\n",
432
+ " file_name = f\"{file_name}.{file_extension}\"\n",
433
+ " if not file_name:\n",
434
+ " file_name = clean_url.split(\"/\")[-1]\n",
435
  "\n",
436
  " \"\"\" Formatted info output \"\"\"\n",
437
  " try:\n",
 
588
  " download(url)\n",
589
  " print(\"\\n\\033[33m# =============================== #\\n\\033[0m\")\n",
590
  "else:\n",
591
+ " with capture.capture_output():\n",
592
  " download(url)\n",
 
593
  "\n",
594
  "print(\"\\r🏁 Download Complete!\" + \" \"*15)\n",
595
  "\n",
 
601
  "## Install of Custom extensions\n",
602
  "if len(extension_repo) > 0:\n",
603
  " print(\"✨ Installing custom extensions...\", end='')\n",
604
+ " with capture.capture_output():\n",
605
  " for repo, repo_name in extension_repo:\n",
606
  " if not repo_name:\n",
607
  " repo_name = repo.split('/')[-1]\n",
 
609
  " && git clone {repo} {repo_name} \\\n",
610
  " && cd {repo_name} \\\n",
611
  " && git fetch\n",
 
612
  " print(f\"\\r📦 Installed '{len(extension_repo)}', Custom extensions!\")\n",
613
  "\n",
614
  "\n",
files_cells/notebooks/en/widgets_en.ipynb CHANGED
@@ -27,8 +27,7 @@
27
  "import os\n",
28
  "import json\n",
29
  "import time\n",
30
- "import ipywidgets as widgets\n",
31
- "from ipywidgets import widgets, Layout, Label, Button, VBox, HBox\n",
32
  "from IPython.display import display, HTML, Javascript, clear_output\n",
33
  "\n",
34
  "\n",
 
27
  "import os\n",
28
  "import json\n",
29
  "import time\n",
30
+ "from ipywidgets import widgets\n",
 
31
  "from IPython.display import display, HTML, Javascript, clear_output\n",
32
  "\n",
33
  "\n",
files_cells/notebooks/ru/auto_cleaner_ru.ipynb CHANGED
@@ -28,8 +28,7 @@
28
  "\n",
29
  "import os\n",
30
  "import time\n",
31
- "import ipywidgets as widgets\n",
32
- "from ipywidgets import Label, Button, VBox, HBox\n",
33
  "from IPython.display import display, HTML\n",
34
  "\n",
35
  "\n",
@@ -58,7 +57,7 @@
58
  "}\n",
59
  "\n",
60
  "\"\"\" functions \"\"\"\n",
61
- "def clean_directory(directory):\n",
62
  " deleted_files = 0\n",
63
  "\n",
64
  " for root, dirs, files in os.walk(directory):\n",
@@ -67,7 +66,7 @@
67
  "\n",
68
  " if file.endswith(\".txt\"):\n",
69
  " continue\n",
70
- " if file.endswith((\".safetensors\", \".pt\", \".png\", \".jpg\", \".jpeg\")):\n",
71
  " deleted_files += 1\n",
72
  "\n",
73
  " os.remove(file_path)\n",
@@ -89,7 +88,7 @@
89
  "\n",
90
  " for option in selected_cleaners:\n",
91
  " if option in directories:\n",
92
- " deleted_files_dict[option] = clean_directory(directories[option])\n",
93
  "\n",
94
  " output.clear_output()\n",
95
  "\n",
@@ -137,9 +136,9 @@
137
  "auto_cleaner_widget = widgets.SelectMultiple(options=AutoCleaner_options, layout=widgets.Layout(width=\"auto\")).add_class(\"custom-select-multiple_AC\")\n",
138
  "output = widgets.Output().add_class(\"output_AC\")\n",
139
  "\n",
140
- "execute_button = Button(description='Выполнить Очистку').add_class(\"button_execute_AC\").add_class(\"button_AC\")\n",
141
  "execute_button.on_click(on_execute_button_press)\n",
142
- "clear_button = Button(description='Скрыть Виджет').add_class(\"button_clear_AC\").add_class(\"button_AC\")\n",
143
  "clear_button.on_click(on_clear_button_press)\n",
144
  "\n",
145
  "storage_info = widgets.HTML(f'''\n",
@@ -149,7 +148,7 @@
149
  "buttons = widgets.HBox([execute_button, clear_button])\n",
150
  "lower_information_panel = widgets.HBox([buttons, storage_info]).add_class(\"lower_information_panel_AC\")\n",
151
  "\n",
152
- "container = VBox([instruction_label, widgets.HTML('<hr>'), auto_cleaner_widget, output, widgets.HTML('<hr>'), lower_information_panel]).add_class(\"container_AC\")\n",
153
  "\n",
154
  "display(container)"
155
  ]
 
28
  "\n",
29
  "import os\n",
30
  "import time\n",
31
+ "from ipywidgets import widgets\n",
 
32
  "from IPython.display import display, HTML\n",
33
  "\n",
34
  "\n",
 
57
  "}\n",
58
  "\n",
59
  "\"\"\" functions \"\"\"\n",
60
+ "def clean_directory(directory, directory_type):\n",
61
  " deleted_files = 0\n",
62
  "\n",
63
  " for root, dirs, files in os.walk(directory):\n",
 
66
  "\n",
67
  " if file.endswith(\".txt\"):\n",
68
  " continue\n",
69
+ " if file.endswith((\".safetensors\", \".pt\")) or directory_type == \"Images\":\n",
70
  " deleted_files += 1\n",
71
  "\n",
72
  " os.remove(file_path)\n",
 
88
  "\n",
89
  " for option in selected_cleaners:\n",
90
  " if option in directories:\n",
91
+ " deleted_files_dict[option] = clean_directory(directories[option], option)\n",
92
  "\n",
93
  " output.clear_output()\n",
94
  "\n",
 
136
  "auto_cleaner_widget = widgets.SelectMultiple(options=AutoCleaner_options, layout=widgets.Layout(width=\"auto\")).add_class(\"custom-select-multiple_AC\")\n",
137
  "output = widgets.Output().add_class(\"output_AC\")\n",
138
  "\n",
139
+ "execute_button = widgets.Button(description='Выполнить Очистку').add_class(\"button_execute_AC\").add_class(\"button_AC\")\n",
140
  "execute_button.on_click(on_execute_button_press)\n",
141
+ "clear_button = widgets.Button(description='Скрыть Виджет').add_class(\"button_clear_AC\").add_class(\"button_AC\")\n",
142
  "clear_button.on_click(on_clear_button_press)\n",
143
  "\n",
144
  "storage_info = widgets.HTML(f'''\n",
 
148
  "buttons = widgets.HBox([execute_button, clear_button])\n",
149
  "lower_information_panel = widgets.HBox([buttons, storage_info]).add_class(\"lower_information_panel_AC\")\n",
150
  "\n",
151
+ "container = widgets.VBox([instruction_label, widgets.HTML('<hr>'), auto_cleaner_widget, output, widgets.HTML('<hr>'), lower_information_panel]).add_class(\"container_AC\")\n",
152
  "\n",
153
  "display(container)"
154
  ]
files_cells/notebooks/ru/downloading_ru.ipynb CHANGED
@@ -39,6 +39,7 @@
39
  "\n",
40
  "os.chdir(root_path)\n",
41
  "\n",
 
42
  "# ============ loading settings V4 =============\n",
43
  "def load_settings(path):\n",
44
  " if os.path.exists(path):\n",
@@ -94,11 +95,10 @@
94
  " subprocess.run(install_cmd, shell=True, capture_output=True)\n",
95
  "\n",
96
  " # Additional specific packages\n",
97
- " with capture.capture_output() as cap:\n",
98
  " !curl -s -OL https://github.com/DEX-1101/sd-webui-notebook/raw/main/res/new_tunnel --output-dir {root_path}\n",
99
  " !curl -s -Lo /usr/bin/cl https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 && chmod +x /usr/bin/cl\n",
100
  " !curl -sLO https://github.com/openziti/zrok/releases/download/v0.4.32/zrok_0.4.32_linux_amd64.tar.gz && tar -xzf zrok_0.4.32_linux_amd64.tar.gz -C /usr/bin && rm -f zrok_0.4.32_linux_amd64.tar.gz\n",
101
- " del cap\n",
102
  "\n",
103
  " clear_output()\n",
104
  "\n",
@@ -113,23 +113,33 @@
113
  "\n",
114
  "# =================== OTHER ====================\n",
115
  "# Setup Timer\n",
116
- "if \"START_COLAB\" in os.environ:\n",
117
- " start_colab = int(os.environ[\"START_COLAB\"])\n",
118
- "else:\n",
119
- " start_colab = int(time.time()) - 5\n",
120
- " os.environ[\"START_COLAB\"] = str(start_colab)\n",
121
- "\n",
122
- "# remove directory func\n",
123
- "def _remove_dir(directory_path):\n",
 
 
 
 
 
 
 
 
 
 
 
 
124
  " if directory_path and os.path.exists(directory_path):\n",
125
  " try:\n",
126
  " shutil.rmtree(directory_path)\n",
127
  " except Exception:\n",
128
  " !rm -rf {directory_path}\n",
129
  "\n",
130
- "# Save files temporarily\n",
131
- "temporarily_dir = f'{root_path}/temp_dir'\n",
132
- "\n",
133
  "def copy_items_with_replace(src_base, dst_base):\n",
134
  " items_to_copy = [\n",
135
  " 'embeddings',\n",
@@ -140,14 +150,13 @@
140
  " ]\n",
141
  "\n",
142
  " print(\"⌚ Перемещение файлов...\", end='')\n",
143
- " time.sleep(1)\n",
144
  " for item in items_to_copy:\n",
145
  " src = os.path.join(src_base, item)\n",
146
  " dst = os.path.join(dst_base, item)\n",
147
  "\n",
148
  " if os.path.exists(src):\n",
149
  " if os.path.exists(dst):\n",
150
- " _remove_dir(dst)\n",
151
  " os.makedirs(os.path.dirname(dst), exist_ok=True)\n",
152
  " shutil.move(src, dst)\n",
153
  " print(\"\\r🔥 Файлы перемещены!\" + \" \"*15)\n",
@@ -166,40 +175,39 @@
166
  " start_install = time.time()\n",
167
  " print(f\"⌚ Распаковка Stable Diffusion{' (Forge)' if UI == 'Forge' else ''}...\", end='')\n",
168
  "\n",
169
- " with capture.capture_output() as cap:\n",
170
  " download_url = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO.zip\"\n",
171
  " if UI == 'Forge':\n",
172
  " download_url = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO_forge.zip\"\n",
173
  "\n",
174
- " aria2_args = \"--console-log-level=error -c -x 16 -s 16 -k 1M\"\n",
175
  " zip_path = f\"{root_path}/repo.zip\"\n",
176
- " !aria2c {aria2_args} {download_url} -d {root_path} -o repo.zip\n",
177
  " !unzip -q -o {zip_path} -d {webui_path}\n",
178
  " !rm -rf {zip_path}\n",
179
  "\n",
180
- " get_ipython().system(f'echo -n {start_colab} > {webui_path}/static/colabTimer.txt')\n",
181
- " del cap\n",
182
  "\n",
183
  " install_time = time.time() - start_install\n",
184
  " minutes, seconds = divmod(int(install_time), 60)\n",
185
  " print(f\"\\r🚀 Распаковка Завершена! За {minutes:02}:{seconds:02} ⚡\" + \" \"*15)\n",
186
  "\n",
187
- " if os.path.exists(temporarily_dir):\n",
188
- " copy_items_with_replace(temporarily_dir, webui_path)\n",
189
- " _remove_dir(temporarily_dir)\n",
190
  "\n",
191
  "# ================= MAIN CODE ==================\n",
192
  "if os.path.exists(webui_path):\n",
193
  " if UI != OLD_UI:\n",
194
  " print(f'Переключение веб-интерфейса с \\033[33m{OLD_UI}\\033[0m на \\033[33m{UI}\\033[0m:')\n",
195
- " copy_items_with_replace(webui_path, temporarily_dir)\n",
196
- " _remove_dir(webui_path)\n",
197
  " os.environ['SDW_OLD_UI'] = UI\n",
198
  " time.sleep(2)\n",
199
  " clear_output()\n",
200
  "\n",
201
  "if not os.path.exists(webui_path):\n",
202
  " unpack_webui()\n",
 
203
  "else:\n",
204
  " print(\"🚀 Все распакованно... Пропуск. ⚡\")\n",
205
  " timer_colab = handle_colab_timer(webui_path, start_colab)\n",
@@ -211,7 +219,7 @@
211
  "if latest_webui or latest_exstensions:\n",
212
  " action = \"WebUI и Расширений\" if latest_webui and latest_exstensions else (\"WebUI\" if latest_webui else \"Расширений\")\n",
213
  " print(f\"⌚️ Обновление {action}...\", end='')\n",
214
- " with capture.capture_output() as cap:\n",
215
  " !git config --global user.email \"you@example.com\"\n",
216
  " !git config --global user.name \"Your Name\"\n",
217
  "\n",
@@ -224,30 +232,26 @@
224
  " ## Update extensions\n",
225
  " if latest_exstensions:\n",
226
  " !{'for dir in ' + webui_path + '/extensions/*/; do cd \\\"$dir\\\" && git reset --hard && git pull; done'}\n",
227
- " del cap\n",
228
  " print(f\"\\r✨ Обновление {action} Завершено!\")\n",
229
  "\n",
230
  "\n",
231
  "# === FIXING EXTENSIONS ===\n",
232
  "anxety_repos = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main\"\n",
233
- "\n",
234
- "with capture.capture_output() as cap:\n",
235
  " # --- Umi-Wildcard ---\n",
236
  " !sed -i '521s/open=\\(False\\|True\\)/open=False/' {webui_path}/extensions/Umi-AI-Wildcards/scripts/wildcard_recursive.py # Closed accordion by default\n",
237
  " # --- Encrypt-Image ---\n",
238
  " !sed -i '9,37d' {webui_path}/extensions/Encrypt-Image/javascript/encrypt_images_info.js # Removes the weird text in webui\n",
239
- "del cap\n",
240
  "\n",
241
  "\n",
242
  "## Version switching\n",
243
  "if commit_hash:\n",
244
  " print('⏳ Активация машины времени...', end=\"\")\n",
245
- " with capture.capture_output() as cap:\n",
246
  " %cd {webui_path}\n",
247
  " !git config --global user.email \"you@example.com\"\n",
248
  " !git config --global user.name \"Your Name\"\n",
249
  " !git reset --hard {commit_hash}\n",
250
- " del cap\n",
251
  " print(f\"\\r⌛️ Машина времени активированна! Текущий коммит: \\033[34m{commit_hash}\\033[0m\")\n",
252
  "\n",
253
  "\n",
@@ -326,6 +330,12 @@
326
  " model_type = data['files'][1]['type']\n",
327
  " model_name = data['files'][1]['name']\n",
328
  "\n",
 
 
 
 
 
 
329
  " return model_type, model_name\n",
330
  "\n",
331
  " def get_download_url(data, model_type):\n",
@@ -348,7 +358,6 @@
348
  " return None, None\n",
349
  "\n",
350
  " model_type, model_name = get_model_info(url, data)\n",
351
- " model_name = file_name or model_name\n",
352
  " download_url = get_download_url(data, model_type)\n",
353
  " image_url, image_name = get_image_info(data, model_type, model_name)\n",
354
  "\n",
@@ -417,8 +426,12 @@
417
  " command = [\"aria2c\"] + aria2_args.split() + [\"-d\", dst_dir, \"-o\", image_name, image_url]\n",
418
  " subprocess.run(command, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)\n",
419
  "\n",
420
- " elif 'github' in url or \"huggingface.co\" in url:\n",
421
- " file_name = clean_url.split(\"/\")[-1] if file_name is None else file_name\n",
 
 
 
 
422
  "\n",
423
  " \"\"\" Formatted info output \"\"\"\n",
424
  " try:\n",
@@ -575,9 +588,8 @@
575
  " download(url)\n",
576
  " print(\"\\n\\033[33m# =============================== #\\n\\033[0m\")\n",
577
  "else:\n",
578
- " with capture.capture_output() as cap:\n",
579
  " download(url)\n",
580
- " del cap\n",
581
  "\n",
582
  "print(\"\\r🏁 Скачивание Завершено!\" + \" \"*15)\n",
583
  "\n",
@@ -589,7 +601,7 @@
589
  "## Install of Custom extensions\n",
590
  "if len(extension_repo) > 0:\n",
591
  " print(\"✨ Установка кастомных расширений...\", end='')\n",
592
- " with capture.capture_output() as cap:\n",
593
  " for repo, repo_name in extension_repo:\n",
594
  " if not repo_name:\n",
595
  " repo_name = repo.split('/')[-1]\n",
@@ -597,7 +609,6 @@
597
  " && git clone {repo} {repo_name} \\\n",
598
  " && cd {repo_name} \\\n",
599
  " && git fetch\n",
600
- " del cap\n",
601
  " print(f\"\\r📦 Установлено '{len(extension_repo)}', Кастомных расширений!\")\n",
602
  "\n",
603
  "\n",
 
39
  "\n",
40
  "os.chdir(root_path)\n",
41
  "\n",
42
+ "\n",
43
  "# ============ loading settings V4 =============\n",
44
  "def load_settings(path):\n",
45
  " if os.path.exists(path):\n",
 
95
  " subprocess.run(install_cmd, shell=True, capture_output=True)\n",
96
  "\n",
97
  " # Additional specific packages\n",
98
+ " with capture.capture_output():\n",
99
  " !curl -s -OL https://github.com/DEX-1101/sd-webui-notebook/raw/main/res/new_tunnel --output-dir {root_path}\n",
100
  " !curl -s -Lo /usr/bin/cl https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 && chmod +x /usr/bin/cl\n",
101
  " !curl -sLO https://github.com/openziti/zrok/releases/download/v0.4.32/zrok_0.4.32_linux_amd64.tar.gz && tar -xzf zrok_0.4.32_linux_amd64.tar.gz -C /usr/bin && rm -f zrok_0.4.32_linux_amd64.tar.gz\n",
 
102
  "\n",
103
  " clear_output()\n",
104
  "\n",
 
113
  "\n",
114
  "# =================== OTHER ====================\n",
115
  "# Setup Timer\n",
116
+ "start_colab = int(os.environ.get(\"START_COLAB\", time.time() - 5))\n",
117
+ "os.environ[\"START_COLAB\"] = str(start_colab)\n",
118
+ "\n",
119
+ "def download_cfg_files(file_paths, destination_path):\n",
120
+ " base_url = \"https://huggingface.co/NagisaNao/SD-CONFIGS/resolve/main\"\n",
121
+ " for filename in file_paths:\n",
122
+ " file_name = filename.split('/')[-1]\n",
123
+ " !wget -O {destination_path}/{file_name} {base_url}/{filename}\n",
124
+ "\n",
125
+ "def cfg_download():\n",
126
+ " common_files = [\"styles.csv\"]\n",
127
+ " a1111_files = [\"A1111/config.json\", \"A1111/ui-config.json\"]\n",
128
+ " forge_files = [\"reForge/config.json\", \"reForge/ui-config.json\"]\n",
129
+ "\n",
130
+ " with capture.capture_output():\n",
131
+ " download_cfg_files(common_files, webui_path)\n",
132
+ " ui_files = a1111_files if UI == 'A1111' else forge_files\n",
133
+ " download_cfg_files(ui_files, webui_path)\n",
134
+ "\n",
135
+ "def remove_dir(directory_path):\n",
136
  " if directory_path and os.path.exists(directory_path):\n",
137
  " try:\n",
138
  " shutil.rmtree(directory_path)\n",
139
  " except Exception:\n",
140
  " !rm -rf {directory_path}\n",
141
  "\n",
142
+ "TEMPORARY_DIR = f'{root_path}/temp_dir'\n",
 
 
143
  "def copy_items_with_replace(src_base, dst_base):\n",
144
  " items_to_copy = [\n",
145
  " 'embeddings',\n",
 
150
  " ]\n",
151
  "\n",
152
  " print(\"⌚ Перемещение файлов...\", end='')\n",
 
153
  " for item in items_to_copy:\n",
154
  " src = os.path.join(src_base, item)\n",
155
  " dst = os.path.join(dst_base, item)\n",
156
  "\n",
157
  " if os.path.exists(src):\n",
158
  " if os.path.exists(dst):\n",
159
+ " remove_dir(dst)\n",
160
  " os.makedirs(os.path.dirname(dst), exist_ok=True)\n",
161
  " shutil.move(src, dst)\n",
162
  " print(\"\\r🔥 Файлы перемещены!\" + \" \"*15)\n",
 
175
  " start_install = time.time()\n",
176
  " print(f\"⌚ Распаковка Stable Diffusion{' (Forge)' if UI == 'Forge' else ''}...\", end='')\n",
177
  "\n",
178
+ " with capture.capture_output():\n",
179
  " download_url = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO.zip\"\n",
180
  " if UI == 'Forge':\n",
181
  " download_url = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO_forge.zip\"\n",
182
  "\n",
 
183
  " zip_path = f\"{root_path}/repo.zip\"\n",
184
+ " !aria2c --console-log-level=error -c -x 16 -s 16 -k 1M {download_url} -d {root_path} -o repo.zip\n",
185
  " !unzip -q -o {zip_path} -d {webui_path}\n",
186
  " !rm -rf {zip_path}\n",
187
  "\n",
188
+ " !echo -n {start_colab} > {webui_path}/static/colabTimer.txt\n",
 
189
  "\n",
190
  " install_time = time.time() - start_install\n",
191
  " minutes, seconds = divmod(int(install_time), 60)\n",
192
  " print(f\"\\r🚀 Распаковка Завершена! За {minutes:02}:{seconds:02} ⚡\" + \" \"*15)\n",
193
  "\n",
194
+ " if os.path.exists(TEMPORARY_DIR):\n",
195
+ " copy_items_with_replace(TEMPORARY_DIR, webui_path)\n",
196
+ " remove_dir(TEMPORARY_DIR)\n",
197
  "\n",
198
  "# ================= MAIN CODE ==================\n",
199
  "if os.path.exists(webui_path):\n",
200
  " if UI != OLD_UI:\n",
201
  " print(f'Переключение веб-интерфейса с \\033[33m{OLD_UI}\\033[0m на \\033[33m{UI}\\033[0m:')\n",
202
+ " copy_items_with_replace(webui_path, TEMPORARY_DIR)\n",
203
+ " remove_dir(webui_path)\n",
204
  " os.environ['SDW_OLD_UI'] = UI\n",
205
  " time.sleep(2)\n",
206
  " clear_output()\n",
207
  "\n",
208
  "if not os.path.exists(webui_path):\n",
209
  " unpack_webui()\n",
210
+ " cfg_download()\n",
211
  "else:\n",
212
  " print(\"🚀 Все распакованно... Пропуск. ⚡\")\n",
213
  " timer_colab = handle_colab_timer(webui_path, start_colab)\n",
 
219
  "if latest_webui or latest_exstensions:\n",
220
  " action = \"WebUI и Расширений\" if latest_webui and latest_exstensions else (\"WebUI\" if latest_webui else \"Расширений\")\n",
221
  " print(f\"⌚️ Обновление {action}...\", end='')\n",
222
+ " with capture.capture_output():\n",
223
  " !git config --global user.email \"you@example.com\"\n",
224
  " !git config --global user.name \"Your Name\"\n",
225
  "\n",
 
232
  " ## Update extensions\n",
233
  " if latest_exstensions:\n",
234
  " !{'for dir in ' + webui_path + '/extensions/*/; do cd \\\"$dir\\\" && git reset --hard && git pull; done'}\n",
 
235
  " print(f\"\\r✨ Обновление {action} Завершено!\")\n",
236
  "\n",
237
  "\n",
238
  "# === FIXING EXTENSIONS ===\n",
239
  "anxety_repos = \"https://huggingface.co/NagisaNao/fast_repo/resolve/main\"\n",
240
+ "with capture.capture_output():\n",
 
241
  " # --- Umi-Wildcard ---\n",
242
  " !sed -i '521s/open=\\(False\\|True\\)/open=False/' {webui_path}/extensions/Umi-AI-Wildcards/scripts/wildcard_recursive.py # Closed accordion by default\n",
243
  " # --- Encrypt-Image ---\n",
244
  " !sed -i '9,37d' {webui_path}/extensions/Encrypt-Image/javascript/encrypt_images_info.js # Removes the weird text in webui\n",
 
245
  "\n",
246
  "\n",
247
  "## Version switching\n",
248
  "if commit_hash:\n",
249
  " print('⏳ Активация машины времени...', end=\"\")\n",
250
+ " with capture.capture_output():\n",
251
  " %cd {webui_path}\n",
252
  " !git config --global user.email \"you@example.com\"\n",
253
  " !git config --global user.name \"Your Name\"\n",
254
  " !git reset --hard {commit_hash}\n",
 
255
  " print(f\"\\r⌛️ Машина времени активированна! Текущий коммит: \\033[34m{commit_hash}\\033[0m\")\n",
256
  "\n",
257
  "\n",
 
330
  " model_type = data['files'][1]['type']\n",
331
  " model_name = data['files'][1]['name']\n",
332
  "\n",
333
+ " if file_name and '.' not in file_name:\n",
334
+ " file_extension = model_name.split('.')[-1]\n",
335
+ " model_name = f\"{file_name}.{file_extension}\"\n",
336
+ " elif file_name:\n",
337
+ " model_name = file_name\n",
338
+ "\n",
339
  " return model_type, model_name\n",
340
  "\n",
341
  " def get_download_url(data, model_type):\n",
 
358
  " return None, None\n",
359
  "\n",
360
  " model_type, model_name = get_model_info(url, data)\n",
 
361
  " download_url = get_download_url(data, model_type)\n",
362
  " image_url, image_name = get_image_info(data, model_type, model_name)\n",
363
  "\n",
 
426
  " command = [\"aria2c\"] + aria2_args.split() + [\"-d\", dst_dir, \"-o\", image_name, image_url]\n",
427
  " subprocess.run(command, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)\n",
428
  "\n",
429
+ " elif 'github' in url or 'huggingface.co' in url:\n",
430
+ " if file_name and '.' not in file_name:\n",
431
+ " file_extension = f\"{clean_url.split('/')[-1].split('.', 1)[1]}\"\n",
432
+ " file_name = f\"{file_name}.{file_extension}\"\n",
433
+ " if not file_name:\n",
434
+ " file_name = clean_url.split(\"/\")[-1]\n",
435
  "\n",
436
  " \"\"\" Formatted info output \"\"\"\n",
437
  " try:\n",
 
588
  " download(url)\n",
589
  " print(\"\\n\\033[33m# =============================== #\\n\\033[0m\")\n",
590
  "else:\n",
591
+ " with capture.capture_output():\n",
592
  " download(url)\n",
 
593
  "\n",
594
  "print(\"\\r🏁 Скачивание Завершено!\" + \" \"*15)\n",
595
  "\n",
 
601
  "## Install of Custom extensions\n",
602
  "if len(extension_repo) > 0:\n",
603
  " print(\"✨ Установка кастомных расширений...\", end='')\n",
604
+ " with capture.capture_output():\n",
605
  " for repo, repo_name in extension_repo:\n",
606
  " if not repo_name:\n",
607
  " repo_name = repo.split('/')[-1]\n",
 
609
  " && git clone {repo} {repo_name} \\\n",
610
  " && cd {repo_name} \\\n",
611
  " && git fetch\n",
 
612
  " print(f\"\\r📦 Установлено '{len(extension_repo)}', Кастомных расширений!\")\n",
613
  "\n",
614
  "\n",
files_cells/notebooks/ru/widgets_ru.ipynb CHANGED
@@ -27,8 +27,7 @@
27
  "import os\n",
28
  "import json\n",
29
  "import time\n",
30
- "import ipywidgets as widgets\n",
31
- "from ipywidgets import widgets, Layout, Label, Button, VBox, HBox\n",
32
  "from IPython.display import display, HTML, Javascript, clear_output\n",
33
  "\n",
34
  "\n",
 
27
  "import os\n",
28
  "import json\n",
29
  "import time\n",
30
+ "from ipywidgets import widgets\n",
 
31
  "from IPython.display import display, HTML, Javascript, clear_output\n",
32
  "\n",
33
  "\n",
files_cells/python/en/auto_cleaner_en.py CHANGED
@@ -4,8 +4,7 @@ from directory_setup import models_dir, vaes_dir, control_dir, loras_dir, output
4
 
5
  import os
6
  import time
7
- import ipywidgets as widgets
8
- from ipywidgets import Label, Button, VBox, HBox
9
  from IPython.display import display, HTML, Javascript
10
 
11
 
@@ -34,7 +33,7 @@ directories = {
34
  }
35
 
36
  """ functions """
37
- def clean_directory(directory):
38
  deleted_files = 0
39
 
40
  for root, dirs, files in os.walk(directory):
@@ -43,7 +42,7 @@ def clean_directory(directory):
43
 
44
  if file.endswith(".txt"):
45
  continue
46
- if file.endswith((".safetensors", ".pt", ".png", ".jpg", ".jpeg")):
47
  deleted_files += 1
48
 
49
  os.remove(file_path)
@@ -65,7 +64,7 @@ def on_execute_button_press(button):
65
 
66
  for option in selected_cleaners:
67
  if option in directories:
68
- deleted_files_dict[option] = clean_directory(directories[option])
69
 
70
  output.clear_output()
71
 
@@ -113,9 +112,9 @@ instruction_label = widgets.HTML('''
113
  auto_cleaner_widget = widgets.SelectMultiple(options=AutoCleaner_options, layout=widgets.Layout(width='auto')).add_class("custom-select-multiple_AC")
114
  output = widgets.Output().add_class("output_AC")
115
  # ---
116
- execute_button = Button(description='Execute Cleaning').add_class("button_execute_AC").add_class("button_AC")
117
  execute_button.on_click(on_execute_button_press)
118
- clear_button = Button(description='Hide Widget').add_class("button_clear_AC").add_class("button_AC")
119
  clear_button.on_click(on_clear_button_press)
120
  # ---
121
  storage_info = widgets.HTML(f'''
@@ -125,7 +124,7 @@ storage_info = widgets.HTML(f'''
125
  buttons = widgets.HBox([execute_button, clear_button])
126
  lower_information_panel = widgets.HBox([buttons, storage_info]).add_class("lower_information_panel_AC")
127
 
128
- container = VBox([instruction_label, widgets.HTML('<hr>'), auto_cleaner_widget, output, widgets.HTML('<hr>'), lower_information_panel]).add_class("container_AC")
129
 
130
  display(container)
131
 
 
4
 
5
  import os
6
  import time
7
+ from ipywidgets import widgets
 
8
  from IPython.display import display, HTML, Javascript
9
 
10
 
 
33
  }
34
 
35
  """ functions """
36
+ def clean_directory(directory, directory_type):
37
  deleted_files = 0
38
 
39
  for root, dirs, files in os.walk(directory):
 
42
 
43
  if file.endswith(".txt"):
44
  continue
45
+ if file.endswith((".safetensors", ".pt")) or directory_type == "Images":
46
  deleted_files += 1
47
 
48
  os.remove(file_path)
 
64
 
65
  for option in selected_cleaners:
66
  if option in directories:
67
+ deleted_files_dict[option] = clean_directory(directories[option], option)
68
 
69
  output.clear_output()
70
 
 
112
  auto_cleaner_widget = widgets.SelectMultiple(options=AutoCleaner_options, layout=widgets.Layout(width='auto')).add_class("custom-select-multiple_AC")
113
  output = widgets.Output().add_class("output_AC")
114
  # ---
115
+ execute_button = widgets.Button(description='Execute Cleaning').add_class("button_execute_AC").add_class("button_AC")
116
  execute_button.on_click(on_execute_button_press)
117
+ clear_button = widgets.Button(description='Hide Widget').add_class("button_clear_AC").add_class("button_AC")
118
  clear_button.on_click(on_clear_button_press)
119
  # ---
120
  storage_info = widgets.HTML(f'''
 
124
  buttons = widgets.HBox([execute_button, clear_button])
125
  lower_information_panel = widgets.HBox([buttons, storage_info]).add_class("lower_information_panel_AC")
126
 
127
+ container = widgets.VBox([instruction_label, widgets.HTML('<hr>'), auto_cleaner_widget, output, widgets.HTML('<hr>'), lower_information_panel]).add_class("container_AC")
128
 
129
  display(container)
130
 
files_cells/python/en/downloading_en.py CHANGED
@@ -29,6 +29,7 @@ OLD_UI = os.getenv('SDW_OLD_UI')
29
 
30
  os.chdir(root_path)
31
 
 
32
  # ============ loading settings V4 =============
33
  def load_settings(path):
34
  if os.path.exists(path):
@@ -84,11 +85,10 @@ if not os.path.exists(flag_file):
84
  subprocess.run(install_cmd, shell=True, capture_output=True)
85
 
86
  # Additional specific packages
87
- with capture.capture_output() as cap:
88
  get_ipython().system('curl -s -OL https://github.com/DEX-1101/sd-webui-notebook/raw/main/res/new_tunnel --output-dir {root_path}')
89
  get_ipython().system('curl -s -Lo /usr/bin/cl https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 && chmod +x /usr/bin/cl')
90
  get_ipython().system('curl -sLO https://github.com/openziti/zrok/releases/download/v0.4.32/zrok_0.4.32_linux_amd64.tar.gz && tar -xzf zrok_0.4.32_linux_amd64.tar.gz -C /usr/bin && rm -f zrok_0.4.32_linux_amd64.tar.gz')
91
- del cap
92
 
93
  clear_output()
94
 
@@ -103,23 +103,33 @@ if not os.path.exists(flag_file):
103
 
104
  # =================== OTHER ====================
105
  # Setup Timer
106
- if "START_COLAB" in os.environ:
107
- start_colab = int(os.environ["START_COLAB"])
108
- else:
109
- start_colab = int(time.time()) - 5
110
- os.environ["START_COLAB"] = str(start_colab)
111
-
112
- # remove directory func
113
- def _remove_dir(directory_path):
 
 
 
 
 
 
 
 
 
 
 
 
114
  if directory_path and os.path.exists(directory_path):
115
  try:
116
  shutil.rmtree(directory_path)
117
  except Exception:
118
  get_ipython().system('rm -rf {directory_path}')
119
 
120
- # Save files temporarily
121
- temporarily_dir = f'{root_path}/temp_dir'
122
-
123
  def copy_items_with_replace(src_base, dst_base):
124
  items_to_copy = [
125
  'embeddings',
@@ -130,14 +140,13 @@ def copy_items_with_replace(src_base, dst_base):
130
  ]
131
 
132
  print("⌚ Moving files...", end='')
133
- time.sleep(1)
134
  for item in items_to_copy:
135
  src = os.path.join(src_base, item)
136
  dst = os.path.join(dst_base, item)
137
 
138
  if os.path.exists(src):
139
  if os.path.exists(dst):
140
- _remove_dir(dst)
141
  os.makedirs(os.path.dirname(dst), exist_ok=True)
142
  shutil.move(src, dst)
143
  print("\r🔥 Files moved!" + " "*15)
@@ -156,40 +165,39 @@ def unpack_webui():
156
  start_install = time.time()
157
  print(f"⌚ Unpacking Stable Diffusion{' (Forge)' if UI == 'Forge' else ''}...", end='')
158
 
159
- with capture.capture_output() as cap:
160
  download_url = "https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO.zip"
161
  if UI == 'Forge':
162
  download_url = "https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO_forge.zip"
163
 
164
- aria2_args = "--console-log-level=error -c -x 16 -s 16 -k 1M"
165
  zip_path = f"{root_path}/repo.zip"
166
- get_ipython().system('aria2c {aria2_args} {download_url} -d {root_path} -o repo.zip')
167
  get_ipython().system('unzip -q -o {zip_path} -d {webui_path}')
168
  get_ipython().system('rm -rf {zip_path}')
169
 
170
- get_ipython().system(f'echo -n {start_colab} > {webui_path}/static/colabTimer.txt')
171
- del cap
172
 
173
  install_time = time.time() - start_install
174
  minutes, seconds = divmod(int(install_time), 60)
175
  print(f"\r🚀 Unpacking complete! For {minutes:02}:{seconds:02} ⚡" + " "*15)
176
 
177
- if os.path.exists(temporarily_dir):
178
- copy_items_with_replace(temporarily_dir, webui_path)
179
- _remove_dir(temporarily_dir)
180
 
181
  # ================= MAIN CODE ==================
182
  if os.path.exists(webui_path):
183
  if UI != OLD_UI:
184
  print(f'Switching the WebUI from \033[33m{OLD_UI}\033[0m to \033[33m{UI}\033[0m:')
185
- copy_items_with_replace(webui_path, temporarily_dir)
186
- _remove_dir(webui_path)
187
  os.environ['SDW_OLD_UI'] = UI
188
  time.sleep(2)
189
  clear_output()
190
 
191
  if not os.path.exists(webui_path):
192
  unpack_webui()
 
193
  else:
194
  print("🚀 All unpacked... Skip. ⚡")
195
  timer_colab = handle_colab_timer(webui_path, start_colab)
@@ -201,7 +209,7 @@ else:
201
  if latest_webui or latest_exstensions:
202
  action = "WebUI and Extensions" if latest_webui and latest_exstensions else ("WebUI" if latest_webui else "Extensions")
203
  print(f"⌚️ Updating {action}...", end='')
204
- with capture.capture_output() as cap:
205
  get_ipython().system('git config --global user.email "you@example.com"')
206
  get_ipython().system('git config --global user.name "Your Name"')
207
 
@@ -214,30 +222,26 @@ if latest_webui or latest_exstensions:
214
  ## Update extensions
215
  if latest_exstensions:
216
  get_ipython().system('{\'for dir in \' + webui_path + \'/extensions/*/; do cd \\"$dir\\" && git reset --hard && git pull; done\'}')
217
- del cap
218
  print(f"\r✨ Updating {action} Completed!")
219
 
220
 
221
  # === FIXING EXTENSIONS ===
222
  anxety_repos = "https://huggingface.co/NagisaNao/fast_repo/resolve/main"
223
-
224
- with capture.capture_output() as cap:
225
  # --- Umi-Wildcard ---
226
  get_ipython().system("sed -i '521s/open=\\(False\\|True\\)/open=False/' {webui_path}/extensions/Umi-AI-Wildcards/scripts/wildcard_recursive.py # Closed accordion by default")
227
  # --- Encrypt-Image ---
228
  get_ipython().system("sed -i '9,37d' {webui_path}/extensions/Encrypt-Image/javascript/encrypt_images_info.js # Removes the weird text in webui")
229
- del cap
230
 
231
 
232
  ## Version switching
233
  if commit_hash:
234
  print('⏳ Time machine activation...', end="")
235
- with capture.capture_output() as cap:
236
  get_ipython().run_line_magic('cd', '{webui_path}')
237
  get_ipython().system('git config --global user.email "you@example.com"')
238
  get_ipython().system('git config --global user.name "Your Name"')
239
  get_ipython().system('git reset --hard {commit_hash}')
240
- del cap
241
  print(f"\r⌛️ The time machine has been activated! Current commit: \033[34m{commit_hash}\033[0m")
242
 
243
 
@@ -316,6 +320,12 @@ def CivitAi_API(url, file_name=None):
316
  model_type = data['files'][1]['type']
317
  model_name = data['files'][1]['name']
318
 
 
 
 
 
 
 
319
  return model_type, model_name
320
 
321
  def get_download_url(data, model_type):
@@ -338,7 +348,6 @@ def CivitAi_API(url, file_name=None):
338
  return None, None
339
 
340
  model_type, model_name = get_model_info(url, data)
341
- model_name = file_name or model_name
342
  download_url = get_download_url(data, model_type)
343
  image_url, image_name = get_image_info(data, model_type, model_name)
344
 
@@ -407,8 +416,12 @@ def manual_download(url, dst_dir, file_name, prefix=None):
407
  command = ["aria2c"] + aria2_args.split() + ["-d", dst_dir, "-o", image_name, image_url]
408
  subprocess.run(command, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
409
 
410
- elif 'github' in url or "huggingface.co" in url:
411
- file_name = clean_url.split("/")[-1] if file_name is None else file_name
 
 
 
 
412
 
413
  """ Formatted info output """
414
  try:
@@ -565,9 +578,8 @@ if detailed_download == "on":
565
  download(url)
566
  print("\n\033[33m# =============================== #\n\033[0m")
567
  else:
568
- with capture.capture_output() as cap:
569
  download(url)
570
- del cap
571
 
572
  print("\r🏁 Download Complete!" + " "*15)
573
 
@@ -579,12 +591,11 @@ get_ipython().system('find {webui_path} \\( -type d \\( -name ".ipynb_checkpoint
579
  ## Install of Custom extensions
580
  if len(extension_repo) > 0:
581
  print("✨ Installing custom extensions...", end='')
582
- with capture.capture_output() as cap:
583
  for repo, repo_name in extension_repo:
584
  if not repo_name:
585
  repo_name = repo.split('/')[-1]
586
  get_ipython().system('cd {extensions_dir} && git clone {repo} {repo_name} && cd {repo_name} && git fetch')
587
- del cap
588
  print(f"\r📦 Installed '{len(extension_repo)}', Custom extensions!")
589
 
590
 
 
29
 
30
  os.chdir(root_path)
31
 
32
+
33
  # ============ loading settings V4 =============
34
  def load_settings(path):
35
  if os.path.exists(path):
 
85
  subprocess.run(install_cmd, shell=True, capture_output=True)
86
 
87
  # Additional specific packages
88
+ with capture.capture_output():
89
  get_ipython().system('curl -s -OL https://github.com/DEX-1101/sd-webui-notebook/raw/main/res/new_tunnel --output-dir {root_path}')
90
  get_ipython().system('curl -s -Lo /usr/bin/cl https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 && chmod +x /usr/bin/cl')
91
  get_ipython().system('curl -sLO https://github.com/openziti/zrok/releases/download/v0.4.32/zrok_0.4.32_linux_amd64.tar.gz && tar -xzf zrok_0.4.32_linux_amd64.tar.gz -C /usr/bin && rm -f zrok_0.4.32_linux_amd64.tar.gz')
 
92
 
93
  clear_output()
94
 
 
103
 
104
  # =================== OTHER ====================
105
  # Setup Timer
106
+ start_colab = int(os.environ.get("START_COLAB", time.time() - 5))
107
+ os.environ["START_COLAB"] = str(start_colab)
108
+
109
+ def download_cfg_files(file_paths, destination_path):
110
+ base_url = "https://huggingface.co/NagisaNao/SD-CONFIGS/resolve/main"
111
+ for filename in file_paths:
112
+ file_name = filename.split('/')[-1]
113
+ get_ipython().system('wget -O {destination_path}/{file_name} {base_url}/{filename}')
114
+
115
+ def cfg_download():
116
+ common_files = ["styles.csv"]
117
+ a1111_files = ["A1111/config.json", "A1111/ui-config.json"]
118
+ forge_files = ["reForge/config.json", "reForge/ui-config.json"]
119
+
120
+ with capture.capture_output():
121
+ download_cfg_files(common_files, webui_path)
122
+ ui_files = a1111_files if UI == 'A1111' else forge_files
123
+ download_cfg_files(ui_files, webui_path)
124
+
125
+ def remove_dir(directory_path):
126
  if directory_path and os.path.exists(directory_path):
127
  try:
128
  shutil.rmtree(directory_path)
129
  except Exception:
130
  get_ipython().system('rm -rf {directory_path}')
131
 
132
+ TEMPORARY_DIR = f'{root_path}/temp_dir'
 
 
133
  def copy_items_with_replace(src_base, dst_base):
134
  items_to_copy = [
135
  'embeddings',
 
140
  ]
141
 
142
  print("⌚ Moving files...", end='')
 
143
  for item in items_to_copy:
144
  src = os.path.join(src_base, item)
145
  dst = os.path.join(dst_base, item)
146
 
147
  if os.path.exists(src):
148
  if os.path.exists(dst):
149
+ remove_dir(dst)
150
  os.makedirs(os.path.dirname(dst), exist_ok=True)
151
  shutil.move(src, dst)
152
  print("\r🔥 Files moved!" + " "*15)
 
165
  start_install = time.time()
166
  print(f"⌚ Unpacking Stable Diffusion{' (Forge)' if UI == 'Forge' else ''}...", end='')
167
 
168
+ with capture.capture_output():
169
  download_url = "https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO.zip"
170
  if UI == 'Forge':
171
  download_url = "https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO_forge.zip"
172
 
 
173
  zip_path = f"{root_path}/repo.zip"
174
+ get_ipython().system('aria2c --console-log-level=error -c -x 16 -s 16 -k 1M {download_url} -d {root_path} -o repo.zip')
175
  get_ipython().system('unzip -q -o {zip_path} -d {webui_path}')
176
  get_ipython().system('rm -rf {zip_path}')
177
 
178
+ get_ipython().system('echo -n {start_colab} > {webui_path}/static/colabTimer.txt')
 
179
 
180
  install_time = time.time() - start_install
181
  minutes, seconds = divmod(int(install_time), 60)
182
  print(f"\r🚀 Unpacking complete! For {minutes:02}:{seconds:02} ⚡" + " "*15)
183
 
184
+ if os.path.exists(TEMPORARY_DIR):
185
+ copy_items_with_replace(TEMPORARY_DIR, webui_path)
186
+ remove_dir(TEMPORARY_DIR)
187
 
188
  # ================= MAIN CODE ==================
189
  if os.path.exists(webui_path):
190
  if UI != OLD_UI:
191
  print(f'Switching the WebUI from \033[33m{OLD_UI}\033[0m to \033[33m{UI}\033[0m:')
192
+ copy_items_with_replace(webui_path, TEMPORARY_DIR)
193
+ remove_dir(webui_path)
194
  os.environ['SDW_OLD_UI'] = UI
195
  time.sleep(2)
196
  clear_output()
197
 
198
  if not os.path.exists(webui_path):
199
  unpack_webui()
200
+ cfg_download()
201
  else:
202
  print("🚀 All unpacked... Skip. ⚡")
203
  timer_colab = handle_colab_timer(webui_path, start_colab)
 
209
  if latest_webui or latest_exstensions:
210
  action = "WebUI and Extensions" if latest_webui and latest_exstensions else ("WebUI" if latest_webui else "Extensions")
211
  print(f"⌚️ Updating {action}...", end='')
212
+ with capture.capture_output():
213
  get_ipython().system('git config --global user.email "you@example.com"')
214
  get_ipython().system('git config --global user.name "Your Name"')
215
 
 
222
  ## Update extensions
223
  if latest_exstensions:
224
  get_ipython().system('{\'for dir in \' + webui_path + \'/extensions/*/; do cd \\"$dir\\" && git reset --hard && git pull; done\'}')
 
225
  print(f"\r✨ Updating {action} Completed!")
226
 
227
 
228
  # === FIXING EXTENSIONS ===
229
  anxety_repos = "https://huggingface.co/NagisaNao/fast_repo/resolve/main"
230
+ with capture.capture_output():
 
231
  # --- Umi-Wildcard ---
232
  get_ipython().system("sed -i '521s/open=\\(False\\|True\\)/open=False/' {webui_path}/extensions/Umi-AI-Wildcards/scripts/wildcard_recursive.py # Closed accordion by default")
233
  # --- Encrypt-Image ---
234
  get_ipython().system("sed -i '9,37d' {webui_path}/extensions/Encrypt-Image/javascript/encrypt_images_info.js # Removes the weird text in webui")
 
235
 
236
 
237
  ## Version switching
238
  if commit_hash:
239
  print('⏳ Time machine activation...', end="")
240
+ with capture.capture_output():
241
  get_ipython().run_line_magic('cd', '{webui_path}')
242
  get_ipython().system('git config --global user.email "you@example.com"')
243
  get_ipython().system('git config --global user.name "Your Name"')
244
  get_ipython().system('git reset --hard {commit_hash}')
 
245
  print(f"\r⌛️ The time machine has been activated! Current commit: \033[34m{commit_hash}\033[0m")
246
 
247
 
 
320
  model_type = data['files'][1]['type']
321
  model_name = data['files'][1]['name']
322
 
323
+ if file_name and '.' not in file_name:
324
+ file_extension = model_name.split('.')[-1]
325
+ model_name = f"{file_name}.{file_extension}"
326
+ elif file_name:
327
+ model_name = file_name
328
+
329
  return model_type, model_name
330
 
331
  def get_download_url(data, model_type):
 
348
  return None, None
349
 
350
  model_type, model_name = get_model_info(url, data)
 
351
  download_url = get_download_url(data, model_type)
352
  image_url, image_name = get_image_info(data, model_type, model_name)
353
 
 
416
  command = ["aria2c"] + aria2_args.split() + ["-d", dst_dir, "-o", image_name, image_url]
417
  subprocess.run(command, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
418
 
419
+ elif 'github' in url or 'huggingface.co' in url:
420
+ if file_name and '.' not in file_name:
421
+ file_extension = f"{clean_url.split('/')[-1].split('.', 1)[1]}"
422
+ file_name = f"{file_name}.{file_extension}"
423
+ if not file_name:
424
+ file_name = clean_url.split("/")[-1]
425
 
426
  """ Formatted info output """
427
  try:
 
578
  download(url)
579
  print("\n\033[33m# =============================== #\n\033[0m")
580
  else:
581
+ with capture.capture_output():
582
  download(url)
 
583
 
584
  print("\r🏁 Download Complete!" + " "*15)
585
 
 
591
  ## Install of Custom extensions
592
  if len(extension_repo) > 0:
593
  print("✨ Installing custom extensions...", end='')
594
+ with capture.capture_output():
595
  for repo, repo_name in extension_repo:
596
  if not repo_name:
597
  repo_name = repo.split('/')[-1]
598
  get_ipython().system('cd {extensions_dir} && git clone {repo} {repo_name} && cd {repo_name} && git fetch')
 
599
  print(f"\r📦 Installed '{len(extension_repo)}', Custom extensions!")
600
 
601
 
files_cells/python/en/widgets_en.py CHANGED
@@ -3,8 +3,7 @@
3
  import os
4
  import json
5
  import time
6
- import ipywidgets as widgets
7
- from ipywidgets import widgets, Layout, Label, Button, VBox, HBox
8
  from IPython.display import display, HTML, Javascript, clear_output
9
 
10
 
 
3
  import os
4
  import json
5
  import time
6
+ from ipywidgets import widgets
 
7
  from IPython.display import display, HTML, Javascript, clear_output
8
 
9
 
files_cells/python/ru/auto_cleaner_ru.py CHANGED
@@ -4,8 +4,7 @@ from directory_setup import models_dir, vaes_dir, control_dir, loras_dir, output
4
 
5
  import os
6
  import time
7
- import ipywidgets as widgets
8
- from ipywidgets import Label, Button, VBox, HBox
9
  from IPython.display import display, HTML
10
 
11
 
@@ -34,7 +33,7 @@ directories = {
34
  }
35
 
36
  """ functions """
37
- def clean_directory(directory):
38
  deleted_files = 0
39
 
40
  for root, dirs, files in os.walk(directory):
@@ -43,7 +42,7 @@ def clean_directory(directory):
43
 
44
  if file.endswith(".txt"):
45
  continue
46
- if file.endswith((".safetensors", ".pt", ".png", ".jpg", ".jpeg")):
47
  deleted_files += 1
48
 
49
  os.remove(file_path)
@@ -65,7 +64,7 @@ def on_execute_button_press(button):
65
 
66
  for option in selected_cleaners:
67
  if option in directories:
68
- deleted_files_dict[option] = clean_directory(directories[option])
69
 
70
  output.clear_output()
71
 
@@ -113,9 +112,9 @@ instruction_label = widgets.HTML('''
113
  auto_cleaner_widget = widgets.SelectMultiple(options=AutoCleaner_options, layout=widgets.Layout(width="auto")).add_class("custom-select-multiple_AC")
114
  output = widgets.Output().add_class("output_AC")
115
 
116
- execute_button = Button(description='Выполнить Очистку').add_class("button_execute_AC").add_class("button_AC")
117
  execute_button.on_click(on_execute_button_press)
118
- clear_button = Button(description='Скрыть Виджет').add_class("button_clear_AC").add_class("button_AC")
119
  clear_button.on_click(on_clear_button_press)
120
 
121
  storage_info = widgets.HTML(f'''
@@ -125,7 +124,7 @@ storage_info = widgets.HTML(f'''
125
  buttons = widgets.HBox([execute_button, clear_button])
126
  lower_information_panel = widgets.HBox([buttons, storage_info]).add_class("lower_information_panel_AC")
127
 
128
- container = VBox([instruction_label, widgets.HTML('<hr>'), auto_cleaner_widget, output, widgets.HTML('<hr>'), lower_information_panel]).add_class("container_AC")
129
 
130
  display(container)
131
 
 
4
 
5
  import os
6
  import time
7
+ from ipywidgets import widgets
 
8
  from IPython.display import display, HTML
9
 
10
 
 
33
  }
34
 
35
  """ functions """
36
+ def clean_directory(directory, directory_type):
37
  deleted_files = 0
38
 
39
  for root, dirs, files in os.walk(directory):
 
42
 
43
  if file.endswith(".txt"):
44
  continue
45
+ if file.endswith((".safetensors", ".pt")) or directory_type == "Images":
46
  deleted_files += 1
47
 
48
  os.remove(file_path)
 
64
 
65
  for option in selected_cleaners:
66
  if option in directories:
67
+ deleted_files_dict[option] = clean_directory(directories[option], option)
68
 
69
  output.clear_output()
70
 
 
112
  auto_cleaner_widget = widgets.SelectMultiple(options=AutoCleaner_options, layout=widgets.Layout(width="auto")).add_class("custom-select-multiple_AC")
113
  output = widgets.Output().add_class("output_AC")
114
 
115
+ execute_button = widgets.Button(description='Выполнить Очистку').add_class("button_execute_AC").add_class("button_AC")
116
  execute_button.on_click(on_execute_button_press)
117
+ clear_button = widgets.Button(description='Скрыть Виджет').add_class("button_clear_AC").add_class("button_AC")
118
  clear_button.on_click(on_clear_button_press)
119
 
120
  storage_info = widgets.HTML(f'''
 
124
  buttons = widgets.HBox([execute_button, clear_button])
125
  lower_information_panel = widgets.HBox([buttons, storage_info]).add_class("lower_information_panel_AC")
126
 
127
+ container = widgets.VBox([instruction_label, widgets.HTML('<hr>'), auto_cleaner_widget, output, widgets.HTML('<hr>'), lower_information_panel]).add_class("container_AC")
128
 
129
  display(container)
130
 
files_cells/python/ru/downloading_ru.py CHANGED
@@ -29,6 +29,7 @@ OLD_UI = os.getenv('SDW_OLD_UI')
29
 
30
  os.chdir(root_path)
31
 
 
32
  # ============ loading settings V4 =============
33
  def load_settings(path):
34
  if os.path.exists(path):
@@ -84,11 +85,10 @@ if not os.path.exists(flag_file):
84
  subprocess.run(install_cmd, shell=True, capture_output=True)
85
 
86
  # Additional specific packages
87
- with capture.capture_output() as cap:
88
  get_ipython().system('curl -s -OL https://github.com/DEX-1101/sd-webui-notebook/raw/main/res/new_tunnel --output-dir {root_path}')
89
  get_ipython().system('curl -s -Lo /usr/bin/cl https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 && chmod +x /usr/bin/cl')
90
  get_ipython().system('curl -sLO https://github.com/openziti/zrok/releases/download/v0.4.32/zrok_0.4.32_linux_amd64.tar.gz && tar -xzf zrok_0.4.32_linux_amd64.tar.gz -C /usr/bin && rm -f zrok_0.4.32_linux_amd64.tar.gz')
91
- del cap
92
 
93
  clear_output()
94
 
@@ -103,23 +103,33 @@ if not os.path.exists(flag_file):
103
 
104
  # =================== OTHER ====================
105
  # Setup Timer
106
- if "START_COLAB" in os.environ:
107
- start_colab = int(os.environ["START_COLAB"])
108
- else:
109
- start_colab = int(time.time()) - 5
110
- os.environ["START_COLAB"] = str(start_colab)
111
-
112
- # remove directory func
113
- def _remove_dir(directory_path):
 
 
 
 
 
 
 
 
 
 
 
 
114
  if directory_path and os.path.exists(directory_path):
115
  try:
116
  shutil.rmtree(directory_path)
117
  except Exception:
118
  get_ipython().system('rm -rf {directory_path}')
119
 
120
- # Save files temporarily
121
- temporarily_dir = f'{root_path}/temp_dir'
122
-
123
  def copy_items_with_replace(src_base, dst_base):
124
  items_to_copy = [
125
  'embeddings',
@@ -130,14 +140,13 @@ def copy_items_with_replace(src_base, dst_base):
130
  ]
131
 
132
  print("⌚ Перемещение файлов...", end='')
133
- time.sleep(1)
134
  for item in items_to_copy:
135
  src = os.path.join(src_base, item)
136
  dst = os.path.join(dst_base, item)
137
 
138
  if os.path.exists(src):
139
  if os.path.exists(dst):
140
- _remove_dir(dst)
141
  os.makedirs(os.path.dirname(dst), exist_ok=True)
142
  shutil.move(src, dst)
143
  print("\r🔥 Файлы перемещены!" + " "*15)
@@ -156,40 +165,39 @@ def unpack_webui():
156
  start_install = time.time()
157
  print(f"⌚ Распаковка Stable Diffusion{' (Forge)' if UI == 'Forge' else ''}...", end='')
158
 
159
- with capture.capture_output() as cap:
160
  download_url = "https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO.zip"
161
  if UI == 'Forge':
162
  download_url = "https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO_forge.zip"
163
 
164
- aria2_args = "--console-log-level=error -c -x 16 -s 16 -k 1M"
165
  zip_path = f"{root_path}/repo.zip"
166
- get_ipython().system('aria2c {aria2_args} {download_url} -d {root_path} -o repo.zip')
167
  get_ipython().system('unzip -q -o {zip_path} -d {webui_path}')
168
  get_ipython().system('rm -rf {zip_path}')
169
 
170
- get_ipython().system(f'echo -n {start_colab} > {webui_path}/static/colabTimer.txt')
171
- del cap
172
 
173
  install_time = time.time() - start_install
174
  minutes, seconds = divmod(int(install_time), 60)
175
  print(f"\r🚀 Распаковка Завершена! За {minutes:02}:{seconds:02} ⚡" + " "*15)
176
 
177
- if os.path.exists(temporarily_dir):
178
- copy_items_with_replace(temporarily_dir, webui_path)
179
- _remove_dir(temporarily_dir)
180
 
181
  # ================= MAIN CODE ==================
182
  if os.path.exists(webui_path):
183
  if UI != OLD_UI:
184
  print(f'Переключение веб-интерфейса с \033[33m{OLD_UI}\033[0m на \033[33m{UI}\033[0m:')
185
- copy_items_with_replace(webui_path, temporarily_dir)
186
- _remove_dir(webui_path)
187
  os.environ['SDW_OLD_UI'] = UI
188
  time.sleep(2)
189
  clear_output()
190
 
191
  if not os.path.exists(webui_path):
192
  unpack_webui()
 
193
  else:
194
  print("🚀 Все распакованно... Пропуск. ⚡")
195
  timer_colab = handle_colab_timer(webui_path, start_colab)
@@ -201,7 +209,7 @@ else:
201
  if latest_webui or latest_exstensions:
202
  action = "WebUI и Расширений" if latest_webui and latest_exstensions else ("WebUI" if latest_webui else "Расширений")
203
  print(f"⌚️ Обновление {action}...", end='')
204
- with capture.capture_output() as cap:
205
  get_ipython().system('git config --global user.email "you@example.com"')
206
  get_ipython().system('git config --global user.name "Your Name"')
207
 
@@ -214,30 +222,26 @@ if latest_webui or latest_exstensions:
214
  ## Update extensions
215
  if latest_exstensions:
216
  get_ipython().system('{\'for dir in \' + webui_path + \'/extensions/*/; do cd \\"$dir\\" && git reset --hard && git pull; done\'}')
217
- del cap
218
  print(f"\r✨ Обновление {action} Завершено!")
219
 
220
 
221
  # === FIXING EXTENSIONS ===
222
  anxety_repos = "https://huggingface.co/NagisaNao/fast_repo/resolve/main"
223
-
224
- with capture.capture_output() as cap:
225
  # --- Umi-Wildcard ---
226
  get_ipython().system("sed -i '521s/open=\\(False\\|True\\)/open=False/' {webui_path}/extensions/Umi-AI-Wildcards/scripts/wildcard_recursive.py # Closed accordion by default")
227
  # --- Encrypt-Image ---
228
  get_ipython().system("sed -i '9,37d' {webui_path}/extensions/Encrypt-Image/javascript/encrypt_images_info.js # Removes the weird text in webui")
229
- del cap
230
 
231
 
232
  ## Version switching
233
  if commit_hash:
234
  print('⏳ Активация машины времени...', end="")
235
- with capture.capture_output() as cap:
236
  get_ipython().run_line_magic('cd', '{webui_path}')
237
  get_ipython().system('git config --global user.email "you@example.com"')
238
  get_ipython().system('git config --global user.name "Your Name"')
239
  get_ipython().system('git reset --hard {commit_hash}')
240
- del cap
241
  print(f"\r⌛️ Машина времени активированна! Текущий коммит: \033[34m{commit_hash}\033[0m")
242
 
243
 
@@ -316,6 +320,12 @@ def CivitAi_API(url, file_name=None):
316
  model_type = data['files'][1]['type']
317
  model_name = data['files'][1]['name']
318
 
 
 
 
 
 
 
319
  return model_type, model_name
320
 
321
  def get_download_url(data, model_type):
@@ -338,7 +348,6 @@ def CivitAi_API(url, file_name=None):
338
  return None, None
339
 
340
  model_type, model_name = get_model_info(url, data)
341
- model_name = file_name or model_name
342
  download_url = get_download_url(data, model_type)
343
  image_url, image_name = get_image_info(data, model_type, model_name)
344
 
@@ -407,8 +416,12 @@ def manual_download(url, dst_dir, file_name, prefix=None):
407
  command = ["aria2c"] + aria2_args.split() + ["-d", dst_dir, "-o", image_name, image_url]
408
  subprocess.run(command, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
409
 
410
- elif 'github' in url or "huggingface.co" in url:
411
- file_name = clean_url.split("/")[-1] if file_name is None else file_name
 
 
 
 
412
 
413
  """ Formatted info output """
414
  try:
@@ -565,9 +578,8 @@ if detailed_download == "on":
565
  download(url)
566
  print("\n\033[33m# =============================== #\n\033[0m")
567
  else:
568
- with capture.capture_output() as cap:
569
  download(url)
570
- del cap
571
 
572
  print("\r🏁 Скачивание Завершено!" + " "*15)
573
 
@@ -579,12 +591,11 @@ get_ipython().system('find {webui_path} \\( -type d \\( -name ".ipynb_checkpoint
579
  ## Install of Custom extensions
580
  if len(extension_repo) > 0:
581
  print("✨ Установка кастомных расширений...", end='')
582
- with capture.capture_output() as cap:
583
  for repo, repo_name in extension_repo:
584
  if not repo_name:
585
  repo_name = repo.split('/')[-1]
586
  get_ipython().system('cd {extensions_dir} && git clone {repo} {repo_name} && cd {repo_name} && git fetch')
587
- del cap
588
  print(f"\r📦 Установле��о '{len(extension_repo)}', Кастомных расширений!")
589
 
590
 
 
29
 
30
  os.chdir(root_path)
31
 
32
+
33
  # ============ loading settings V4 =============
34
  def load_settings(path):
35
  if os.path.exists(path):
 
85
  subprocess.run(install_cmd, shell=True, capture_output=True)
86
 
87
  # Additional specific packages
88
+ with capture.capture_output():
89
  get_ipython().system('curl -s -OL https://github.com/DEX-1101/sd-webui-notebook/raw/main/res/new_tunnel --output-dir {root_path}')
90
  get_ipython().system('curl -s -Lo /usr/bin/cl https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 && chmod +x /usr/bin/cl')
91
  get_ipython().system('curl -sLO https://github.com/openziti/zrok/releases/download/v0.4.32/zrok_0.4.32_linux_amd64.tar.gz && tar -xzf zrok_0.4.32_linux_amd64.tar.gz -C /usr/bin && rm -f zrok_0.4.32_linux_amd64.tar.gz')
 
92
 
93
  clear_output()
94
 
 
103
 
104
  # =================== OTHER ====================
105
  # Setup Timer
106
+ start_colab = int(os.environ.get("START_COLAB", time.time() - 5))
107
+ os.environ["START_COLAB"] = str(start_colab)
108
+
109
+ def download_cfg_files(file_paths, destination_path):
110
+ base_url = "https://huggingface.co/NagisaNao/SD-CONFIGS/resolve/main"
111
+ for filename in file_paths:
112
+ file_name = filename.split('/')[-1]
113
+ get_ipython().system('wget -O {destination_path}/{file_name} {base_url}/{filename}')
114
+
115
+ def cfg_download():
116
+ common_files = ["styles.csv"]
117
+ a1111_files = ["A1111/config.json", "A1111/ui-config.json"]
118
+ forge_files = ["reForge/config.json", "reForge/ui-config.json"]
119
+
120
+ with capture.capture_output():
121
+ download_cfg_files(common_files, webui_path)
122
+ ui_files = a1111_files if UI == 'A1111' else forge_files
123
+ download_cfg_files(ui_files, webui_path)
124
+
125
+ def remove_dir(directory_path):
126
  if directory_path and os.path.exists(directory_path):
127
  try:
128
  shutil.rmtree(directory_path)
129
  except Exception:
130
  get_ipython().system('rm -rf {directory_path}')
131
 
132
+ TEMPORARY_DIR = f'{root_path}/temp_dir'
 
 
133
  def copy_items_with_replace(src_base, dst_base):
134
  items_to_copy = [
135
  'embeddings',
 
140
  ]
141
 
142
  print("⌚ Перемещение файлов...", end='')
 
143
  for item in items_to_copy:
144
  src = os.path.join(src_base, item)
145
  dst = os.path.join(dst_base, item)
146
 
147
  if os.path.exists(src):
148
  if os.path.exists(dst):
149
+ remove_dir(dst)
150
  os.makedirs(os.path.dirname(dst), exist_ok=True)
151
  shutil.move(src, dst)
152
  print("\r🔥 Файлы перемещены!" + " "*15)
 
165
  start_install = time.time()
166
  print(f"⌚ Распаковка Stable Diffusion{' (Forge)' if UI == 'Forge' else ''}...", end='')
167
 
168
+ with capture.capture_output():
169
  download_url = "https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO.zip"
170
  if UI == 'Forge':
171
  download_url = "https://huggingface.co/NagisaNao/fast_repo/resolve/main/FULL_REPO_forge.zip"
172
 
 
173
  zip_path = f"{root_path}/repo.zip"
174
+ get_ipython().system('aria2c --console-log-level=error -c -x 16 -s 16 -k 1M {download_url} -d {root_path} -o repo.zip')
175
  get_ipython().system('unzip -q -o {zip_path} -d {webui_path}')
176
  get_ipython().system('rm -rf {zip_path}')
177
 
178
+ get_ipython().system('echo -n {start_colab} > {webui_path}/static/colabTimer.txt')
 
179
 
180
  install_time = time.time() - start_install
181
  minutes, seconds = divmod(int(install_time), 60)
182
  print(f"\r🚀 Распаковка Завершена! За {minutes:02}:{seconds:02} ⚡" + " "*15)
183
 
184
+ if os.path.exists(TEMPORARY_DIR):
185
+ copy_items_with_replace(TEMPORARY_DIR, webui_path)
186
+ remove_dir(TEMPORARY_DIR)
187
 
188
  # ================= MAIN CODE ==================
189
  if os.path.exists(webui_path):
190
  if UI != OLD_UI:
191
  print(f'Переключение веб-интерфейса с \033[33m{OLD_UI}\033[0m на \033[33m{UI}\033[0m:')
192
+ copy_items_with_replace(webui_path, TEMPORARY_DIR)
193
+ remove_dir(webui_path)
194
  os.environ['SDW_OLD_UI'] = UI
195
  time.sleep(2)
196
  clear_output()
197
 
198
  if not os.path.exists(webui_path):
199
  unpack_webui()
200
+ cfg_download()
201
  else:
202
  print("🚀 Все распакованно... Пропуск. ⚡")
203
  timer_colab = handle_colab_timer(webui_path, start_colab)
 
209
  if latest_webui or latest_exstensions:
210
  action = "WebUI и Расширений" if latest_webui and latest_exstensions else ("WebUI" if latest_webui else "Расширений")
211
  print(f"⌚️ Обновление {action}...", end='')
212
+ with capture.capture_output():
213
  get_ipython().system('git config --global user.email "you@example.com"')
214
  get_ipython().system('git config --global user.name "Your Name"')
215
 
 
222
  ## Update extensions
223
  if latest_exstensions:
224
  get_ipython().system('{\'for dir in \' + webui_path + \'/extensions/*/; do cd \\"$dir\\" && git reset --hard && git pull; done\'}')
 
225
  print(f"\r✨ Обновление {action} Завершено!")
226
 
227
 
228
  # === FIXING EXTENSIONS ===
229
  anxety_repos = "https://huggingface.co/NagisaNao/fast_repo/resolve/main"
230
+ with capture.capture_output():
 
231
  # --- Umi-Wildcard ---
232
  get_ipython().system("sed -i '521s/open=\\(False\\|True\\)/open=False/' {webui_path}/extensions/Umi-AI-Wildcards/scripts/wildcard_recursive.py # Closed accordion by default")
233
  # --- Encrypt-Image ---
234
  get_ipython().system("sed -i '9,37d' {webui_path}/extensions/Encrypt-Image/javascript/encrypt_images_info.js # Removes the weird text in webui")
 
235
 
236
 
237
  ## Version switching
238
  if commit_hash:
239
  print('⏳ Активация машины времени...', end="")
240
+ with capture.capture_output():
241
  get_ipython().run_line_magic('cd', '{webui_path}')
242
  get_ipython().system('git config --global user.email "you@example.com"')
243
  get_ipython().system('git config --global user.name "Your Name"')
244
  get_ipython().system('git reset --hard {commit_hash}')
 
245
  print(f"\r⌛️ Машина времени активированна! Текущий коммит: \033[34m{commit_hash}\033[0m")
246
 
247
 
 
320
  model_type = data['files'][1]['type']
321
  model_name = data['files'][1]['name']
322
 
323
+ if file_name and '.' not in file_name:
324
+ file_extension = model_name.split('.')[-1]
325
+ model_name = f"{file_name}.{file_extension}"
326
+ elif file_name:
327
+ model_name = file_name
328
+
329
  return model_type, model_name
330
 
331
  def get_download_url(data, model_type):
 
348
  return None, None
349
 
350
  model_type, model_name = get_model_info(url, data)
 
351
  download_url = get_download_url(data, model_type)
352
  image_url, image_name = get_image_info(data, model_type, model_name)
353
 
 
416
  command = ["aria2c"] + aria2_args.split() + ["-d", dst_dir, "-o", image_name, image_url]
417
  subprocess.run(command, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
418
 
419
+ elif 'github' in url or 'huggingface.co' in url:
420
+ if file_name and '.' not in file_name:
421
+ file_extension = f"{clean_url.split('/')[-1].split('.', 1)[1]}"
422
+ file_name = f"{file_name}.{file_extension}"
423
+ if not file_name:
424
+ file_name = clean_url.split("/")[-1]
425
 
426
  """ Formatted info output """
427
  try:
 
578
  download(url)
579
  print("\n\033[33m# =============================== #\n\033[0m")
580
  else:
581
+ with capture.capture_output():
582
  download(url)
 
583
 
584
  print("\r🏁 Скачивание Завершено!" + " "*15)
585
 
 
591
  ## Install of Custom extensions
592
  if len(extension_repo) > 0:
593
  print("✨ Установка кастомных расширений...", end='')
594
+ with capture.capture_output():
595
  for repo, repo_name in extension_repo:
596
  if not repo_name:
597
  repo_name = repo.split('/')[-1]
598
  get_ipython().system('cd {extensions_dir} && git clone {repo} {repo_name} && cd {repo_name} && git fetch')
 
599
  print(f"\r📦 Установле��о '{len(extension_repo)}', Кастомных расширений!")
600
 
601
 
files_cells/python/ru/widgets_ru.py CHANGED
@@ -3,8 +3,7 @@
3
  import os
4
  import json
5
  import time
6
- import ipywidgets as widgets
7
- from ipywidgets import widgets, Layout, Label, Button, VBox, HBox
8
  from IPython.display import display, HTML, Javascript, clear_output
9
 
10
 
 
3
  import os
4
  import json
5
  import time
6
+ from ipywidgets import widgets
 
7
  from IPython.display import display, HTML, Javascript, clear_output
8
 
9