forked from KolibriOS/kolibrios
Eolite: fix attribute set for selected files
git-svn-id: svn://kolibrios.org@7593 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
bf033b8aaa
commit
dfa7b43372
@ -1,7 +1,7 @@
|
|||||||
#ifdef LANG_RUS
|
#ifdef LANG_RUS
|
||||||
?define WINDOW_TITLE_PROPERTIES "‘¢®©á⢠"
|
?define WINDOW_TITLE_PROPERTIES "‘¢®©á⢠"
|
||||||
?define BTN_CLOSE "‡ ªàëâì"
|
?define T_CLOSE "‡ ªàëâì"
|
||||||
?define BTN_APPLY "<EFBFBD>ਬ¥¨âì"
|
?define T_APPLY "<EFBFBD>ਬ¥¨âì"
|
||||||
?define QUEST_1 "<EFBFBD>ਬ¥¨âì ª® ¢á¥¬ ¢«®¦¥ë¬"
|
?define QUEST_1 "<EFBFBD>ਬ¥¨âì ª® ¢á¥¬ ¢«®¦¥ë¬"
|
||||||
?define QUEST_2 "ä ©« ¬ ¨ ¯ ¯ª ¬?"
|
?define QUEST_2 "ä ©« ¬ ¨ ¯ ¯ª ¬?"
|
||||||
?define PR_T_NAME "ˆ¬ï:"
|
?define PR_T_NAME "ˆ¬ï:"
|
||||||
@ -18,8 +18,8 @@
|
|||||||
?define SET_BYTE_LANG "¡ ©â"
|
?define SET_BYTE_LANG "¡ ©â"
|
||||||
#else // Apply to all subfolders
|
#else // Apply to all subfolders
|
||||||
?define WINDOW_TITLE_PROPERTIES "Properties"
|
?define WINDOW_TITLE_PROPERTIES "Properties"
|
||||||
?define BTN_CLOSE "Close"
|
?define T_CLOSE "Close"
|
||||||
?define BTN_APPLY "Apply"
|
?define T_APPLY "Apply"
|
||||||
?define QUEST_1 "Apply to all subfolders"
|
?define QUEST_1 "Apply to all subfolders"
|
||||||
?define QUEST_2 "files and Folders?"
|
?define QUEST_2 "files and Folders?"
|
||||||
?define PR_T_NAME "Name:"
|
?define PR_T_NAME "Name:"
|
||||||
@ -36,6 +36,11 @@
|
|||||||
?define SET_BYTE_LANG "byte"
|
?define SET_BYTE_LANG "byte"
|
||||||
#endif
|
#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 path_to_file[4096];
|
||||||
char file_name2[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};
|
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_general;
|
||||||
BDVK file_info_dirsize;
|
BDVK file_info_dirsize;
|
||||||
|
|
||||||
bool quest_active;
|
bool apply_question_active;
|
||||||
|
|
||||||
_dir_size more_files_count;
|
_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;
|
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)
|
if (selected_count)
|
||||||
{
|
{
|
||||||
cur_file = malloc(4096);
|
|
||||||
for (i=0; i<files.count; i++)
|
for (i=0; i<files.count; i++)
|
||||||
{
|
{
|
||||||
if (getElementSelectedFlag(i) == true)
|
if (getElementSelectedFlag(i) == true)
|
||||||
{
|
{
|
||||||
strcpy(cur_file, #path);
|
sprintf(#pcur_file,"%s/%s",#path,file_mas[i]*304+buf+72);
|
||||||
strcat(cur_file, file_mas[i]*304+buf+72);
|
SetPropertiesFile(#pcur_file, #file_info_general);
|
||||||
SetPropertiesDir(cur_file);
|
if (SET_PROPERTIES_ALL_SUBFOLDER == mode) {
|
||||||
if (prop==2)
|
if (dir_exists(#pcur_file)) SetPropertiesDir(#pcur_file);
|
||||||
{
|
|
||||||
if (dir_exists(cur_file))
|
|
||||||
{
|
|
||||||
SetPropertiesDir(cur_file);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
free(cur_file);
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
SetPropertiesFile(#file_path, #file_info_general);
|
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;
|
cmd_free=3;
|
||||||
_not_draw = true;
|
_not_draw = true;
|
||||||
Open_Dir(#path,WITH_REDRAW);
|
Open_Dir(#path,WITH_REDRAW);
|
||||||
@ -136,12 +139,12 @@ void SetProperties(byte prop)
|
|||||||
|
|
||||||
void ShowConfirmQuestionPopin()
|
void ShowConfirmQuestionPopin()
|
||||||
{
|
{
|
||||||
quest_active = 1;
|
apply_question_active = 1;
|
||||||
DrawPopup(15,80,250,90,1,system.color.work, system.color.work_graph);
|
DrawPopup(15,80,250,90,1,system.color.work, system.color.work_graph);
|
||||||
WriteText(35, 102, 0x90, 0x000000, QUEST_1);
|
WriteText(35, 102, 0x90, 0x000000, QUEST_1);
|
||||||
WriteText(65, 117, 0x90, 0x000000, QUEST_2);
|
WriteText(65, 117, 0x90, 0x000000, QUEST_2);
|
||||||
DrawStandartCaptButton(62,138,301,T_YES);
|
DrawStandartCaptButton(62,138,B_SETINGS_APPLY_SUBFOLDER,T_YES);
|
||||||
DrawStandartCaptButton(155,138,302,T_NO);
|
DrawStandartCaptButton(155,138,B_SETINGS_APPLY_NO_SUBFOLDER,T_NO);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GetSizeMoreFiles(dword way)
|
void GetSizeMoreFiles(dword way)
|
||||||
@ -202,30 +205,20 @@ void properties_dialog()
|
|||||||
ch_read_only.click(id);
|
ch_read_only.click(id);
|
||||||
ch_hidden.click(id);
|
ch_hidden.click(id);
|
||||||
ch_system.click(id);
|
ch_system.click(id);
|
||||||
if (quest_active)
|
if (apply_question_active)
|
||||||
{
|
{
|
||||||
IF (id==301) SetProperties(2);
|
IF (id==B_SETINGS_APPLY_SUBFOLDER)
|
||||||
IF (id==302) SetProperties(1);
|
SetProperties(SET_PROPERTIES_ALL_SUBFOLDER);
|
||||||
quest_active=false;
|
IF (id==B_SETINGS_APPLY_NO_SUBFOLDER)
|
||||||
|
SetProperties(SET_PROPERTIES_NO_SUBFOLDER);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (id==1) || (id==10)
|
if (id==1) || (id==B_CLOSE)
|
||||||
{
|
{
|
||||||
cmd_free=3;
|
cmd_free=3;
|
||||||
ExitProcess();
|
ExitProcess();
|
||||||
}
|
}
|
||||||
IF (id==11)
|
if (id==B_APPLY) EventApplyProperties();
|
||||||
{
|
|
||||||
if (selected_count) || (itdir)
|
|
||||||
{
|
|
||||||
ShowConfirmQuestionPopin();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
SetProperties(0);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case evMouse:
|
case evMouse:
|
||||||
@ -236,32 +229,30 @@ void properties_dialog()
|
|||||||
case evKey:
|
case evKey:
|
||||||
GetKeys();
|
GetKeys();
|
||||||
|
|
||||||
if (quest_active)
|
if (apply_question_active)
|
||||||
{
|
{
|
||||||
IF (key_scancode==SCAN_CODE_ENTER) SetProperties(2);
|
IF (key_scancode==SCAN_CODE_ENTER)
|
||||||
IF (key_scancode==SCAN_CODE_ESC) SetProperties(1);
|
SetProperties(SET_PROPERTIES_ALL_SUBFOLDER);
|
||||||
quest_active=false;
|
IF (key_scancode==SCAN_CODE_ESC)
|
||||||
|
SetProperties(SET_PROPERTIES_NO_SUBFOLDER);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (key_scancode==SCAN_CODE_ESC)
|
|
||||||
|
switch(key_scancode)
|
||||||
{
|
{
|
||||||
|
case SCAN_CODE_ESC:
|
||||||
cmd_free=3;
|
cmd_free=3;
|
||||||
ExitProcess();
|
ExitProcess();
|
||||||
}
|
|
||||||
if (key_scancode==SCAN_CODE_ENTER)
|
|
||||||
{
|
|
||||||
if (selected_count) || (itdir)
|
|
||||||
{
|
|
||||||
ShowConfirmQuestionPopin();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
SetProperties(0);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
case SCAN_CODE_ENTER:
|
||||||
|
EventApplyProperties();
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
edit_box_key stdcall(#file_name_ed);
|
edit_box_key stdcall(#file_name_ed);
|
||||||
edit_box_key stdcall(#path_to_file_ed);
|
edit_box_key stdcall(#path_to_file_ed);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case evReDraw:
|
case evReDraw:
|
||||||
@ -271,7 +262,7 @@ void properties_dialog()
|
|||||||
|
|
||||||
void DrawPropertiesWindow()
|
void DrawPropertiesWindow()
|
||||||
{
|
{
|
||||||
proc_info settings_form;
|
proc_info pform;
|
||||||
char element_size_label[32];
|
char element_size_label[32];
|
||||||
char folder_info[200];
|
char folder_info[200];
|
||||||
dword ext1;
|
dword ext1;
|
||||||
@ -279,10 +270,10 @@ void DrawPropertiesWindow()
|
|||||||
incn y;
|
incn y;
|
||||||
char temp_path[sizeof(file_path)];
|
char temp_path[sizeof(file_path)];
|
||||||
DefineAndDrawWindow(Form.left + 150,150,315,360+skin_height,0x34,system.color.work,WINDOW_TITLE_PROPERTIES,0);
|
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(pform.cwidth - 96, pform.cheight-34, B_CLOSE, T_CLOSE);
|
||||||
DrawStandartCaptButton(settings_form.cwidth -208, settings_form.cheight-34, 11, BTN_APPLY);
|
DrawStandartCaptButton(pform.cwidth -208, pform.cheight-34, B_APPLY, T_APPLY);
|
||||||
|
|
||||||
WriteText(10, 78, 0x90, system.color.work_text, PR_T_DEST);
|
WriteText(10, 78, 0x90, system.color.work_text, PR_T_DEST);
|
||||||
edit_box_draw stdcall (#path_to_file_ed);
|
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);
|
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);
|
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
|
y.n = 212; //212 => attributes_frame.y
|
||||||
ch_read_only.draw(24, y.inc(18));
|
ch_read_only.draw(24, y.inc(18));
|
||||||
ch_hidden.draw(24, y.inc(24));
|
ch_hidden.draw(24, y.inc(24));
|
||||||
ch_system.draw(24, y.inc(24));
|
ch_system.draw(24, y.inc(24));
|
||||||
|
if (apply_question_active) ShowConfirmQuestionPopin();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PropertiesDrawIcon(dword file_path, extension)
|
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);
|
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);
|
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);
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
#define TITLE "Eolite File Manager 4.05"
|
#define TITLE "Eolite File Manager 4.06"
|
||||||
#define ABOUT_TITLE "EOLITE 4.05"
|
#define ABOUT_TITLE "EOLITE 4.06"
|
||||||
|
|
||||||
#ifdef LANG_RUS
|
#ifdef LANG_RUS
|
||||||
?define T_FILE "” ©«"
|
?define T_FILE "” ©«"
|
||||||
|
Loading…
Reference in New Issue
Block a user