X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FcreaDevManagerLib%2FwxCDMFileDescriptionPanel.cpp;fp=lib%2FcreaDevManagerLib%2FwxCDMFileDescriptionPanel.cpp;h=b7d8df215159f6bdee0fa23985deb13376b5661c;hb=73787c5a26e6b218b9e6c716dafc7d16330441e7;hp=0000000000000000000000000000000000000000;hpb=5dc4f3d992f59df3b049458a00d8d3071f434a50;p=crea.git diff --git a/lib/creaDevManagerLib/wxCDMFileDescriptionPanel.cpp b/lib/creaDevManagerLib/wxCDMFileDescriptionPanel.cpp new file mode 100644 index 0000000..b7d8df2 --- /dev/null +++ b/lib/creaDevManagerLib/wxCDMFileDescriptionPanel.cpp @@ -0,0 +1,145 @@ +/* +# --------------------------------------------------------------------- +# +# Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image +# pour la Sant�) +# Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton +# Previous Authors : Laurent Guigues, Jean-Pierre Roux +# CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil +# +# This software is governed by the CeCILL-B license under French law and +# abiding by the rules of distribution of free software. You can use, +# modify and/ or redistribute the software under the terms of the CeCILL-B +# license as circulated by CEA, CNRS and INRIA at the following URL +# http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html +# or in the file LICENSE.txt. +# +# As a counterpart to the access to the source code and rights to copy, +# modify and redistribute granted by the license, users are provided only +# with a limited warranty and the software's author, the holder of the +# economic rights, and the successive licensors have only limited +# liability. +# +# The fact that you are presently reading this means that you have had +# knowledge of the CeCILL-B license and that you accept its terms. +# ------------------------------------------------------------------------ + */ + +/* + * wxCDMBlackBoxDescriptionPanel.cpp + * + * Created on: Nov 27, 2012 + * Author: Daniel Felipe Gonzalez Obando + */ + +#include "wxCDMFileDescriptionPanel.h" + +#include + +#include "creaDevManagerIds.h" +#include "images/FlIcon.xpm" + +BEGIN_EVENT_TABLE(wxCDMFileDescriptionPanel, wxPanel) +EVT_MENU(ID_BUTTON_OPEN_FOLDER, wxCDMFileDescriptionPanel::OnBtnOpenContainingFolder) +EVT_MENU(ID_BUTTON_OPEN_COMMAND, wxCDMFileDescriptionPanel::OnBtnOpenWithCommand) +END_EVENT_TABLE() + +wxCDMFileDescriptionPanel::wxCDMFileDescriptionPanel( + wxWindow* parent, + modelCDMFile* file, + wxWindowID id, + const wxString& caption, + const wxPoint& pos, + const wxSize& size, + long style +) +{ + wxCDMFileDescriptionPanel::Create(parent, file, id, caption, pos, size, style); +} + +wxCDMFileDescriptionPanel::~wxCDMFileDescriptionPanel() +{ +} + +bool wxCDMFileDescriptionPanel::Create( + wxWindow* parent, + modelCDMFile* file, + wxWindowID id, + const wxString& caption, + const wxPoint& pos, + const wxSize& size, + long style +) +{ + wxPanel::Create(parent, id, pos, size, style); + this->file = file; + CreateControls(); + return TRUE; +} + +void wxCDMFileDescriptionPanel::CreateControls() +{ + wxBoxSizer *sizer = new wxBoxSizer(wxVERTICAL); + + //Welcome + sizer->Add(new wxStaticText(this, -1, _("File")),0, wxALIGN_CENTER, 0); + + //Image + sizer->Add(new wxStaticBitmap(this, -1, wxBitmap(FlIcon)),0, wxALIGN_CENTER, 0); + + //BlackBox Name + sizer->Add(new wxStaticText(this, -1, crea::std2wx(this->file->GetName())),0, wxALIGN_CENTER, 0); + + //BlackBox Properties + wxStaticBox* propertiesBox = new wxStaticBox(this, -1, _T("&Properties")); + wxStaticBoxSizer* propertiesBoxInnerSizer = new wxStaticBoxSizer(propertiesBox, wxVERTICAL); + + wxFlexGridSizer* flexGridSizer = new wxFlexGridSizer(4, 2, 9, 15); + + wxStaticText *pLocation = new wxStaticText(this, -1, wxT("Location")); + wxStaticText *pLength = new wxStaticText(this, -1, wxT("File Length")); + + wxTextCtrl *pLocationtc = new wxTextCtrl(this, -1, crea::std2wx(this->file->GetPath())); + int lgth = this->file->GetLength(); + std::stringstream ss; + ss << lgth; + std::string lgths = ss.str(); + wxTextCtrl *pLengthtc = new wxTextCtrl(this, -1, crea::std2wx(lgths)); + + flexGridSizer->Add(pLocation, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL); + flexGridSizer->Add(pLocationtc, 1, wxEXPAND); + flexGridSizer->Add(pLength, 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL); + flexGridSizer->Add(pLengthtc, 1, wxEXPAND); + + propertiesBoxInnerSizer -> Add(flexGridSizer, 0, wxEXPAND); + sizer -> Add(propertiesBoxInnerSizer, 1, wxEXPAND | wxALL, 20); + + + //Actions + wxStaticBox* actionsBox = new wxStaticBox(this, -1, _T("&Actions")); + wxStaticBoxSizer* actionsBoxInnerSizer = new wxStaticBoxSizer(actionsBox, wxVERTICAL); + sizer -> Add(actionsBoxInnerSizer, 1, wxEXPAND | wxALL, 20); + + actionsBoxInnerSizer->Add(new wxButton(this, ID_BUTTON_OPEN_FOLDER, _T("Open in File Explorer")), 0, wxEXPAND | wxRIGHT | wxLEFT, 20); + actionsBoxInnerSizer->Add(new wxButton(this, ID_BUTTON_OPEN_COMMAND, _T("Open with a command")), 0, wxEXPAND | wxRIGHT | wxLEFT, 20); + + //Assign sizer + actionsBoxInnerSizer->SetSizeHints(this); + + SetSizer(sizer); + sizer->SetSizeHints(this); +} + +void wxCDMFileDescriptionPanel::OnBtnOpenContainingFolder(wxCommandEvent& event) +{ + //TODO: implement method + std::cerr << "Event OnBtnOpenContainingFolder not implemented" << std::endl; + event.Skip(); +} + +void wxCDMFileDescriptionPanel::OnBtnOpenWithCommand(wxCommandEvent& event) +{ + //TODO: implement method + std::cerr << "Event OnBtnOpenWithCommand not implemented" << std::endl; + event.Skip(); +}