Eolite -> Properties dialog: do not show dates for devices and disks, make window shorter if dates are not shown

git-svn-id: svn://kolibrios.org@9535 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Kirill Lipatov (Leency) 2021-12-31 00:14:50 +00:00
parent ac5506b6cc
commit e4d175d635
3 changed files with 41 additions and 42 deletions

View File

@ -11,9 +11,9 @@ TODO:
http://board.kolibrios.org/viewtopic.php?f=23&t=4521&p=77334#p77334 http://board.kolibrios.org/viewtopic.php?f=23&t=4521&p=77334#p77334
*/ */
#define ABOUT_TITLE "EOLITE 5.18" #define ABOUT_TITLE "EOLITE 5.19"
#define TITLE_EOLITE "Eolite File Manager 5.18" #define TITLE_EOLITE "Eolite File Manager 5.19"
#define TITLE_KFM "Kolibri File Manager 2.18"; #define TITLE_KFM "Kolibri File Manager 2.19";
#define MEMSIZE 1024 * 250 #define MEMSIZE 1024 * 250
#include "../lib/clipboard.h" #include "../lib/clipboard.h"

View File

@ -73,16 +73,14 @@ char *actions[] = {
#define QUEST_2 "ä ©« ¬ ¨ ¯ ¯ª ¬?" #define QUEST_2 "ä ©« ¬ ¨ ¯ ¯ª ¬?"
#define PR_T_NAME "ˆ¬ï:" #define PR_T_NAME "ˆ¬ï:"
#define PR_T_DEST "<22> á¯®«®¦¥­¨¥:" #define PR_T_DEST "<22> á¯®«®¦¥­¨¥:"
#define PR_T_SIZE "<22> §¬¥à:"
#define CREATED_OPENED_MODIFIED "‘®§¤ ­:\nŽâªàëâ:\nˆ§¬¥­¥­:" #define CREATED_OPENED_MODIFIED "‘®§¤ ­:\nŽâªàëâ:\nˆ§¬¥­¥­:"
#define SET_6 "” ©«®¢: " #define T_FILES_FOLDERS "” ©«®¢: %i <20> ¯®ª: %i"
#define SET_7 " <20> ¯®ª: "
#define PR_T_CONTAINS "‘®¤¥à¦¨â: " #define PR_T_CONTAINS "‘®¤¥à¦¨â: "
#define FLAGS " €ââਡãâë " #define FLAGS " €ââਡãâë "
#define PR_T_HIDDEN "‘ªàëâë©" #define PR_T_HIDDEN "‘ªàëâë©"
#define PR_T_SYSTEM "‘¨á⥬­ë©" #define PR_T_SYSTEM "‘¨á⥬­ë©"
#define PR_T_ONLY_READ "’®«ìª® ç⥭¨¥" #define PR_T_ONLY_READ "’®«ìª® ç⥭¨¥"
#define SET_BYTE_LANG "¡ ©â" #define T_PROP_SIZE "<22> §¬¥à: %s (%i ¡ ©â)"
#define TITLE_SETT "<22> áâனª¨" #define TITLE_SETT "<22> áâனª¨"
#define SHOW_DEVICE_CLASS "‚뢮¤¨âì ­ §¢ ­¨ï ª« áá  ãáâனáâ¢" #define SHOW_DEVICE_CLASS "‚뢮¤¨âì ­ §¢ ­¨ï ª« áá  ãáâனáâ¢"
@ -171,17 +169,15 @@ char *actions[] = {
#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:"
#define PR_T_DEST "Destination:" #define PR_T_DEST "Location:"
#define PR_T_SIZE "Size:"
#define CREATED_OPENED_MODIFIED "Created:\nOpened:\nModified:" #define CREATED_OPENED_MODIFIED "Created:\nOpened:\nModified:"
#define SET_6 "Files: " #define T_FILES_FOLDERS "Files: %i Folders: %i"
#define SET_7 " Folders: "
#define PR_T_CONTAINS "Contains: " #define PR_T_CONTAINS "Contains: "
#define FLAGS " Attributes " #define FLAGS " Attributes "
#define PR_T_HIDDEN "Hidden" #define PR_T_HIDDEN "Hidden"
#define PR_T_SYSTEM "System" #define PR_T_SYSTEM "System"
#define PR_T_ONLY_READ "Read-only" #define PR_T_ONLY_READ "Read-only"
#define SET_BYTE_LANG "byte" #define T_PROP_SIZE "Size: %s (%i byte)"
#define TITLE_SETT "Settings" #define TITLE_SETT "Settings"
#define SHOW_DEVICE_CLASS "Show device class name" #define SHOW_DEVICE_CLASS "Show device class name"

View File

@ -1,6 +1,6 @@
char path_to_file[4096]; char path_to_file[PATHLEN];
char file_name2[4096]; char file_name2[PATHLEN];
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};
edit_box path_to_file_ed = {160,120,79,0xffffff,0x94AECE,0xFFFfff,0xffffff,2,sizeof(path_to_file)-2,#path_to_file,NULL, 0b,2,2}; edit_box path_to_file_ed = {160,120,79,0xffffff,0x94AECE,0xFFFfff,0xffffff,2,sizeof(path_to_file)-2,#path_to_file,NULL, 0b,2,2};
@ -32,14 +32,12 @@ void SetPropertiesDir(dword way)
dword cur_file; dword cur_file;
if (dir_exists(way)) if (dir_exists(way))
{ {
cur_file = malloc(4096); cur_file = malloc(PATHLEN);
GetDir(#dirbuf, #fcount, way, DIRS_ONLYREAL); GetDir(#dirbuf, #fcount, way, DIRS_ONLYREAL);
for (i=0; i<fcount; i++) for (i=0; i<fcount; i++)
{ {
filename = i*304+dirbuf+72; filename = i*304+dirbuf+72;
strcpy(cur_file, way); sprintf(cur_file, "%s/%s", way, filename);
chrcat(cur_file, '/');
strcat(cur_file, filename);
if ( ESDWORD[filename-40] & ATR_FOLDER ) if ( ESDWORD[filename-40] & ATR_FOLDER )
{ {
SetPropertiesDir(cur_file); SetPropertiesDir(cur_file);
@ -58,7 +56,7 @@ void SetProperties(int mode)
char pcur_file[4096]; char pcur_file[4096];
dword i; dword i;
apply_question_active=false; apply_question_active = false;
if (SET_PROPERTIES_SINGLE_FILE == mode) { if (SET_PROPERTIES_SINGLE_FILE == mode) {
SetPropertiesFile(#file_path, #file_info_general); SetPropertiesFile(#file_path, #file_info_general);
@ -95,7 +93,7 @@ void SetProperties(int mode)
void ShowConfirmQuestionPopin() void ShowConfirmQuestionPopin()
{ {
apply_question_active = 1; apply_question_active = true;
DrawPopup(15,80,250,90,1,sc.work, sc.work_graph); DrawPopup(15,80,250,90,1,sc.work, sc.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);
@ -226,8 +224,13 @@ void DrawPropertiesWindow()
dword ext1; dword ext1;
dword element_size; dword element_size;
incn y; incn y;
char temp_path[sizeof(file_path)]; char temp_path[PATHLEN];
DefineAndDrawWindow(Form.left + 150,150,315,360+skin_height,0x34,sc.work,WINDOW_TITLE_PROPERTIES,0); bool show_date = false;
if (chrnum(path, '/')>1) || (streq(path, "/kolibrios")) || (streq(path, "/sys")) show_date = true;
if (getSelectedCount()) show_date = false;
DefineAndDrawWindow(Form.left + 150,150,315,show_date*60+300+skin_height,0x34,sc.work,WINDOW_TITLE_PROPERTIES,0);
GetProcessInfo(#pform, SelfInfo); GetProcessInfo(#pform, SelfInfo);
DrawStandartCaptButton(pform.cwidth - 96, pform.cheight-34, B_CLOSE, T_CLOSE); DrawStandartCaptButton(pform.cwidth - 96, pform.cheight-34, B_CLOSE, T_CLOSE);
@ -235,16 +238,14 @@ void DrawPropertiesWindow()
WriteText(10, 78, 0x90, sc.work_text, PR_T_DEST); WriteText(10, 78, 0x90, sc.work_text, PR_T_DEST);
edit_box_draw stdcall (#path_to_file_ed); edit_box_draw stdcall (#path_to_file_ed);
WriteText(10, 97, 0x90, sc.work_text, PR_T_SIZE);
if (getSelectedCount()) if (getSelectedCount())
{ {
PropertiesDrawIcon(NULL, "<lot>"); PropertiesDrawIcon(NULL, "<lot>");
sprintf(#folder_info,"%s%d%s%d",SET_6,more_files_count.files,SET_7,more_files_count.folders); sprintf(#folder_info,T_FILES_FOLDERS,more_files_count.files,more_files_count.folders);
WriteText(file_name_ed.left+4, 30, 0x90, sc.work_text, #folder_info); WriteText(file_name_ed.left+4, 30, 0x90, sc.work_text, #folder_info);
sprintf(#element_size_label,"%s (%d %s)",ConvertSize64(more_files_count.bytes, NULL),more_files_count.bytes,SET_BYTE_LANG); sprintf(#element_size_label,T_PROP_SIZE,ConvertSize64(more_files_count.bytes, NULL),more_files_count.bytes);
WriteText(120, 97, 0x90, sc.work_text, #element_size_label); WriteText(10, 97, 0x90, sc.work_text, #element_size_label);
} }
else else
{ {
@ -259,24 +260,26 @@ void DrawPropertiesWindow()
WriteText(file_name_ed.left, file_name_ed.top-15, 0x80, sc.work_text, PR_T_NAME); WriteText(file_name_ed.left, file_name_ed.top-15, 0x80, sc.work_text, PR_T_NAME);
DrawEditBox(#file_name_ed); DrawEditBox(#file_name_ed);
if (!itdir) element_size = file_info_general.sizelo; if (!itdir) {
else element_size = file_info_general.sizelo;
{ } else {
WriteText(10,116, 0x90, sc.work_text, PR_T_CONTAINS); sprintf(#folder_info,PR_T_CONTAINS,dir_size.files,dir_size.folders);
sprintf(#folder_info,"%s%d%s%d",SET_6,dir_size.files,SET_7,dir_size.folders); WriteText(10, 117, 0x90, sc.work_text, PR_T_CONTAINS);
WriteText(120, 116, 0x90, sc.work_text, #folder_info); WriteText(120, 117, 0x90, sc.work_text, #folder_info);
element_size = dir_size.bytes; element_size = dir_size.bytes;
} }
WriteTextLines(10, 136, 0x90, sc.work_text, CREATED_OPENED_MODIFIED, 20); sprintf(#element_size_label,T_PROP_SIZE,ConvertSize64(element_size, NULL),element_size);
DrawDate(120, 136, sc.work_text, #file_info_general.datecreate); WriteText(10, 99, 0x90, sc.work_text, #element_size_label);
DrawDate(120, 156, sc.work_text, #file_info_general.datelastaccess);
DrawDate(120, 176, sc.work_text, #file_info_general.datelastedit);
sprintf(#element_size_label,"%s (%d %s)",ConvertSize64(element_size, NULL),element_size,SET_BYTE_LANG);
WriteText(120, 99, 0x90, sc.work_text, #element_size_label);
} }
DrawFrame(10, 212, -10*2 + pform.cwidth - 2, 92, FLAGS);
y.n = 212; //212 => attributes_frame.y if (show_date) {
WriteTextLines(10, 136, 0x90, sc.work_text, CREATED_OPENED_MODIFIED, 20);
DrawDate(120, 136, sc.work_text, #file_info_general.datecreate);
DrawDate(120, 156, sc.work_text, #file_info_general.datelastaccess);
DrawDate(120, 176, sc.work_text, #file_info_general.datelastedit);
}
DrawFrame(10, y.set(pform.cheight - 143), -10*2 + pform.cwidth - 2, 92, FLAGS);
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));