Eolite/KFM2 beta 12:

- fully rework of popins
- user can edit current path now
- fixed: now folders can be renamed and even "open with" from menu
- fixed: now popin is shown only on the active panel in kfm2
- fixed: popin doesn't close on error while renaming or creating file/folder

git-svn-id: svn://kolibrios.org@8953 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Kirill Lipatov (Leency) 2021-06-28 10:55:08 +00:00
parent 0f76213e5a
commit 956739a5ad
7 changed files with 218 additions and 269 deletions

View File

@ -2,16 +2,18 @@
//GNU GPL license. //GNU GPL license.
/* /*
TODO: BUGS:
- fix a kfm2 bug with selected files on window deactivation - fix a kfm2 bug with selected files on window deactivation
- click on a path bar opens edit - back button broken
- click to show breadcrumbs - bug with going to wrong path (related to prior issue?)
TODO:
- 70.5 - get volume info and label - 70.5 - get volume info and label
- click on a path bar dropdown opens breadcrumbs
*/ */
#define ABOUT_TITLE "EOLITE 5 Beta11" #define ABOUT_TITLE "EOLITE 5 Beta12"
#define TITLE_EOLITE "Eolite File Manager 5 Beta11" #define TITLE_EOLITE "Eolite File Manager 5 Beta12"
#define TITLE_KFM "Kolibri File Manager 2 Beta11"; #define TITLE_KFM "Kolibri File Manager 2 Beta12";
#define MEMSIZE 1024 * 250 #define MEMSIZE 1024 * 250
#include "../lib/clipboard.h" #include "../lib/clipboard.h"
@ -34,11 +36,9 @@ TODO:
#include "imgs/images.h" #include "imgs/images.h"
#include "include/const.h" #include "include/const.h"
_history history;
struct Eolite_colors struct Eolite_colors
{ {
bool def; bool skin_is_dark;
dword lpanel; dword lpanel;
dword list_vert_line; //vertical line between columns in list dword list_vert_line; //vertical line between columns in list
dword selec; dword selec;
@ -55,16 +55,9 @@ struct Eolite_colors
} col; } col;
dword waves_pal[256]; dword waves_pal[256];
//Global data
bool efm = false; bool efm = false;
_history history;
int toolbar_buttons_x[7]={9,46,85,134,167,203};
byte del_active=0;
byte new_element_active=0;
llist files, files_active, files_inactive;
bool list_full_redraw;
//Folder data //Folder data
dword buf; dword buf;
@ -74,10 +67,9 @@ bool list_full_redraw;
dword path; dword path;
bool dir_at_fat16 = NULL; bool dir_at_fat16 = NULL;
//Sselected element data //Selected element data
byte file_path[4096]; byte file_path[4096];
byte file_name[256]; byte file_name[256];
byte new_element_name[256];
byte temp[4096]; byte temp[4096];
bool itdir; bool itdir;
@ -89,6 +81,8 @@ bool list_full_redraw;
bool sort_desc=false; bool sort_desc=false;
int status_bar_h; int status_bar_h;
int icon_size = 18; int icon_size = 18;
char active_popin = NULL;
bool list_full_redraw;
//Threads data //Threads data
dword about_thread_id; dword about_thread_id;
@ -103,15 +97,17 @@ bool list_full_redraw;
int disk_popin_active_on_panel=0; int disk_popin_active_on_panel=0;
#define PANES_COUNT 2 #define PANES_COUNT 2
dword location[PANES_COUNT]; dword location[PANES_COUNT];
llist files, files_active, files_inactive;
libimg_image icons16_default; libimg_image icons16_default;
libimg_image icons16_selected; libimg_image icons16_selected;
libimg_image icons32_default; libimg_image icons32_default;
libimg_image icons32_selected; libimg_image icons32_selected;
edit_box new_file_ed = {200,213,180,0xFFFFFF,0x94AECE,0xFFFFFF,0xFFFFFF,0x10000000, byte popin_string[4096];
248,#new_element_name,0,ed_focus+ed_always_focus,6,0}; edit_box popin_text = {200,213,180,0xFFFFFF,0x94AECE,0xFFFFFF,0xFFFFFF,0x10000000,
248,#popin_string,0,ed_focus+ed_always_focus,6,0};
PathShow_data FileShow = {0, 56,215, 8, 100, 1, 0, 0x0, 0xFFFfff, #file_name, #temp, 0}; PathShow_data FileShow = {0, 56,215, 8, 100, 1, 0, 0x0, 0xFFFfff, #file_name, #temp, 0};
#include "include\settings.h" #include "include\settings.h"
@ -199,10 +195,10 @@ void main()
loop() switch(@WaitEventTimeout(100)) loop() switch(@WaitEventTimeout(100))
{ {
case evMouse: case evMouse:
if (del_active) || (disk_popin_active_on_panel) || (Form.status_window&ROLLED_UP) break; if (Form.status_window&ROLLED_UP) break;
if (new_element_active)
{ if (active_popin) {
edit_box_mouse stdcall(#new_file_ed); if (popin_string[0]!=-1) edit_box_mouse stdcall(#popin_text);
break; break;
} }
@ -301,38 +297,42 @@ void main()
case evButton: case evButton:
id = GetButtonID(); id = GetButtonID();
if (id==CLOSE_BTN) { if (CLOSE_BTN == id) {
KillProcess(about_thread_id); KillProcess(about_thread_id);
SaveIniSettings(); SaveIniSettings();
ExitProcess(); ExitProcess();
} }
if (new_element_active) || (del_active) || (disk_popin_active_on_panel) { if (active_popin) {
if (POPUP_BTN1==id) && (del_active) EventDelete(); if (POPIN_DISK==active_popin) {
if (POPUP_BTN1==id) && (new_element_active) NewElement(); if (id>=100) && (id<=120) {
if (POPUP_BTN2==id) EventClosePopinForm(); active_popin = NULL;
if (disk_popin_active_on_panel) { EventDriveClick(id);
if (id>=100) && (id<=120) EventDriveClick(id);
else EventClosePopinForm();
} }
EventClosePopinForm(); //POPIN_DISK create close btn with POPUP_BTN2
break; }
if (POPUP_BTN2==id) EventClosePopinForm();
if (POPUP_BTN1==id) EventPopinClickOkay();
break; break;
} }
switch(id) switch(id)
{ {
case PATH_BTN:
notify(COPY_PATH_STR);
Clipboard__CopyText(path);
break;
case KFM_DEV_DROPDOWN_1: case KFM_DEV_DROPDOWN_1:
case KFM_DEV_DROPDOWN_1+1:
case KFM_DEV_DROPDOWN_2: case KFM_DEV_DROPDOWN_2:
case KFM_DEV_DROPDOWN_2+1: ShowPopinForm(POPIN_DISK);
EventOpenDiskPopin(active_panel);
break; break;
case BACK_BTN...PASTE_BTN: case BACK_BTN...PASTE_BTN:
EventToolbarButtonClick(id); EventToolbarButtonClick(id);
break; break;
case BTN_PATH:
case BTN_PATH+1:
ShowPopinForm(POPIN_PATH);
break;
case BTN_BREADCRUMB:
case BTN_BREADCRUMB+1:
ShowPopinForm(POPIN_BREADCR);
break;
case 31...33: case 31...33:
EventSort(id-30); EventSort(id-30);
break; break;
@ -342,9 +342,6 @@ void main()
case 52...60: //Actions case 52...60: //Actions
FnProcess(id-50); FnProcess(id-50);
break; break;
case 61: // Set path as default
SetDefaultPath(path);
break;
case 100...120: case 100...120:
EventDriveClick(id); EventDriveClick(id);
break; break;
@ -363,26 +360,25 @@ void main()
if (Form.status_window&ROLLED_UP) break; if (Form.status_window&ROLLED_UP) break;
if (new_element_active) || (del_active) || (disk_popin_active_on_panel) if (active_popin)
{ {
if (key_scancode == SCAN_CODE_ESC) EventClosePopinForm(); if (key_scancode == SCAN_CODE_ESC) EventClosePopinForm();
if (del_active) { if (POPIN_DISK == active_popin) {
if (key_scancode == SCAN_CODE_ENTER) EventDelete(); if (key_scancode >= SCAN_CODE_1)
&& (key_scancode >= SCAN_CODE_10) {
EventDriveClick(key_scancode-1+100);
} }
if (new_element_active) { } else {
if (key_scancode == SCAN_CODE_ENTER) NewElement(); if (key_scancode == SCAN_CODE_ENTER) EventPopinClickOkay();
if (popin_string[0] != -1) {
EAX = key_editbox; EAX = key_editbox;
edit_box_key stdcall (#new_file_ed); edit_box_key stdcall (#popin_text);
}
} }
break; break;
} }
if (key_modifier&KEY_LALT) || (key_modifier&KEY_RALT) {
if (key_scancode == SCAN_CODE_F1) EventOpenDiskPopin(1);
if (key_scancode == SCAN_CODE_F2) EventOpenDiskPopin(2);
break;
}
if (key_modifier&KEY_LSHIFT) || (key_modifier&KEY_RSHIFT) { if (key_modifier&KEY_LSHIFT) || (key_modifier&KEY_RSHIFT) {
if (key_scancode == SCAN_CODE_ENTER) { if (key_scancode == SCAN_CODE_ENTER) {
@ -409,7 +405,13 @@ void main()
case SCAN_CODE_F1...SCAN_CODE_F3: case SCAN_CODE_F1...SCAN_CODE_F3:
EventSort(key_scancode - 58); EventSort(key_scancode - 58);
break; break;
case SCAN_CODE_1...SCAN_CODE_10: case SCAN_CODE_1...SCAN_CODE_2:
if (efm) {
active_panel = key_scancode - SCAN_CODE_1;
ShowPopinForm(POPIN_DISK);
break;
}
case SCAN_CODE_3...SCAN_CODE_10:
key_scancode-=2; key_scancode-=2;
if (key_scancode >= SystemDiscs.list.count) break; if (key_scancode >= SystemDiscs.list.count) break;
if (!efm) { if (!efm) {
@ -473,7 +475,7 @@ void main()
EventShowListMenu(); EventShowListMenu();
break; break;
case SCAN_CODE_DEL: case SCAN_CODE_DEL:
Del_Form(); ShowPopinForm(POPIN_DELETE);
break; break;
case SCAN_CODE_SPACE: case SCAN_CODE_SPACE:
EventChooseFile(files.cur_y); EventChooseFile(files.cur_y);
@ -540,7 +542,7 @@ void draw_window()
DrawBar(0, SELECTY+KFM2_DEVH+1, Form.cwidth, 3, sc.work); DrawBar(0, SELECTY+KFM2_DEVH+1, Form.cwidth, 3, sc.work);
DrawBar(0, SELECTY-1, 1, KFM2_DEVH+2, sc.work); DrawBar(0, SELECTY-1, 1, KFM2_DEVH+2, sc.work);
DrawBar(Form.cwidth-1, SELECTY-1, 1, KFM2_DEVH+2, sc.work); DrawBar(Form.cwidth-1, SELECTY-1, 1, KFM2_DEVH+2, sc.work);
DrawBar(Form.cwidth/2-16, SELECTY-1, 16, KFM2_DEVH+2, sc.work); DrawBar(Form.cwidth/2-16, SELECTY-1, 15, KFM2_DEVH+2, sc.work);
/* /*
#define PAD 7 #define PAD 7
#define GAP_S 26+5 #define GAP_S 26+5
@ -726,8 +728,9 @@ void List_ReDraw()
DrawBar(files.x+files.w-68,all_lines_h + files.y,1,files.h - all_lines_h, separator_color); DrawBar(files.x+files.w-68,all_lines_h + files.y,1,files.h - all_lines_h, separator_color);
DrawScroll(scroll_used); DrawScroll(scroll_used);
if (del_active) Del_Form(); if (files.x!=files_inactive.x) {
if (new_element_active) && (col.selec != 0xCCCccc) NewElement_Form(new_element_active, #new_element_name); if (active_popin) ShowPopinForm(active_popin);
}
} }
void Line_ReDraw(dword bgcol, filenum){ void Line_ReDraw(dword bgcol, filenum){
@ -751,7 +754,7 @@ void Line_ReDraw(dword bgcol, filenum){
DrawBar(files.x,y,4,files.item_h,bgcol); DrawBar(files.x,y,4,files.item_h,bgcol);
DrawBar(files.x+4,y,icon_size,icon_y-y,bgcol); DrawBar(files.x+4,y,icon_size,icon_y-y,bgcol);
if (files.item_h>icon_size) DrawBar(files.x+4,icon_y+icon_size-1,icon_size,y+files.item_h-icon_y-icon_size+1,bgcol); if (files.item_h>icon_size) DrawBar(files.x+4,icon_y+icon_size,icon_size,y+files.item_h-icon_y-icon_size,bgcol);
if (colored_lines.checked) { if (colored_lines.checked) {
if (bgcol!=col.selec) && (filenum%2) bgcol=col.odd_line; if (bgcol!=col.selec) && (filenum%2) bgcol=col.odd_line;
separator_color = bgcol; separator_color = bgcol;
@ -829,7 +832,7 @@ void Line_ReDraw(dword bgcol, filenum){
bgcol, text_col, kfont.size.pt, #label_file_name); bgcol, text_col, kfont.size.pt, #label_file_name);
} }
DrawIconByExtension(#full_path, ext1, files.x+4, icon_y, bgcol); DrawIconByExtension(#full_path, ext1, files.x+4, icon_y, bgcol);
if (current_inactive) DrawWideRectangle(files.x+2, y, files.w-4, files.item_h, 2, col.selec_active); if (current_inactive) DrawWideRectangle(files.x+2, y, files.w-4, files.item_h, 2, col.selec);
} }
@ -907,39 +910,6 @@ inline Sorting()
} }
void Del_Form()
{
byte f_count[128];
int dform_x = files.w - 220 / 2 + files.x;
if (!selected_count) && (!strncmp(#file_name,"..",2)) return;
else
{
if (!files.count) return;
DrawEolitePopup(T_YES, T_NO);
WriteText(-strlen(T_DELETE_FILE)*3+110+dform_x,175,0x80,sc.work_text,T_DELETE_FILE);
if (selected_count)
{
sprintf(#f_count,"%s%d%s",DEL_MORE_FILES_1,selected_count,DEL_MORE_FILES_2);
WriteText(-strlen(#f_count)*3+110+dform_x,190,0x80,sc.work_text,#f_count);
}
else
{
if (strlen(#file_name)<28)
{
WriteText(strlen(#file_name)*3+110+dform_x+2,190,0x80,sc.work_text,"?");
WriteText(-strlen(#file_name)*3+110+dform_x,190,0x80,sc.work_text,#file_name);
}
else
{
WriteText(164+dform_x,190,0x80,0,"...?");
ESI = 24;
WriteText(dform_x+20,190,0,0,#file_name);
}
}
del_active=1;
}
}
void SelectFileByName(dword that_file) void SelectFileByName(dword that_file)
{ {
int ind; int ind;
@ -1018,76 +988,123 @@ void ShowOpenWithDialog()
RunProgram("/sys/@open", #open_param); RunProgram("/sys/@open", #open_param);
} }
void NewElement() bool EventCreateAndRename()
{ {
BDVK element_info; sprintf(#temp,"%s/%s",path,popin_text.text);
byte copy_result, info_result; if (file_exists(#temp)) {
sprintf(#temp,"%s/%s",path,new_file_ed.text);
info_result = GetFileInfo(#temp, #element_info);
switch(new_element_active)
{
case CREATE_FILE:
if (info_result!=5) {
notify(FS_ITEM_ALREADY_EXISTS); notify(FS_ITEM_ALREADY_EXISTS);
} else { return false;
CreateFile(0, 0, #temp); }
if (EAX) switch(active_popin)
{ {
if (EAX==5) notify(NOT_CREATE_FILE); case POPIN_NEW_FILE:
else Write_Error(EAX); if (CreateFile(0, 0, #temp)) goto __FAIL;
}
}
break; break;
case CREATE_FOLDER: case POPIN_NEW_FOLDER:
if (info_result!=5) { if (CreateDir(#temp)) goto __FAIL;
notify(FS_ITEM_ALREADY_EXISTS);
} else {
CreateDir(#temp);
if (EAX)
{
if (EAX==5) notify(NOT_CREATE_FOLDER);
else Write_Error(EAX);
}
}
break; break;
case RENAME_ITEM: case POPIN_RENAME:
if (info_result!=5) { if (RenameMove(popin_text.text, #file_path))
notify(FS_ITEM_ALREADY_EXISTS);
} else {
if (RenameMove(new_file_ed.text, #file_path))
{ {
if (itdir) { if (itdir) {
notify("'Error renaming folder' -E"); goto __FAIL;
return;
} else { } else {
if (copy_result = CopyFile(#file_path,#temp)) { if (CopyFile(#file_path,#temp)) {
Write_Error(copy_result); goto __FAIL;
} else { } else {
DeleteFile(#file_path); DeleteFile(#file_path);
SelectFileByName(new_file_ed.text);
}
} }
} }
} }
} }
Open_Dir(path,WITH_REDRAW); Open_Dir(path,WITH_REDRAW);
SelectFileByName(new_file_ed.text); SelectFileByName(popin_text.text);
return true;
__FAIL:
Write_Error(EAX);
return false;
}
void EventPopinClickOkay()
{
switch(active_popin) {
case POPIN_PATH:
strcpy(path, #popin_string);
Open_Dir(path, WITH_REDRAW);
break;
case POPIN_DELETE:
CopyFilesListToClipboard(DELETE);
EventClosePopinForm();
sprintf(#param, "-d %s", #file_path);
RunProgram(#program_path, #param);
break;
case POPIN_RENAME:
case POPIN_NEW_FILE:
case POPIN_NEW_FOLDER:
if (!EventCreateAndRename()) return;
}
EventClosePopinForm(); EventClosePopinForm();
} }
void NewElement_Form(byte crt, dword strng) void EventClosePopinForm()
{ {
int dform_x=files.w-220/2+files.x; active_popin = NULL;
if (!new_element_active) draw_window();
{
new_element_active = crt;
edit_box_set_text stdcall (#new_file_ed, strng);
} }
if (new_element_active==3) DrawEolitePopup(T_RENAME, T_CANCEL);
else DrawEolitePopup(T_CREATE, T_CANCEL); void ShowPopinForm(byte _popin_type)
new_file_ed.left = dform_x+10; {
DrawEditBox(#new_file_ed); int popinx;
popin_string[0] = -1;
switch(_popin_type) {
case POPIN_PATH:
edit_box_set_text stdcall (#popin_text, path);
DrawEolitePopup(T_GOPATH, T_CANCEL);
break;
case POPIN_NEW_FILE:
edit_box_set_text stdcall (#popin_text, T_NEW_FILE);
DrawEolitePopup(T_CREATE, T_CANCEL);
break;
case POPIN_NEW_FOLDER:
edit_box_set_text stdcall (#popin_text, T_NEW_FOLDER);
DrawEolitePopup(T_CREATE, T_CANCEL);
break;
case POPIN_RENAME:
edit_box_set_text stdcall (#popin_text, #file_name);
DrawEolitePopup(T_RENAME, T_CANCEL);
break;
case POPIN_DELETE:
if (!files.count) return;
if (!selected_count) && (!strncmp(#file_name,"..",2)) return;
popinx = DrawEolitePopup(T_YES, T_NO);
WriteTextCenter(popinx, 178, POPIN_W, sc.work_text, T_DELETE_FILE);
if (selected_count) {
sprintf(#param,"%s%d%s",DEL_MORE_FILES_1,selected_count,DEL_MORE_FILES_2);
} else {
if (strlen(#file_name)<28) {
sprintf(#param,"%s ?",#file_name);
} else {
strncpy(#param, #file_name, POPIN_W-20/6-4);
strcat(#param, "...?");
}
}
WriteTextCenter(popinx, 192, POPIN_W, sc.work_text, #param);
break;
case POPIN_DISK:
DefineHiddenButton(0,0,5000,3000,9999+BT_NOFRAME);
if (active_panel==0) {
SystemDiscs.DrawOptions(1);
} else {
SystemDiscs.DrawOptions(Form.cwidth/2-1);
}
break;
case POPIN_BREADCR:
notify("'Not implemented yet' C");
return;
//DrawBreadCrumbs();
break;
}
active_popin = _popin_type;
} }
void EventShowAbout() void EventShowAbout()
@ -1108,7 +1125,7 @@ void FnProcess(byte N)
EventShowProperties(); EventShowProperties();
break; break;
case 2: case 2:
if (files.count) NewElement_Form(RENAME_ITEM, #file_name); if (files.count) ShowPopinForm(POPIN_RENAME);
break; break;
case 3: case 3:
if (files.count) && (!itdir) RunProgram("/sys/quark", #file_path); if (files.count) && (!itdir) RunProgram("/sys/quark", #file_path);
@ -1131,13 +1148,13 @@ void FnProcess(byte N)
} }
break; break;
case 7: case 7:
NewElement_Form(CREATE_FOLDER, T_NEW_FOLDER); ShowPopinForm(POPIN_NEW_FOLDER);
break; break;
case 8: case 8:
Del_Form(); ShowPopinForm(POPIN_DELETE);
break; break;
case 9: case 9:
NewElement_Form(CREATE_FILE, T_NEW_FILE); ShowPopinForm(POPIN_NEW_FILE);
break; break;
case 10: //F10 case 10: //F10
if (active_settings) { if (active_settings) {
@ -1296,23 +1313,6 @@ void EventPaste(dword _into_path) {
EventClosePopinForm(); EventClosePopinForm();
} }
void EventDelete()
{
char line_param[4096+5];
CopyFilesListToClipboard(DELETE);
EventClosePopinForm();
sprintf(#line_param, "-d %s", #file_path);
RunProgram(#program_path, #line_param);
}
void EventClosePopinForm()
{
del_active = 0;
new_element_active = 0;
disk_popin_active_on_panel = 0;
draw_window();
}
void EventShowProperties() void EventShowProperties()
char line_param[4096+5]; char line_param[4096+5];
{ {
@ -1368,22 +1368,10 @@ void EventToolbarButtonClick(int _btid)
void EventDriveClick(int __id) void EventDriveClick(int __id)
{ {
SystemDiscs.Click(__id-100);
if (efm) { if (efm) {
draw_window(); draw_window();
} }
} SystemDiscs.Click(__id-100);
void EventOpenDiskPopin(int panel_n)
{
DefineHiddenButton(0,0,5000,3000,9999+BT_NOFRAME);
if (panel_n==0) {
disk_popin_active_on_panel = 1;
SystemDiscs.DrawOptions(1);
} else {
disk_popin_active_on_panel = 2;
SystemDiscs.DrawOptions(Form.cwidth/2-1);
}
} }
stop: stop:

View File

@ -15,9 +15,8 @@
#define T_CANCEL "Žâ¬¥­ " #define T_CANCEL "Žâ¬¥­ "
#define T_CREATE "‘®§¤ âì" #define T_CREATE "‘®§¤ âì"
#define T_RENAME "<22>¥à¥­ §¢ âì" #define T_RENAME "<22>¥à¥­ §¢ âì"
#define T_GOPATH "<22>¥à¥©â¨"
#define FS_ITEM_ALREADY_EXISTS "'<27>«¥¬¥­â á â ª¨¬ ¨¬¥­¥¬ 㦥 áãé¥áâ¢ã¥â' -E" #define FS_ITEM_ALREADY_EXISTS "'<27>«¥¬¥­â á â ª¨¬ ¨¬¥­¥¬ 㦥 áãé¥áâ¢ã¥â' -E"
#define NOT_CREATE_FOLDER "'ŤĄ 㤠«®áě ᮧ¤ âě Ż ŻŞă.' -E"
#define NOT_CREATE_FILE "'ŤĄ 㤠«®áě ᮧ¤ âě ä ©«.' -E"
#define T_NOTIFY_APP_PARAM_WRONG "'<27> à ¬¥âà ¤«ï § ¯ã᪠ Eolite ­¥ ¢¥à¥­: ¯ ¯ª  ­¥ áãé¥áâ¢ã¥â!' -E" #define T_NOTIFY_APP_PARAM_WRONG "'<27> à ¬¥âà ¤«ï § ¯ã᪠ Eolite ­¥ ¢¥à¥­: ¯ ¯ª  ­¥ áãé¥áâ¢ã¥â!' -E"
#define T_COPY_WINDOW_TITLE "Š®¯¨àãî..." #define T_COPY_WINDOW_TITLE "Š®¯¨àãî..."
#define T_MOVE_WINDOW_TITLE "<22>¥à¥¬¥é î..." #define T_MOVE_WINDOW_TITLE "<22>¥à¥¬¥é î..."
@ -79,10 +78,9 @@ char *actions[] = {
#define T_CANCEL "Cancel" #define T_CANCEL "Cancel"
#define T_CREATE "Create" #define T_CREATE "Create"
#define T_RENAME "Rename" #define T_RENAME "Rename"
#define T_GOPATH "Go to"
#define FS_ITEM_ALREADY_EXISTS "'An item with that name already exists' -E" #define FS_ITEM_ALREADY_EXISTS "'An item with that name already exists' -E"
#define WAIT_DELETING_FOLDER "Deleting folder. Please, wait..." #define WAIT_DELETING_FOLDER "Deleting folder. Please, wait..."
#define NOT_CREATE_FOLDER "'Folder can not be created.' -E"
#define NOT_CREATE_FILE "'File can not be created.' -E"
#define T_NOTIFY_APP_PARAM_WRONG "'Eolite param is wrong: directory does not exist!' -E" #define T_NOTIFY_APP_PARAM_WRONG "'Eolite param is wrong: directory does not exist!' -E"
#define T_COPY_WINDOW_TITLE "Copying..." #define T_COPY_WINDOW_TITLE "Copying..."
#define T_MOVE_WINDOW_TITLE "Moving..." #define T_MOVE_WINDOW_TITLE "Moving..."
@ -137,11 +135,12 @@ char *actions[] = {
//Button IDs //Button IDs
enum { enum {
PATH_BTN = 10,
POPUP_BTN1 = 201, POPUP_BTN1 = 201,
POPUP_BTN2 = 202, POPUP_BTN2 = 202,
KFM_DEV_DROPDOWN_1 = 205, KFM_DEV_DROPDOWN_1 = 205,
KFM_DEV_DROPDOWN_2 = 207, KFM_DEV_DROPDOWN_2 = 207,
BTN_PATH = 210,
BTN_BREADCRUMB = 214,
BREADCRUMB_ID = 300, BREADCRUMB_ID = 300,
BACK_BTN = 400, BACK_BTN = 400,
@ -153,19 +152,24 @@ enum {
KFM_FUNC_ID = 450 KFM_FUNC_ID = 450
}; };
//NewElement options
enum {
CREATE_FILE=1,
CREATE_FOLDER,
RENAME_ITEM
};
//OpenDir options //OpenDir options
enum { enum {
WITH_REDRAW, WITH_REDRAW,
ONLY_OPEN ONLY_OPEN
}; };
//OpenDir options
enum {
POPIN_PATH=1,
POPIN_NEW_FILE,
POPIN_NEW_FOLDER,
POPIN_RENAME,
POPIN_DELETE,
POPIN_DISK,
POPIN_BREADCR
};
char *devinfo = { char *devinfo = {
"r", 0, T_SYS, "r", 0, T_SYS,
"k", 1, T_PROG, "k", 1, T_PROG,
@ -183,3 +187,6 @@ char *devinfo = {
#define DDW 110 #define DDW 110
#define KFM2_DEVH 20 #define KFM2_DEVH 20
#define SELECTY 10 #define SELECTY 10
#define POPIN_W 260
int toolbar_buttons_x[7]={9,46,85,134,167,203};

View File

@ -123,7 +123,6 @@ void Tip(int y, dword caption, id, arrow)
WriteText(165,y+5,0x80,col.list_gb_text,arrow); //arrow WriteText(165,y+5,0x80,col.list_gb_text,arrow); //arrow
} }
void ActionsDraw(int actions_y) void ActionsDraw(int actions_y)
{ {
int i; int i;
@ -178,21 +177,16 @@ void DrawPathBar()
void DrawPathEolite() void DrawPathEolite()
{ {
if (show_breadcrumb.checked) {
DrawBreadCrumbs();
return;
}
PathShow.text_pointer = location[0]; PathShow.text_pointer = location[0];
PathShow.start_x = 250; PathShow.start_x = 250;
PathShow.start_y = 17; PathShow.start_y = 17;
PathShow.area_size_x = Form.cwidth-300; PathShow.area_size_x = Form.cwidth-300;
DrawBar(PathShow.start_x-3, PathShow.start_y-6, PathShow.area_size_x+3, 19, col.odd_line); DrawBar(PathShow.start_x-3, PathShow.start_y-6, PathShow.area_size_x+3, 19, col.odd_line);
DrawRectangle(PathShow.start_x-4,PathShow.start_y-7,PathShow.area_size_x+4,20,sc.work_graph); DrawRectangle(PathShow.start_x-4,PathShow.start_y-7,PathShow.area_size_x+4,20,sc.work_graph);
DefineHiddenButton(PathShow.start_x-4+1,PathShow.start_y-7+1,PathShow.area_size_x+4-2,20-2,PATH_BTN); DefineHiddenButton(PathShow.start_x-4+1,PathShow.start_y-7+1,PathShow.area_size_x+4-2,20-2,BTN_PATH);
DrawBar(PathShow.start_x-4, PathShow.start_y+14, PathShow.area_size_x+5+18, 1, sc.work_light); DrawBar(PathShow.start_x-4, PathShow.start_y+14, PathShow.area_size_x+5+18, 1, sc.work_light);
DrawFlatButtonSmall(PathShow.start_x+PathShow.area_size_x,PathShow.start_y-7,18,20, 61, "\x19"); DrawFlatButtonSmall(PathShow.start_x+PathShow.area_size_x,PathShow.start_y-7,18,20, BTN_BREADCRUMB, "\x19");
PathShow.font_color = col.list_gb_text; PathShow.font_color = col.list_gb_text;
PathShow_prepare stdcall(#PathShow); PathShow_prepare stdcall(#PathShow);
@ -218,10 +212,11 @@ void DrawPathBarKfm()
do { do {
DrawBar(draw_x, SELECTY-1, draw_w-KFM2_DEVH+1, 1, sc.work_graph); DrawBar(draw_x, SELECTY-1, draw_w-KFM2_DEVH+1, 1, sc.work_graph);
DrawBar(draw_x, SELECTY, draw_w-KFM2_DEVH+1, KFM2_DEVH, back_color); DrawBar(draw_x, SELECTY, draw_w-KFM2_DEVH+1, KFM2_DEVH, back_color);
DefineHiddenButton(draw_x, SELECTY, draw_w-KFM2_DEVH, KFM2_DEVH-1, BTN_PATH+i);
DrawBar(draw_x, SELECTY+KFM2_DEVH, draw_w-KFM2_DEVH+1, 1, sc.work_graph); DrawBar(draw_x, SELECTY+KFM2_DEVH, draw_w-KFM2_DEVH+1, 1, sc.work_graph);
kfont.WriteIntoWindow(draw_x + 3, math.max(KFM2_DEVH-kfont.height/2+SELECTY,0), kfont.WriteIntoWindow(draw_x + 3, math.max(KFM2_DEVH-kfont.height/2+SELECTY,0),
back_color, text_color, kfont.size.pt, location[i]+strrchr(location[i], '/')); back_color, text_color, kfont.size.pt, location[i]+strrchr(location[i], '/'));
DrawFlatButtonSmall(draw_x+draw_w-KFM2_DEVH+1, SELECTY-1, KFM2_DEVH-1, KFM2_DEVH+1, 576+i, "\x19"); DrawFlatButtonSmall(draw_x+draw_w-KFM2_DEVH+1, SELECTY-1, KFM2_DEVH-1, KFM2_DEVH+1, BTN_BREADCRUMB+i, "\x19");
draw_x = Form.cwidth/2 + DDW + 1; draw_x = Form.cwidth/2 + DDW + 1;
draw_w = Form.cwidth - draw_x - 2; draw_w = Form.cwidth - draw_x - 2;
i++; i++;
@ -256,10 +251,10 @@ void DrawBreadCrumbs()
//area_w = Form.cwidth - btn.x - 20; //area_w = Form.cwidth - btn.x - 20;
for (i=0; i<breadCrumb.count-1; i++) for (i=0; i<breadCrumb.count-1; i++)
{ {
text_line = breadCrumb.get(i) + #PathShow_path; text_line = breadCrumb.get(i) + #PathShow_path; ///EDI!
btn.w = strlen(text_line)*8+10; btn.w = strlen(text_line)*8+10;
DrawBreadcrumbButton(btn.x, btn.y, btn.w, btn.h, i+BREADCRUMB_ID, text_line); DrawBreadcrumbButton(btn.x, btn.y, btn.w, btn.h, i+BREADCRUMB_ID, text_line);
btn.x += btn.w; btn.y += btn.h;
} }
btn.x++; btn.x++;
DrawBar(btn.x,btn.y-1,Form.cwidth-btn.x-25,btn.h+3,sc.work); DrawBar(btn.x,btn.y-1,Form.cwidth-btn.x-25,btn.h+3,sc.work);
@ -292,13 +287,15 @@ void DrawBreadcrumbButton(dword x,y,w,h,id,text)
// // // //
//===================================================// //===================================================//
void DrawEolitePopup(dword b1_text, b2_text) int DrawEolitePopup(dword b1_text, b2_text)
{ {
#define POPIN_W 260
int popin_x = files.w - POPIN_W / 2 + files.x ; int popin_x = files.w - POPIN_W / 2 + files.x ;
DrawPopup(popin_x, 160, POPIN_W, 95, 1, sc.work, sc.work_graph); DrawPopup(popin_x, 160, POPIN_W, 95, 1, sc.work, sc.work_graph);
DrawCaptButton(popin_x+23+000, 215, 100, 26, POPUP_BTN1, sc.button, sc.button_text, b1_text); DrawCaptButton(popin_x+23+000, 215, 100, 26, POPUP_BTN1, sc.button, sc.button_text, b1_text);
DrawCaptButton(popin_x+23+114, 215, 100, 26, POPUP_BTN2, sc.button, sc.button_text, b2_text); DrawCaptButton(popin_x+23+114, 215, 100, 26, POPUP_BTN2, sc.button, sc.button_text, b2_text);
popin_text.left = popin_x+30;
if (popin_string[0] != -1) DrawEditBox(#popin_text);
return popin_x;
} }
void DrawDot(dword x,y) { void DrawDot(dword x,y) {

View File

@ -121,8 +121,8 @@ void _SystemDiscs::DrawSelect(int draw_x, btid, dword _path)
DrawBar(draw_x, SELECTY, DDW+1-KFM2_DEVH, KFM2_DEVH, 0xFFFFFF); DrawBar(draw_x, SELECTY, DDW+1-KFM2_DEVH, KFM2_DEVH, 0xFFFFFF);
_PutImage(draw_x + 5, SELECTY+2, 18,17, dev_icon*17*18*3+#devices); _PutImage(draw_x + 5, SELECTY+2, 18,17, dev_icon*17*18*3+#devices);
kfont.WriteIntoWindow(draw_x + 24, math.max(KFM2_DEVH-kfont.height/2+SELECTY,0), 0xFFFfff, 0x000000, kfont.size.pt, #dev_name+1); kfont.WriteIntoWindow(draw_x + 24, math.max(KFM2_DEVH-kfont.height/2+SELECTY,0), 0xFFFfff, 0x000000, kfont.size.pt, #dev_name+1);
DefineHiddenButton(draw_x, SELECTY, DDW-1, KFM2_DEVH-1, btid+1); DefineHiddenButton(draw_x, SELECTY, DDW-1, KFM2_DEVH-1, btid);
DrawFlatButtonSmall(draw_x+DDW-KFM2_DEVH+1, SELECTY-1, KFM2_DEVH-1, KFM2_DEVH+1, btid, "\x19"); DrawFlatButtonSmall(draw_x+DDW-KFM2_DEVH+1, SELECTY-1, KFM2_DEVH-1, KFM2_DEVH+1, NULL, "\x19");
} }
void _SystemDiscs::DrawOptions(int draw_x) void _SystemDiscs::DrawOptions(int draw_x)

View File

@ -11,15 +11,6 @@ char file_actions[]=
<EFBFBD>¥à¥¨¬¥­®¢ âì |F2 <EFBFBD>¥à¥¨¬¥­®¢ âì |F2
¤ «¨âì |Del ¤ «¨âì |Del
¢®©á⢠ |F1"; ¢®©á⢠ |F1";
char folder_actions[]=
"Žâªàëâì |Enter
-
Š®¯¨à®¢ âì |Crl+C
ë१ âì |Crl+X
áâ ¢¨âì |Crl+V
-
¤ «¨âì |Del
¢®©á⢠ |F1";
char empty_folder_actions[]= char empty_folder_actions[]=
"‚áâ ¢¨âì |Crl+V"; "‚áâ ¢¨âì |Crl+V";
char burger_menu_items[] = char burger_menu_items[] =
@ -41,15 +32,6 @@ Aseta |Crl+V
Nimeta ümber |F2 Nimeta ümber |F2
Kustuta |Del Kustuta |Del
Properties |F1"; Properties |F1";
char folder_actions[]=
"Ava |Enter
-
Kopeeri |Crl+C
Lõika |Crl+X
Aseta |Crl+V
-
Kustuta |Del
Properties |F1";
char empty_folder_actions[]= char empty_folder_actions[]=
"Aseta |Crl+V"; "Aseta |Crl+V";
char burger_menu_items[] = char burger_menu_items[] =
@ -71,15 +53,6 @@ Paste |Crl+V
Rename |F2 Rename |F2
Delete |Del Delete |Del
Properties |F1"; Properties |F1";
char folder_actions[]=
"Open |Enter
-
Copy |Crl+C
Cut |Crl+X
Paste |Crl+V
-
Delete |Del
Properties |F1";
char empty_folder_actions[]= char empty_folder_actions[]=
"Paste |Crl+V"; "Paste |Crl+V";
char burger_menu_items[] = char burger_menu_items[] =
@ -91,7 +64,7 @@ About";
#endif #endif
enum { MENU_DIR=1, MENU_FILE, MENU_NO_FILE, MENU_BURGER }; enum { MENU_FILE=1, MENU_NO_FILE, MENU_BURGER };
bool active_menu = false; bool active_menu = false;
@ -107,17 +80,9 @@ void EventMenuClick(dword _id)
case 4: CopyFilesListToClipboard(CUT); break; case 4: CopyFilesListToClipboard(CUT); break;
case 5: EventPaste(#path); break; case 5: EventPaste(#path); break;
case 6: FnProcess(2); break; case 6: FnProcess(2); break;
case 7: Del_Form(); break; case 7: ShowPopinForm(POPIN_DELETE); break;
case 8: FnProcess(1); break; case 8: FnProcess(1); break;
} }
if (active_menu == MENU_DIR) switch(_id) {
case 1: EventOpen(0); break;
case 2: CopyFilesListToClipboard(COPY); break;
case 3: CopyFilesListToClipboard(CUT); break;
case 4: EventPaste(#path); break;
case 5: Del_Form(); break;
case 6: FnProcess(1); break;
}
if (active_menu == MENU_BURGER) switch(_id) { if (active_menu == MENU_BURGER) switch(_id) {
case 1: EventOpenNewEolite(); break; case 1: EventOpenNewEolite(); break;
case 2: EventOpenConsoleHere(); break; case 2: EventOpenConsoleHere(); break;
@ -137,9 +102,6 @@ void EventShowListMenu()
if (!files.count) { if (!files.count) {
text = #empty_folder_actions; text = #empty_folder_actions;
active_menu = MENU_NO_FILE; active_menu = MENU_NO_FILE;
} else if (itdir) {
text = #folder_actions;
active_menu = MENU_DIR;
} else { } else {
text = #file_actions; text = #file_actions;
active_menu = MENU_FILE; active_menu = MENU_FILE;

View File

@ -3,7 +3,6 @@
?define TITLE_SETT "<EFBFBD> áâனª¨" ?define TITLE_SETT "<EFBFBD> áâனª¨"
?define SHOW_DEVICE_CLASS "‚뢮¤¨âì ­ §¢ ­¨ï ª« áá  ãáâனáâ¢" ?define SHOW_DEVICE_CLASS "‚뢮¤¨âì ­ §¢ ­¨ï ª« áá  ãáâனáâ¢"
?define SHOW_STATUS_BAR "<EFBFBD>®ª §ë¢ âì áâ âãá ¡ à" ?define SHOW_STATUS_BAR "<EFBFBD>®ª §ë¢ âì áâ âãá ¡ à"
?define SHOW_BREADCRUMBS "<EFBFBD>ᯮ«ě§®˘ âě 'ĺ«Ąˇ­ëĄ Şŕ®čި'"
?define BIG_ICONS "ˆá¯®«ì§®¢ âì ¡®«ì訥 ¨ª®­ª¨" ?define BIG_ICONS "ˆá¯®«ì§®¢ âì ¡®«ì訥 ¨ª®­ª¨"
?define COLORED_LINES "<EFBFBD>®¤á¢¥ç¨¢ âì ç¥â­ë¥ «¨­¨¨ ¢ ᯨ᪥" ?define COLORED_LINES "<EFBFBD>®¤á¢¥ç¨¢ âì ç¥â­ë¥ «¨­¨¨ ¢ ᯨ᪥"
?define FONT_SIZE_LABEL "<EFBFBD> §¬¥à èà¨äâ " ?define FONT_SIZE_LABEL "<EFBFBD> §¬¥à èà¨äâ "
@ -16,7 +15,6 @@
?define TITLE_SETT "Settings" ?define TITLE_SETT "Settings"
?define SHOW_DEVICE_CLASS "Show device class name" ?define SHOW_DEVICE_CLASS "Show device class name"
?define SHOW_STATUS_BAR "Show status bar" ?define SHOW_STATUS_BAR "Show status bar"
?define SHOW_BREADCRUMBS "Show breadcrumbs"
?define BIG_ICONS "Big icons in list" ?define BIG_ICONS "Big icons in list"
?define COLORED_LINES "Highlight even lines in list" ?define COLORED_LINES "Highlight even lines in list"
?define FONT_SIZE_LABEL "Font size" ?define FONT_SIZE_LABEL "Font size"
@ -38,7 +36,6 @@ more_less_box font_size = { NULL, 9, 22, FONT_SIZE_LABEL };
more_less_box line_height = { NULL, 16, 64, LIST_LINE_HEIGHT }; more_less_box line_height = { NULL, 16, 64, LIST_LINE_HEIGHT };
checkbox show_dev_name = { SHOW_DEVICE_CLASS }; checkbox show_dev_name = { SHOW_DEVICE_CLASS };
checkbox show_status_bar = { SHOW_STATUS_BAR }; checkbox show_status_bar = { SHOW_STATUS_BAR };
checkbox show_breadcrumb = { SHOW_BREADCRUMBS };
checkbox big_icons = { BIG_ICONS }; checkbox big_icons = { BIG_ICONS };
checkbox colored_lines = { COLORED_LINES }; checkbox colored_lines = { COLORED_LINES };
@ -80,7 +77,6 @@ void settings_dialog()
break; break;
} }
show_dev_name.click(id); show_dev_name.click(id);
show_breadcrumb.click(id);
show_status_bar.click(id); show_status_bar.click(id);
colored_lines.click(id); colored_lines.click(id);
if (font_size.click(id)) { if (font_size.click(id)) {
@ -103,7 +99,7 @@ void settings_dialog()
case evReDraw: case evReDraw:
DefineAndDrawWindow(Form.cwidth-300/2+Form.left, Form.cheight-292/2+Form.top, 400, DefineAndDrawWindow(Form.cwidth-300/2+Form.left, Form.cheight-292/2+Form.top, 400,
-efm*62+365+skin_height,0x34,sc.work,TITLE_SETT,0); -efm*42+345+skin_height,0x34,sc.work,TITLE_SETT,0);
GetProcessInfo(#Settings, SelfInfo); GetProcessInfo(#Settings, SelfInfo);
DrawSettingsCheckBoxes(); DrawSettingsCheckBoxes();
} }
@ -128,7 +124,6 @@ void DrawSettingsCheckBoxes()
if (!efm) { if (!efm) {
show_dev_name.draw(XXX, y.inc(14)); show_dev_name.draw(XXX, y.inc(14));
show_status_bar.draw(XXX, y.inc(25)); show_status_bar.draw(XXX, y.inc(25));
show_breadcrumb.draw(XXX, y.inc(25));
} }
big_icons.draw(XXX, y.inc(25)); big_icons.draw(XXX, y.inc(25));
colored_lines.draw(XXX, y.inc(25)); colored_lines.draw(XXX, y.inc(25));
@ -238,7 +233,7 @@ void SetAppColors()
if (skin_is_dark()) if (skin_is_dark())
{ {
//use dark colors //use dark colors
col.def = false; col.skin_is_dark = true;
col.list_bg = sc.work; col.list_bg = sc.work;
col.list_gb_text = sc.work_text; col.list_gb_text = sc.work_text;
col.list_text_hidden = 0xA6A6B7; col.list_text_hidden = 0xA6A6B7;
@ -254,7 +249,7 @@ void SetAppColors()
else else
{ {
//use light colors //use light colors
col.def = true; col.skin_is_dark = false;
col.list_bg = 0xFFFfff; col.list_bg = 0xFFFfff;
col.list_gb_text = 0x000000; col.list_gb_text = 0x000000;
col.list_text_hidden = 0xA6A6B7; col.list_text_hidden = 0xA6A6B7;

View File

@ -123,7 +123,7 @@
"Žè¨¡ª  #32: ᫨誮¬ ¬­®£® ¯à®æ¥áᮢ", 0}; "Žè¨¡ª  #32: ᫨誮¬ ¬­®£® ¯à®æ¥áᮢ", 0};
#else #else
unsigned char *ERROR_TEXT[]={ unsigned char *ERROR_TEXT[]={
"Code #0 - No error, compleated successfully", "Code #0 - No error",
"Error #1 - Base or partition of a hard disk is not defined", "Error #1 - Base or partition of a hard disk is not defined",
"Error #2 - Function isn't supported for this file system", "Error #2 - Function isn't supported for this file system",
"Error #3 - Unknown file system", "Error #3 - Unknown file system",