-#include "frmContactEditorSound.h"
-
-#include <wx/tokenzr.h>
-#include <wx/file.h>
-#include <SFML/Audio.hpp>
+// frmContactEditorSound.cpp - frmContactEditorSound form.
+//
+// (c) 2012-2015 Xestia Software Development.
+//
+// This file is part of Xestia Address Book.
+//
+// Xestia Address Book is free software: you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by the
+// Free Software Foundation, version 3 of the license.
+//
+// Xestia Address Book is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with Xestia Address Book. If not, see <http://www.gnu.org/licenses/>
-#include "../common/textprocessing.h"
-#include "../common/base64.h"
-#include "../common/mime.h"
+#include "frmContactEditorSound.h"
frmContactEditorSound::frmContactEditorSound( wxWindow* parent )
:
frmContactEditorSoundADT( parent )
{
+
+ // Setup the window.
+
EditorMode = FALSE;
- sliPriority->Disable();
+ priorityCtrl = new XABPriorityCtrl(tabGeneral);
+ szrGeneral->Add(priorityCtrl, 1, wxEXPAND, 5);
+ szrGeneral->Layout();
cmbType->Append(wxT(""));
cmbType->Append(_("Home"));
cmbType->Append(_("Work"));
-}
-
-void frmContactEditorSound::EnablePriority( wxCommandEvent& event )
-{
- if (chkUsePref->IsChecked()){
- sliPriority->Enable();
- } else {
- sliPriority->Disable();
- }
+
}
void frmContactEditorSound::ProcessData( wxCommandEvent& event )
{
+
+ // Process audio data.
+
long ListCtrlIndex;
if (EditorMode == FALSE){
wxSAudioFilename = fipSound->GetPath();
-/*
-#if wxABI_VERSION < 20900
- if (AudioFile.Open(wxSAudioFilename.c_str(), wxT("rb"))){
-#else
- if (AudioFile.Open(wxSAudioFilename, wxT("rb"))){
-#endif
-
-*/
if (AudioFile.Open(wxSAudioFilename, wxFile::read)){
- ssize_t flen;
+
len = AudioFile.Length();
unsigned char* AudioFileData = new unsigned char[len];
- flen = AudioFile.Read(AudioFileData, (size_t)len);
-
- // Get MIME Type.
-
- /*const char *MIMEType;
- magic_t MagicCookie = magic_open(MAGIC_MIME);
- magic_setflags(MagicCookie, MAGIC_MIME_TYPE);
-
- if (!MagicCookie){
-
- wxMessageBox(_("An error occured with the support library for getting the picture type."), _("Error opening picture file"), wxICON_ERROR);
- return;
-
- }
-
- if (magic_load(MagicCookie, NULL) != 0) {
-
- wxMessageBox(_("An error occured whilst determining the picture type."), _("Error opening picture file"), wxICON_ERROR);
- return;
-
- }
-
- MIMEType = magic_file(MagicCookie, wxSAudioFilename.mb_str());
- wxSAudioMIMEType = wxString::FromUTF8(MIMEType);
- magic_close(MagicCookie);*/
wxSAudioMIMEType = GetMIME(wxSAudioFilename);
// Setup Organisation Priority.
- if (chkUsePref->IsChecked()){
+ if (priorityCtrl->IsPriorityChecked()){
- SoundListPrefPtr->insert(std::make_pair(SoundListIndex, sliPriority->GetValue()));
+ SoundListPrefPtr->insert(std::make_pair(SoundListIndex, priorityCtrl->GetValue()));
} else {
}
- if (chkUsePref->IsChecked()){
+ if (priorityCtrl->IsPriorityChecked()){
- SoundListCtrlPtr->SetItem(ListCtrlIndex, 2, wxString::Format(wxT("%i"), sliPriority->GetValue()));
+ SoundListCtrlPtr->SetItem(ListCtrlIndex, 2, wxString::Format(wxT("%i"), priorityCtrl->GetValue()));
}
// Do not touch the audio file but update the settings
// associated with the audio file.
-
-
long longSelected = -1;
wxString strValue;
SoundListPrefPtr->erase(SoundListIndex);
- if (chkUsePref->IsChecked()){
+ if (priorityCtrl->IsPriorityChecked()){
- SoundListPrefPtr->insert(std::make_pair(SoundListIndex, sliPriority->GetValue()));
+ SoundListPrefPtr->insert(std::make_pair(SoundListIndex, priorityCtrl->GetValue()));
} else {
SoundListCtrlPtr->SetItem(longSelected, 0, wxT("Sound"));
SoundListCtrlPtr->SetItem(longSelected, 1, strValue);
- if (chkUsePref->IsChecked()){
+ if (priorityCtrl->IsPriorityChecked()){
- SoundListCtrlPtr->SetItem(longSelected, 2, wxString::Format(wxT("%i"), sliPriority->GetValue()));
+ SoundListCtrlPtr->SetItem(longSelected, 2, wxString::Format(wxT("%i"), priorityCtrl->GetValue()));
} else {
void frmContactEditorSound::CloseWindow( wxCommandEvent& event )
{
+
+ // Close this window.
+
this->Close();
+
}
void frmContactEditorSound::SetEditorMode(bool EditMode)
{
+
+ // Set the editor mode.
+
// Set if the editor is adding or editing an address.
// FALSE = Add
// TRUE = Edit
cmbType->SetSelection(0);
}
-
- //strValue.Clear();
-
+
// Get the website priority.
intiter = SoundListPrefPtr->find(SoundListIndex);
- if (intiter->first == SoundListIndex && intiter->second > 0){
-
- sliPriority->SetValue(intiter->second);
- sliPriority->Enable();
- chkUsePref->SetValue(TRUE);
+ if (intiter->first == SoundListIndex && intiter->second > 0 &&
+ intiter != SoundListPrefPtr->end()){
+
+ priorityCtrl->SetValue(intiter->second);
+ priorityCtrl->EnablePriority(true);
}
wxListCtrl *SoundListCtrl,
int SoundIndex )
{
+
+ // Setup the pointers.
SoundListPtr = SoundList;
SoundListAltIDPtr = SoundListAltID;