Eolite: fix attribute set for selected files

git-svn-id: svn://kolibrios.org@7593 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Kirill Lipatov (Leency) 2019-03-10 18:08:50 +00:00
parent bf033b8aaa
commit dfa7b43372
2 changed files with 76 additions and 75 deletions

View File

@ -1,7 +1,7 @@
#ifdef LANG_RUS
?define WINDOW_TITLE_PROPERTIES "‘¢®©á⢠"
?define BTN_CLOSE "‡ ªàëâì"
?define BTN_APPLY "<EFBFBD>ਬ¥­¨âì"
?define T_CLOSE "‡ ªàëâì"
?define T_APPLY "<EFBFBD>ਬ¥­¨âì"
?define QUEST_1 "<EFBFBD>ਬ¥­¨âì ª® ¢á¥¬ ¢«®¦¥­­ë¬"
?define QUEST_2 "ä ©« ¬ ¨ ¯ ¯ª ¬?"
?define PR_T_NAME "ˆ¬ï:"
@ -18,8 +18,8 @@
?define SET_BYTE_LANG "¡ ©â"
#else // Apply to all subfolders
?define WINDOW_TITLE_PROPERTIES "Properties"
?define BTN_CLOSE "Close"
?define BTN_APPLY "Apply"
?define T_CLOSE "Close"
?define T_APPLY "Apply"
?define QUEST_1 "Apply to all subfolders"
?define QUEST_2 "files and Folders?"
?define PR_T_NAME "Name:"
@ -36,6 +36,11 @@
?define SET_BYTE_LANG "byte"
#endif
#define B_SETINGS_APPLY_SUBFOLDER 301
#define B_SETINGS_APPLY_NO_SUBFOLDER 302
#define B_APPLY 11
#define B_CLOSE 12
char path_to_file[4096];
char file_name2[4096];
edit_box file_name_ed = {230,59,32,0xffffff,0x94AECE,0xFFFfff,0xffffff,0x10000000,sizeof(file_name2)-2,#file_name2,NULL, 0b,2,2};
@ -44,7 +49,7 @@ edit_box path_to_file_ed = {160,120,79,0xffffff,0x94AECE,0xFFFfff,0xffffff,2,siz
BDVK file_info_general;
BDVK file_info_dirsize;
bool quest_active;
bool apply_question_active;
_dir_size more_files_count;
@ -86,46 +91,44 @@ void SetPropertiesDir(dword way)
}
}
void SetProperties(byte prop)
#define SET_PROPERTIES_SINGLE_FILE 0
#define SET_PROPERTIES_NO_SUBFOLDER 1
#define SET_PROPERTIES_ALL_SUBFOLDER 2
void SetProperties(int mode)
{
dword cur_file;
char pcur_file[4096];
dword i;
if (prop==1) || (prop==2)
apply_question_active=false;
if (SET_PROPERTIES_SINGLE_FILE == mode) {
SetPropertiesFile(#file_path, #file_info_general);
}
if (SET_PROPERTIES_ALL_SUBFOLDER == mode)
|| (SET_PROPERTIES_NO_SUBFOLDER == mode)
{
if (selected_count)
{
cur_file = malloc(4096);
for (i=0; i<files.count; i++)
{
if (getElementSelectedFlag(i) == true)
{
strcpy(cur_file, #path);
strcat(cur_file, file_mas[i]*304+buf+72);
SetPropertiesDir(cur_file);
if (prop==2)
{
if (dir_exists(cur_file))
{
SetPropertiesDir(cur_file);
sprintf(#pcur_file,"%s/%s",#path,file_mas[i]*304+buf+72);
SetPropertiesFile(#pcur_file, #file_info_general);
if (SET_PROPERTIES_ALL_SUBFOLDER == mode) {
if (dir_exists(#pcur_file)) SetPropertiesDir(#pcur_file);
}
}
}
}
free(cur_file);
}
else
{
SetPropertiesFile(#file_path, #file_info_general);
if (prop==2) SetPropertiesDir(#file_path);
if (SET_PROPERTIES_ALL_SUBFOLDER == mode) SetPropertiesDir(#file_path);
}
quest_active = 0;
DrawPropertiesWindow();
}
else
{
SetPropertiesFile(#file_path, #file_info_general);
}
cmd_free=3;
_not_draw = true;
Open_Dir(#path,WITH_REDRAW);
@ -136,12 +139,12 @@ void SetProperties(byte prop)
void ShowConfirmQuestionPopin()
{
quest_active = 1;
apply_question_active = 1;
DrawPopup(15,80,250,90,1,system.color.work, system.color.work_graph);
WriteText(35, 102, 0x90, 0x000000, QUEST_1);
WriteText(65, 117, 0x90, 0x000000, QUEST_2);
DrawStandartCaptButton(62,138,301,T_YES);
DrawStandartCaptButton(155,138,302,T_NO);
DrawStandartCaptButton(62,138,B_SETINGS_APPLY_SUBFOLDER,T_YES);
DrawStandartCaptButton(155,138,B_SETINGS_APPLY_NO_SUBFOLDER,T_NO);
}
void GetSizeMoreFiles(dword way)
@ -202,30 +205,20 @@ void properties_dialog()
ch_read_only.click(id);
ch_hidden.click(id);
ch_system.click(id);
if (quest_active)
if (apply_question_active)
{
IF (id==301) SetProperties(2);
IF (id==302) SetProperties(1);
quest_active=false;
IF (id==B_SETINGS_APPLY_SUBFOLDER)
SetProperties(SET_PROPERTIES_ALL_SUBFOLDER);
IF (id==B_SETINGS_APPLY_NO_SUBFOLDER)
SetProperties(SET_PROPERTIES_NO_SUBFOLDER);
break;
}
if (id==1) || (id==10)
if (id==1) || (id==B_CLOSE)
{
cmd_free=3;
ExitProcess();
}
IF (id==11)
{
if (selected_count) || (itdir)
{
ShowConfirmQuestionPopin();
}
else
{
SetProperties(0);
}
break;
}
if (id==B_APPLY) EventApplyProperties();
break;
case evMouse:
@ -236,32 +229,30 @@ void properties_dialog()
case evKey:
GetKeys();
if (quest_active)
if (apply_question_active)
{
IF (key_scancode==SCAN_CODE_ENTER) SetProperties(2);
IF (key_scancode==SCAN_CODE_ESC) SetProperties(1);
quest_active=false;
IF (key_scancode==SCAN_CODE_ENTER)
SetProperties(SET_PROPERTIES_ALL_SUBFOLDER);
IF (key_scancode==SCAN_CODE_ESC)
SetProperties(SET_PROPERTIES_NO_SUBFOLDER);
break;
}
if (key_scancode==SCAN_CODE_ESC)
switch(key_scancode)
{
case SCAN_CODE_ESC:
cmd_free=3;
ExitProcess();
}
if (key_scancode==SCAN_CODE_ENTER)
{
if (selected_count) || (itdir)
{
ShowConfirmQuestionPopin();
}
else
{
SetProperties(0);
}
break;
}
case SCAN_CODE_ENTER:
EventApplyProperties();
break;
default:
edit_box_key stdcall(#file_name_ed);
edit_box_key stdcall(#path_to_file_ed);
}
break;
case evReDraw:
@ -271,7 +262,7 @@ void properties_dialog()
void DrawPropertiesWindow()
{
proc_info settings_form;
proc_info pform;
char element_size_label[32];
char folder_info[200];
dword ext1;
@ -279,10 +270,10 @@ void DrawPropertiesWindow()
incn y;
char temp_path[sizeof(file_path)];
DefineAndDrawWindow(Form.left + 150,150,315,360+skin_height,0x34,system.color.work,WINDOW_TITLE_PROPERTIES,0);
GetProcessInfo(#settings_form, SelfInfo);
GetProcessInfo(#pform, SelfInfo);
DrawStandartCaptButton(settings_form.cwidth - 96, settings_form.cheight-34, 10, BTN_CLOSE);
DrawStandartCaptButton(settings_form.cwidth -208, settings_form.cheight-34, 11, BTN_APPLY);
DrawStandartCaptButton(pform.cwidth - 96, pform.cheight-34, B_CLOSE, T_CLOSE);
DrawStandartCaptButton(pform.cwidth -208, pform.cheight-34, B_APPLY, T_APPLY);
WriteText(10, 78, 0x90, system.color.work_text, PR_T_DEST);
edit_box_draw stdcall (#path_to_file_ed);
@ -326,11 +317,12 @@ void DrawPropertiesWindow()
sprintf(#element_size_label,"%s (%d %s)",ConvertSize64(element_size, NULL),element_size,SET_BYTE_LANG);
WriteText(120, 99, 0x90, system.color.work_text, #element_size_label);
}
DrawFrame(10, 212, -10*2 + settings_form.cwidth - 2, 92, FLAGS);
DrawFrame(10, 212, -10*2 + pform.cwidth - 2, 92, FLAGS);
y.n = 212; //212 => attributes_frame.y
ch_read_only.draw(24, y.inc(18));
ch_hidden.draw(24, y.inc(24));
ch_system.draw(24, y.inc(24));
if (apply_question_active) ShowConfirmQuestionPopin();
}
void PropertiesDrawIcon(dword file_path, extension)
@ -339,3 +331,12 @@ void PropertiesDrawIcon(dword file_path, extension)
DrawBar(20-ICON_PADDING, 30-ICON_PADDING-1, ICON_PADDING*2+16, ICON_PADDING*2+16, 0xFFFfff);
DrawIconByExtension(file_path, extension, -icon_size/2+28, -icon_size/2+38, 0xFFFfff);
}
void EventApplyProperties()
{
if (selected_count) || (itdir) {
ShowConfirmQuestionPopin();
} else {
SetProperties(SET_PROPERTIES_SINGLE_FILE);
}
}

View File

@ -1,5 +1,5 @@
#define TITLE "Eolite File Manager 4.05"
#define ABOUT_TITLE "EOLITE 4.05"
#define TITLE "Eolite File Manager 4.06"
#define ABOUT_TITLE "EOLITE 4.06"
#ifdef LANG_RUS
?define T_FILE "” ©«"