forked from KolibriOS/kolibrios
Eolite 2.94: change attributes for selected elements
git-svn-id: svn://kolibrios.org@5688 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
d1fc876276
commit
13153fc632
@ -103,8 +103,8 @@
|
||||
enum {ONLY_SHOW, WITH_REDRAW, ONLY_OPEN}; //OpenDir
|
||||
enum { CREATE_FILE=1, CREATE_FOLDER, RENAME_ITEM }; //NewElement
|
||||
|
||||
#define TITLE "Eolite File Manager v2.93"
|
||||
#define ABOUT_TITLE "Eolite 2.93"
|
||||
#define TITLE "Eolite File Manager v2.94"
|
||||
#define ABOUT_TITLE "Eolite 2.94"
|
||||
dword col_padding, col_selec, col_lpanel;
|
||||
|
||||
int toolbar_buttons_x[7]={9,46,85,134,167,203};
|
||||
|
@ -1,6 +1,9 @@
|
||||
#ifdef LANG_RUS
|
||||
?define WINDOW_TITLE_PROPERTIES "‘¢®©á⢠"
|
||||
?define BTN_CLOSE "‡ ªàëâì"
|
||||
?define BTN_APPLY "<EFBFBD>ਬ¥¨âì"
|
||||
?define QUEST_1 "<EFBFBD>ਬ¥¨âì ª® ¢á¥¬ ¢«®¦¥ë¬"
|
||||
?define QUEST_2 "ä ©« ¬ ¨ ¯ ¯ª ¬"
|
||||
?define PR_T_NAME "ˆ¬ï:"
|
||||
?define PR_T_DEST "<EFBFBD> ᯮ«®¦¥¨¥:"
|
||||
?define PR_T_SIZE "<EFBFBD> §¬¥à:"
|
||||
@ -18,6 +21,9 @@
|
||||
#else
|
||||
?define WINDOW_TITLE_PROPERTIES "Properties"
|
||||
?define BTN_CLOSE "Close"
|
||||
?define BTN_APPLY "Apply"
|
||||
?define QUEST_1 "<EFBFBD>ਬ¥¨âì ª® ¢á¥¬ ¢«®¦¥ë¬"
|
||||
?define QUEST_2 "ä ©« ¬ ¨ ¯ ¯ª ¬"
|
||||
?define PR_T_NAME "Name:"
|
||||
?define PR_T_DEST "Destination:"
|
||||
?define PR_T_SIZE "Size:"
|
||||
@ -39,23 +45,114 @@ char path_to_file[4096]="\0";
|
||||
char file_name2[4096]="\0";
|
||||
edit_box file_name_ed = {195,50,25,0xffffff,0x94AECE,0x000000,0xffffff,2,4098,#file_name2,#mouse_ddd2, 1000000000000000b,2,2};
|
||||
edit_box path_to_file_ed = {145,100,46,0xffffff,0x94AECE,0x000000,0xffffff,2,4098,#path_to_file,#mouse_ddd2, 1000000000000000b,2,2};
|
||||
frame flags_frame = { 0, 280, 10, 83, 151, 0x000111, 0xFFFfff, 1, FLAGS, 0, 0, 6, 0x000111, 0xCCCccc };
|
||||
frame flags_frame = { 0, 280, 10, 83, 151, 0x000111, 0xFFFfff, 1, FLAGS, 0, 0, 6, 0x000111, 0xFFFFFF };
|
||||
|
||||
int file_count, dir_count, size_dir;
|
||||
char folder_info[200];
|
||||
dword element_size;
|
||||
char element_size_label[32];
|
||||
BDVK file_info_general;
|
||||
BDVK file_info_dirsize;
|
||||
|
||||
void SetProperties(byte id)
|
||||
proc_info settings_form;
|
||||
byte quest_active, atr_readonly, atr_hidden, atr_system;
|
||||
|
||||
void SetPropertiesDir(dword way)
|
||||
{
|
||||
if (selected_count) return;
|
||||
dword dirbuf, fcount, i, filename;
|
||||
dword cur_file;
|
||||
if (isdir(way))
|
||||
{
|
||||
cur_file = malloc(4096);
|
||||
GetDir(#dirbuf, #fcount, way, DIRS_ONLYREAL);
|
||||
for (i=0; i<fcount; i++)
|
||||
{
|
||||
filename = i*304+dirbuf+72;
|
||||
strcpy(cur_file, way);
|
||||
chrcat(cur_file, '/');
|
||||
strcat(cur_file, filename);
|
||||
if ( TestBit(ESDWORD[filename-40], 4) )
|
||||
{
|
||||
SetPropertiesDir(cur_file);
|
||||
}
|
||||
GetFileInfo(cur_file, #file_info_dirsize);
|
||||
file_info_dirsize.readonly = atr_readonly;
|
||||
file_info_dirsize.hidden = atr_hidden;
|
||||
file_info_dirsize.system = atr_system;
|
||||
SetFileInfo(cur_file, #file_info_dirsize);
|
||||
}
|
||||
free(cur_file);
|
||||
}
|
||||
}
|
||||
|
||||
void SetProperties(byte prop)
|
||||
{
|
||||
dword cur_file;
|
||||
dword selected_offset2;
|
||||
|
||||
if (prop==1) || (prop==2)
|
||||
{
|
||||
if (selected_count)
|
||||
{
|
||||
cur_file = malloc(4096);
|
||||
for (i=0; i<files.count; i++)
|
||||
{
|
||||
selected_offset2 = file_mas[i]*304 + buf+32 + 7;
|
||||
if (ESBYTE[selected_offset2])
|
||||
{
|
||||
strcpy(cur_file, #path);
|
||||
strcat(cur_file, file_mas[i]*304+buf+72);
|
||||
GetFileInfo(cur_file, #file_info_general);
|
||||
file_info_general.readonly = atr_readonly;
|
||||
file_info_general.hidden = atr_hidden;
|
||||
file_info_general.system = atr_system;
|
||||
SetFileInfo(cur_file, #file_info_general);
|
||||
if (prop==2)
|
||||
{
|
||||
if (isdir(cur_file))
|
||||
{
|
||||
SetPropertiesDir(cur_file);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
free(cur_file);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (id==20) file_info_general.readonly ^= true;
|
||||
if (id==21) file_info_general.hidden ^= true;
|
||||
if (id==22) file_info_general.system ^= true;
|
||||
GetFileInfo(#file_path, #file_info_general);
|
||||
file_info_general.readonly = atr_readonly;
|
||||
file_info_general.hidden = atr_hidden;
|
||||
file_info_general.system = atr_system;
|
||||
SetFileInfo(#file_path, #file_info_general);
|
||||
if (prop==2) SetPropertiesDir(#file_path);
|
||||
}
|
||||
quest_active = 0;
|
||||
DrawPropertiesWindow();
|
||||
}
|
||||
else
|
||||
{
|
||||
GetFileInfo(#file_path, #file_info_general);
|
||||
file_info_general.readonly = atr_readonly;
|
||||
file_info_general.hidden = atr_hidden;
|
||||
file_info_general.system = atr_system;
|
||||
SetFileInfo(#file_path, #file_info_general);
|
||||
}
|
||||
cmd_free=3;
|
||||
_not_draw = true;
|
||||
Open_Dir(#path,WITH_REDRAW);
|
||||
_not_draw = false;
|
||||
EventRedrawWindow(Form.left,Form.top);
|
||||
ExitProcess();
|
||||
}
|
||||
|
||||
void Quest()
|
||||
{
|
||||
DrawPopup(30,80,200,90,1,system.color.work, system.color.work_graph);
|
||||
WriteText(50, 100, 0x80, 0x000000, QUEST_1);
|
||||
WriteText(80, 115, 0x80, 0x000000, QUEST_2);
|
||||
DrawFlatButton(52,138,70,20,301,0xFFB6B5,T_YES);
|
||||
DrawFlatButton(145,138,70,20,302,0xC6DFC6,T_NO);
|
||||
}
|
||||
|
||||
void GetSizeDir(dword way)
|
||||
@ -129,23 +226,29 @@ void properties_dialog()
|
||||
byte id;
|
||||
byte key;
|
||||
dword file_name_off;
|
||||
dword element_size;
|
||||
dword selected_offset2;
|
||||
char element_size_label[32],tmp;
|
||||
proc_info settings_form;
|
||||
|
||||
DSBYTE[#folder_info]=0;
|
||||
file_count = 0;
|
||||
dir_count = 0;
|
||||
size_dir = 0;
|
||||
|
||||
if (selected_count) GetSizeMoreFiles(#path);
|
||||
if (selected_count)
|
||||
{
|
||||
GetSizeMoreFiles(#path);
|
||||
atr_readonly = 0;
|
||||
atr_hidden = 0;
|
||||
atr_system = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
GetFileInfo(#file_path, #file_info_general);
|
||||
strcpy(#file_name2, #file_name);
|
||||
file_name_ed.size = strlen(#file_name2);
|
||||
if(itdir) GetSizeDir(#file_path);
|
||||
atr_readonly = file_info_general.readonly;
|
||||
atr_hidden = file_info_general.hidden;
|
||||
atr_system = file_info_general.system;
|
||||
}
|
||||
strcpy(#path_to_file, #path);
|
||||
path_to_file_ed.size = strlen(#path_to_file);
|
||||
@ -155,22 +258,33 @@ void properties_dialog()
|
||||
{
|
||||
case evButton:
|
||||
id=GetButtonID();
|
||||
if (quest_active)
|
||||
{
|
||||
IF (id==301) SetProperties(2);
|
||||
IF (id==302) SetProperties(1);
|
||||
break;
|
||||
}
|
||||
if (id==1) || (id==10)
|
||||
{
|
||||
cmd_free=3;
|
||||
ExitProcess();
|
||||
}
|
||||
if (id==20) SetProperties(id);
|
||||
if (id==21)
|
||||
IF (id==11)
|
||||
{
|
||||
SetProperties(id);
|
||||
_not_draw = true;
|
||||
Open_Dir(#path,WITH_REDRAW);
|
||||
_not_draw = false;
|
||||
EventRedrawWindow(Form.left,Form.top);
|
||||
if (selected_count) || (itdir)
|
||||
{
|
||||
quest_active = 1;
|
||||
Quest();
|
||||
}
|
||||
if (id==22) SetProperties(id);
|
||||
|
||||
else
|
||||
{
|
||||
SetProperties(0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
if (id==20) atr_readonly ^= 1;
|
||||
if (id==21) atr_hidden ^= 1;
|
||||
if (id==22) atr_system ^= 1;
|
||||
DrawPropertiesCheckBoxes();
|
||||
break;
|
||||
|
||||
@ -181,6 +295,12 @@ void properties_dialog()
|
||||
|
||||
case evKey:
|
||||
key = GetKey();
|
||||
if (quest_active)
|
||||
{
|
||||
IF (key==013) SetProperties(2);
|
||||
IF (key==027) SetProperties(1);
|
||||
break;
|
||||
}
|
||||
if (key==27)
|
||||
{
|
||||
cmd_free=3;
|
||||
@ -192,9 +312,16 @@ void properties_dialog()
|
||||
break;
|
||||
|
||||
case evReDraw:
|
||||
DefineAndDrawWindow(Form.left + 150,150,270,285+GetSkinHeight(),0x34,system.color.work,WINDOW_TITLE_PROPERTIES);
|
||||
DrawPropertiesWindow();
|
||||
}
|
||||
}
|
||||
|
||||
void DrawPropertiesWindow()
|
||||
{
|
||||
DefineAndDrawWindow(Form.left + 150,150,270,285+GetSkinHeight(),0x34,0xFFFFFF,WINDOW_TITLE_PROPERTIES);
|
||||
GetProcessInfo(#settings_form, SelfInfo);
|
||||
DrawFlatButton(settings_form.cwidth - 70 - 13, settings_form.cheight - 34, 70, 22, 10, 0xE4DFE1, BTN_CLOSE);
|
||||
DrawFlatButton(settings_form.cwidth - 150 - 13, settings_form.cheight - 34, 70, 22, 11, 0xE4DFE1, BTN_APPLY);
|
||||
DrawBar(10, 10, 32, 32, 0xFFFfff);
|
||||
|
||||
WriteText(10, 50, 0x80, 0x000000, PR_T_DEST);
|
||||
@ -237,20 +364,17 @@ void properties_dialog()
|
||||
|
||||
sprintf(#element_size_label,"%s (%d %s)",ConvertSize(element_size),element_size,SET_BYTE_LANG);
|
||||
WriteText(100, 65, 0x80, 0x000000, #element_size_label);
|
||||
|
||||
}
|
||||
flags_frame.size_x = - flags_frame.start_x * 2 + settings_form.cwidth - 2;
|
||||
flags_frame.font_color = system.color.work_text;
|
||||
flags_frame.font_backgr_color = system.color.work;
|
||||
flags_frame.ext_col = system.color.work_graph;
|
||||
frame_draw stdcall (#flags_frame);
|
||||
DrawPropertiesCheckBoxes();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void DrawPropertiesCheckBoxes()
|
||||
{
|
||||
CheckBox2(22, flags_frame.start_y + 14, 20, PR_T_ONLY_READ, file_info_general.readonly);
|
||||
CheckBox2(22, flags_frame.start_y + 36, 21, PR_T_HIDDEN, file_info_general.hidden);
|
||||
CheckBox2(22, flags_frame.start_y + 58, 22, PR_T_SYSTEM, file_info_general.system);
|
||||
CheckBox2(22, flags_frame.start_y + 14, 20, PR_T_ONLY_READ, atr_readonly);
|
||||
CheckBox2(22, flags_frame.start_y + 36, 21, PR_T_HIDDEN, atr_hidden);
|
||||
CheckBox2(22, flags_frame.start_y + 58, 22, PR_T_SYSTEM, atr_system);
|
||||
}
|
Loading…
Reference in New Issue
Block a user