gecko-dev/cmd/macfe/Composer/meditdlg.cp
1998-08-05 02:52:10 +00:00

5615 lines
151 KiB
C++
Raw Blame History

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
*
* The contents of this file are subject to the Netscape Public License
* Version 1.0 (the "NPL"); you may not use this file except in
* compliance with the NPL. You may obtain a copy of the NPL at
* http://www.mozilla.org/NPL/
*
* Software distributed under the NPL is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
* for the specific language governing rights and limitations under the
* NPL.
*
* The Initial Developer of this code under the NPL is Netscape
* Communications Corporation. Portions created by Netscape are
* Copyright (C) 1998 Netscape Communications Corporation. All Rights
* Reserved.
*/
#include "meditdlg.h"
#include "meditor.h" // HandleModalDialog
#include "shist.h"
#include "CEditView.h"
#include "edt.h"
#include "pa_tags.h"
#include "secnav.h"
#include "rosetta.h"
// macfe
#include "ulaunch.h" // StartDocInApp
#include "CColorCaption.h" // for CChameleonCaption
#include "macgui.h" // StPrepareForDialog, UGraphics
#include "resgui.h" // msg_Help, msg_Apply, CLOSE_STR_RESID, EDITOR_PERCENT_PARENT_CELL
#include "uerrmgr.h"
#include "uapp.h" // CFrontApp::DoGetURL
#include "macutil.h"
#include "ufilemgr.h"
#include "CPrefsDialog.h"
#include "prefapi.h"
#include "prefwutil.h" // SetColor
#include "CNSContext.h" // ExtractHyperView
#include "CLargeEditField.h"
#include "CPrefsMediator.h"
#include "URobustCreateWindow.h"
#include "UGraphicGizmos.h"
// powerplant
#include "CTabControl.h"
#include "LToggleButton.h"
#include "StBlockingDialogHandler.h"
#include "UMenuUtils.h"
#include "LGAEditField.h"
#include "LGAPopup.h"
#include "LGACaption.h"
#include "CTabSwitcher.h"
#include <LStdControl.h>
#include <UDesktop.h>
#include <UReanimator.h>
#include <URegistrar.h>
#include <UTextTraits.h>
#include "xp_help.h"
extern char *XP_NEW_DOC_NAME;
static Boolean IsEditFieldWithinLimits(LGAEditField* editField, int minVal, int maxVal );
static void SetTextTraitsIDByCsid(LEditField* pane, int16 win_csid)
{
ThrowIfNil_(pane);
static int16 res_csid = -1;
if(-1 == res_csid) // un-initialized
res_csid = INTL_CharSetNameToID(INTL_ResourceCharSet());
if(win_csid != res_csid)
pane->SetTextTraitsID(CPrefs::GetTextFieldTextResIDs(win_csid));
}
//static void SetOkButtonState( Boolean enable )
//{
// StBlockingDialogHandler handler(5150, LCommander::GetTopCommander());
// LWindow *dlog = (LWindow *)handler.GetDialog();
// LControl *okButton = (LControl *)dlog->FindPaneByID( 'OKOK' );
// if ( okButton == NULL )
// return;
// if (enable)
// okButton->Enable();
// else
// okButton->Disable();
//}
// input: c-string; output: c-string
// returns true if the user clicked ok
static Boolean GetExtraHTML( char *pExtra, char **newExtraHTML , int16 win_csid)
{
StBlockingDialogHandler handler(5114, LCommander::GetTopCommander());
LWindow *dlog = (LWindow *)handler.GetDialog();
LControl *okButton = (LControl *)dlog->FindPaneByID( 'OKOK' );
if ( okButton == NULL )
return false;
CLargeEditField *editField = (CLargeEditField *)dlog->FindPaneByID( 'Xhtm' );
if ( editField == NULL )
return false;
SetTextTraitsIDByCsid( editField, win_csid );
dlog->SetLatentSub( editField );
if ( pExtra )
{
editField->SetLongDescriptor( pExtra );
editField->SelectAll();
}
MessageT theMessage;
do
{
char *pCurrent = editField->GetLongDescriptor();
if ( pCurrent == NULL || ( pExtra && XP_STRCMP( pExtra, pCurrent ) == 0 ) )
okButton->Disable();
else
okButton->Enable();
if ( pCurrent )
XP_FREE( pCurrent );
theMessage = handler.DoDialog();
if ( theMessage == msg_Help )
ShowHelp ( HELP_EXTRA_HTML );
} while ( theMessage != msg_OK && theMessage != msg_Cancel );
if ( theMessage == msg_OK )
*newExtraHTML = editField->GetLongDescriptor();
return theMessage == msg_OK;
}
void CChameleonView::SetColor(RGBColor textColor)
{
fTextColor.red = textColor.red;
fTextColor.green = textColor.green;
fTextColor.blue = textColor.blue;
}
void CChameleonView::DrawSelf()
{
Rect frame;
CalcLocalFrameRect(frame);
ApplyForeAndBackColors();
::RGBBackColor(&fTextColor);
EraseRect(&frame);
}
void CEditorPrefContain::DrawSelf()
{
Rect theFrame;
if (CalcLocalFrameRect(theFrame))
{
StColorPenState theSaver;
theSaver.Normalize();
SBevelColorDesc theDesc;
UGraphicGizmos::LoadBevelTraits(5000, theDesc);
::PmForeColor(theDesc.fillColor);
::PaintRect(&theFrame);
StClipRgnState theClipSaver(theFrame);
StColorState::Normalize();
theFrame.top -= 5;
::FrameRect(&theFrame);
SBooleanRect theBevelSides = { true, true, true, true };
UGraphicGizmos::BevelTintPartialRect(theFrame, 3, 0x4000, 0x4000, theBevelSides);
}
}
#pragma mark -
/**********************************************************/
// This is probably stupid. This just allows all the dialogs I'm creating
// to remember who created them. Also the creator can specify which tab the
// Tab control should start on, if there is a tab control. Also, if this
// is an image, link, or HRule dialog, the creator can specify whether the
// final action should be to insert or modify a selected element.
Boolean CEditDialog::Start(ResIDT inWindowID, MWContext * context, short initTabValue, Boolean insert)
{
CEditDialog* newWindow = NULL;
LEditField* theEditField = NULL;
StBlockingDialogHandler handler(inWindowID, LCommander::GetTopCommander()); // inSuperCommander
newWindow = (CEditDialog*)handler.GetDialog();
ThrowIfNULL_(newWindow);
UReanimator::LinkListenerToControls( newWindow, newWindow, inWindowID ); // the handler is listening; but we want a crack at the messages also...
newWindow->SetContext(context);
newWindow->SetInitTabValue(initTabValue);
newWindow->SetInWindowID(inWindowID);
newWindow->SetInsertFlag(insert);
newWindow->InitializeDialogControls();
newWindow->Show();
EDT_BeginBatchChanges(context);
while (TRUE) { // Loop FOREVER. We exit from the loop by returning from particular cases.
MessageT theMessage = handler.DoDialog();
LCommander* theTarget = GetTarget();
switch (theMessage) {
case msg_Help:
newWindow->Help();
break;
case msg_Apply:
if (theTarget == NULL || theTarget->SwitchTarget(newWindow))
if (newWindow->CommitChanges(TRUE)) {
LStdControl* cancel = (LStdControl*)newWindow->FindPaneByID( 'CANC' );
if (cancel) {
StringHandle CloseHandle = GetString(CLOSE_STR_RESID);
CStr255 Close = **( (CStr255**)CloseHandle ); // Lock it? I don't think so.
cancel->SetDescriptor(Close);
}
}
break;
case msg_OK:
if (theTarget == NULL || theTarget->SwitchTarget(newWindow))
if (newWindow->CommitChanges(TRUE)) {
EDT_EndBatchChanges(context);
return TRUE; // Bye Bye!!
}
break;
case msg_Cancel: {
EDT_EndBatchChanges(context);
return FALSE; // Bye Bye!!
}
break;
default:
// this should never happen; hopefully, non-debug code makes this case go away
XP_ASSERT( 0 );
break;
}
}
}
Boolean CEditDialog::AllowSubRemoval( LCommander * /* inSub */ )
{
// don't allow removal
return false;
}
void CEditDialog::ChooseImageFile(CLargeEditField* editField)
{
if ( editField == NULL )
return;
StPrepareForDialog preparer;
StandardFileReply reply;
Point loc = { -1, -1 };
OSType types[ 4 ];
types[ 0 ] = 'GIFf';
types[ 1 ] = 'TEXT';
types[ 2 ] = 'JPEG';
types[ 3 ] = 'JFIF';
::StandardGetFile( NULL, 4, types, &reply );
if ( !reply.sfGood )
return;
char *fileLink = CFileMgr::GetURLFromFileSpec( reply.sfFile );
if ( fileLink == NULL )
return;
editField->SetDescriptor( CtoPstr(/*NET_UnEscape*/(fileLink)) );
XP_FREE(fileLink);
}
/**********************************************************/
#pragma mark -
#pragma mark CTarget
CTarget::CTarget( LStream* inStream ) : CEditDialog( inStream )
{
fOriginalTarget = NULL;
fTargetName = NULL;
ErrorManager::PrepareToInteract();
UDesktop::Deactivate();
}
CTarget::~CTarget()
{
UDesktop::Activate();
if ( fOriginalTarget )
XP_FREE( fOriginalTarget );
fOriginalTarget = NULL;
fTargetName = NULL;
}
void CTarget::InitializeDialogControls()
{
// Create Controls
ThrowIfNil_(fTargetName = (CLargeEditField*)FindPaneByID( 'tgnm' ));
if ( EDT_GetCurrentElementType(fContext) == ED_ELEMENT_TARGET )
StrAllocCopy( fOriginalTarget, EDT_GetTargetData(fContext) );
else
{
StrAllocCopy( fOriginalTarget, (char *)LO_GetSelectionText(fContext) );
CleanUpTargetString( fOriginalTarget );
}
if ( fOriginalTarget )
fTargetName->SetDescriptor( CStr255(fOriginalTarget) );
this->SetLatentSub( fTargetName );
fTargetName->SelectAll();
}
void CTarget::CleanUpTargetString(char *target)
{
if ( target == NULL )
return;
// move temp past spaces and leading # and strcpy from new location over target
// remove leading spaces
char *temp = target;
while ( *temp == ' ' )
temp++;
// remove a leading pound, if any
if ( *temp == '#' )
temp++;
// strcpy now that we have temp correctly positioned
XP_STRCPY( target, temp );
// truncate at the first return character
char *ret = XP_STRCHR( target, '\r' );
if ( ret )
*ret = '\0';
}
Boolean CTarget::AlreadyExistsInDocument(char *anchor)
{
char *targs = EDT_GetAllDocumentTargets( fContext );
if ( targs == NULL )
return FALSE;
char *parse = targs;
if ( parse )
{
while ( *parse )
{
if ( XP_STRCMP( anchor, parse ) == 0 )
{
XP_FREE( targs );
return TRUE;
}
parse += XP_STRLEN( parse ) + 1;
}
}
XP_FREE(targs);
return FALSE;
}
Boolean CTarget::CommitChanges( Boolean /* isAllPanes */ )
{
char *anchor = fTargetName->GetLongDescriptor();
if ( anchor == NULL )
return true;
CleanUpTargetString( anchor );
if ( AlreadyExistsInDocument(anchor) && (fInsert || XP_STRCMP(anchor, fOriginalTarget)) )
{
ErrorManager::PlainAlert( DUPLICATE_TARGET );
XP_FREE( anchor );
return false;
}
if ( !mUndoInited )
{
EDT_BeginBatchChanges( fContext );
mUndoInited = true;
}
if ( fInsert )
EDT_InsertTarget( fContext, anchor );
else
EDT_SetTargetData( fContext, anchor );
XP_FREE( anchor );
return true;
}
/**********************************************************/
#pragma mark CUnknownTag
CUnknownTag::CUnknownTag( LStream* inStream ) : CEditDialog( inStream )
{
ErrorManager::PrepareToInteract();
UDesktop::Deactivate();
}
CUnknownTag::~CUnknownTag()
{
UDesktop::Activate();
}
void CUnknownTag::FinishCreateSelf()
{
fTargetName = NULL;
CEditDialog::FinishCreateSelf();
}
void CUnknownTag::InitializeDialogControls()
{
fTargetName = (CLargeEditField *)FindPaneByID( 'tgnm' );
SetTextTraitsIDByCsid(fTargetName, GetWinCSID());
if ( !fInsert )
{
char *tag = EDT_GetUnknownTagData( fContext );
if ( tag )
{
fTargetName->SetLongDescriptor( tag );
XP_FREE( tag );
}
}
this->SetLatentSub( fTargetName );
fTargetName->SelectAll();
}
Boolean CUnknownTag::CommitChanges( Boolean /* isAllPanes */ )
{
// HACK!!! CUnknownTag is used (unfortunately) by both "Insert HTML Tag" and "Extra HTML<4D>"
// This is bad and should be corrected as soon as possible (after 4.0 ships)
// in the case of extra HTML we can end up here but fTargetName will be NULL
// let's just bail out and handle this in the extraHTML dlog code (by returning false)
if ( fTargetName == NULL )
return false;
char *anchor = fTargetName->GetLongDescriptor();
if ( anchor == NULL )
return true;
if ( EDT_ValidateTag(anchor, FALSE) != ED_TAG_OK )
{
ErrorManager::PlainAlert( BAD_TAG );
XP_FREE( anchor );
return false;
}
if ( mUndoInited )
{
EDT_BeginBatchChanges( fContext );
mUndoInited = true;
}
if ( fInsert )
EDT_InsertUnknownTag( fContext, anchor );
else
EDT_SetUnknownTagData( fContext, anchor );
XP_FREE( anchor );
return true;
}
void CUnknownTag::Help()
{
ShowHelp( HELP_HTML_TAG );
}
void CUnknownTag::ListenToMessage( MessageT inMessage, void* ioParam )
{
switch ( inMessage )
{
case 'vrfy':
char *anchor = fTargetName->GetLongDescriptor();
if (anchor)
{
if (EDT_ValidateTag( anchor, false ) != ED_TAG_OK)
ErrorManager::PlainAlert( BAD_TAG );
XP_FREE( anchor );
}
break;
default:
LDialogBox::ListenToMessage( inMessage, ioParam );
break;
}
}
/**********************************************************/
#pragma mark -
// Does PowerPlant now have a better class? Can we replace this homebrew class?
// This is a single column LListBox which allows multiple things to be selected.
MultipleSelectionSingleColumn::MultipleSelectionSingleColumn( LStream* inStream ) : LListBox( inStream )
{
FocusDraw();
if((*mMacListH)->dataBounds.right == 0)
::LAddColumn(1 , 0, mMacListH);
(*mMacListH)->selFlags &= ~lOnlyOne; // make sure this bit is cleared.
}
int16 MultipleSelectionSingleColumn::NumItems()
{
return ((**mMacListH).dataBounds.bottom);
}
void MultipleSelectionSingleColumn::DeselectAll()
{
Cell theCell;
int16 count = NumItems();
theCell.h = 0;
FocusDraw();
for (theCell.v = 0; theCell.v < count; theCell.v++)
LSetSelect(false, theCell, mMacListH);
}
void MultipleSelectionSingleColumn::SelectAll()
{
Cell theCell;
int16 count = NumItems();
theCell.h = 0;
FocusDraw();
for (theCell.v = 0; theCell.v < count; theCell.v++)
LSetSelect(true, theCell, mMacListH);
}
void MultipleSelectionSingleColumn::AddItem( char* data, Boolean isSelected )
{
if(SwitchTarget(this))
{
int16 rowNum = 0;
FocusDraw();
Cell theCell;
theCell.h = 0;
rowNum = ::LAddRow(1 , (**mMacListH).dataBounds.bottom, mMacListH);
theCell.v = rowNum;
::LSetCell(data, strlen(data) + 1 ,theCell, mMacListH);
::LSetSelect( isSelected, theCell, mMacListH );
}
}
StringPtr MultipleSelectionSingleColumn::GetItem(Str255 outDescriptor, int32 rowNum) const
{
outDescriptor[0] = 0;
Cell theCell = {0, 0};
theCell.h = 0;
theCell.v = rowNum;
Int16 dataLen = 255;
::LGetCell(outDescriptor + 1, &dataLen, theCell, mMacListH);
outDescriptor[0] = dataLen;
return outDescriptor;
}
Boolean MultipleSelectionSingleColumn::IsSelected(int32 rowNum) // rowNum is zero based
{
FocusDraw();
Cell theCell;
theCell.h = 0;
theCell.v = rowNum;
return ::LGetSelect(false, &theCell, mMacListH); // false means to only look at this one item...
}
void MultipleSelectionSingleColumn::RemoveAllItems()
{
FocusDraw();
if ((**mMacListH).dataBounds.bottom)
::LDelRow((**mMacListH).dataBounds.bottom, 0, mMacListH);
}
/**********************************************************/
#pragma mark CPublishHistory
char* CPublishHistory::GetPublishHistoryCharPtr(short whichone)
{
switch (whichone) {
case 0: return CPrefs::GetCharPtr(CPrefs::PublishHistory0);
case 1: return CPrefs::GetCharPtr(CPrefs::PublishHistory1);
case 2: return CPrefs::GetCharPtr(CPrefs::PublishHistory2);
case 3: return CPrefs::GetCharPtr(CPrefs::PublishHistory3);
case 4: return CPrefs::GetCharPtr(CPrefs::PublishHistory4);
case 5: return CPrefs::GetCharPtr(CPrefs::PublishHistory5);
case 6: return CPrefs::GetCharPtr(CPrefs::PublishHistory6);
case 7: return CPrefs::GetCharPtr(CPrefs::PublishHistory7);
case 8: return CPrefs::GetCharPtr(CPrefs::PublishHistory8);
case 9: return CPrefs::GetCharPtr(CPrefs::PublishHistory9);
}
return CPrefs::GetCharPtr(CPrefs::PublishHistory0);
}
void CPublishHistory::SetPublishHistoryCharPtr(char* entry, short whichone)
{
switch (whichone) {
case 0: CPrefs::SetString( entry, CPrefs::PublishHistory0); break;
case 1: CPrefs::SetString( entry, CPrefs::PublishHistory1); break;
case 2: CPrefs::SetString( entry, CPrefs::PublishHistory2); break;
case 3: CPrefs::SetString( entry, CPrefs::PublishHistory3); break;
case 4: CPrefs::SetString( entry, CPrefs::PublishHistory4); break;
case 5: CPrefs::SetString( entry, CPrefs::PublishHistory5); break;
case 6: CPrefs::SetString( entry, CPrefs::PublishHistory6); break;
case 7: CPrefs::SetString( entry, CPrefs::PublishHistory7); break;
case 8: CPrefs::SetString( entry, CPrefs::PublishHistory8); break;
case 9: CPrefs::SetString( entry, CPrefs::PublishHistory9); break;
}
}
Boolean CPublishHistory::IsTherePublishHistory()
{
char *lowest = GetPublishHistoryCharPtr(0);
if (lowest == NULL) return FALSE;
if (*lowest == '\0') return FALSE;
return TRUE;
}
void CPublishHistory::AddPublishHistoryEntry(char *entry)
{
if (entry == NULL) return;
short highestcopy = 9;
short i;
for (i = 0; i < 9 ; i++) {
char * hist = GetPublishHistoryCharPtr(i);
if (hist && strcmp(hist, entry) == NULL) highestcopy = i;
}
while (highestcopy > 0) {
SetPublishHistoryCharPtr(GetPublishHistoryCharPtr(highestcopy - 1), highestcopy);
highestcopy--;
}
SetPublishHistoryCharPtr(entry, 0);
}
#pragma mark CPublish
CPublish::CPublish( LStream* inStream ) : CEditDialog( inStream )
{
ErrorManager::PrepareToInteract();
UDesktop::Deactivate();
}
CPublish::~CPublish()
{
UDesktop::Activate();
}
void CPublish::FinishCreateSelf()
{
// Create Controls
fLocalLocation = NULL;
fImageFiles = NULL;
fFolderFiles = NULL;
fDefaultLocation = NULL;
fFileList = NULL;
fPublishLocation = NULL;
fUserID = NULL;
fPassword = NULL;
fSavePassword = NULL;
mHistoryList = NULL;
CEditDialog::FinishCreateSelf();
}
void CPublish::InitializeDialogControls()
{
fLocalLocation = (LCaption*)this->FindPaneByID( 'Pub0' );
fImageFiles = (LControl*)this->FindPaneByID( 'Pub1' );
fFolderFiles = (LControl*)this->FindPaneByID( 'Pub2' );
History_entry * pEntry = SHIST_GetCurrent(&fContext->hist);
if (pEntry && pEntry->address && NET_IsLocalFileURL(pEntry->address))
fFolderFiles->Enable();
else
fFolderFiles->Disable();
fFileList = (MultipleSelectionSingleColumn*)this->FindPaneByID( 'Pub3' );
fPublishLocation = (LGAEditField*)this->FindPaneByID( 'Pub4' );
fUserID = (LGAEditField*)this->FindPaneByID( 'user' );
fPassword = (LGAEditField*)this->FindPaneByID( 'Pass' );
fDefaultLocation = (LControl*)this->FindPaneByID( 'Dflt' );
fSavePassword = (LControl*)this->FindPaneByID( 'Pub5' );
mHistoryList = (LGAPopup *)this->FindPaneByID( 'Pub6' );
MenuHandle menu = mHistoryList->GetMacMenuH();
if (menu && CPublishHistory::IsTherePublishHistory()) {
::SetMenuItemText(menu, 1, "\p ");
mHistoryList->SetMaxValue(10); // maximum of 10 entries.
int i;
for (i = 0; i < 10; i++) {
char *entry = CPublishHistory::GetPublishHistoryCharPtr(i);
if (entry == NULL || *entry == '\0') break;
char *location = NULL;
char *user = NULL;
char *pass = NULL;
if (NET_ParseUploadURL(entry, &location, &user, &pass)) {
UMenuUtils::InsertMenuItem(menu, CtoPstr(location), i + 2);
XP_FREE(location);
XP_FREE(user);
XP_FREE(pass);
}
}
}
char *location = EDT_GetDefaultPublishURL( fContext, NULL, NULL, NULL );
if ( location )
{
fPublishLocation->SetDescriptor( CtoPstr(location) );
XP_FREE( location );
}
this->SetLatentSub( fPublishLocation );
char *localDir = DocName();
if (localDir) {
char *pSlash = strrchr(localDir, '/');
if (pSlash) { // if there is a slash, only keep everything AFTER the last slash
pSlash++; // go past the slash
XP_STRCPY(localDir, pSlash);
}
fLocalLocation->SetDescriptor( CtoPstr(localDir) );
XP_FREE( localDir );
}
CLargeEditField *titleField = (CLargeEditField *)FindPaneByID( 'Titl' );
if ( titleField )
{
int16 res_csid = INTL_CharSetNameToID(INTL_ResourceCharSet());
int16 win_csid = GetWinCSID();
if(win_csid != res_csid)
titleField->SetTextTraitsID(CPrefs::GetTextFieldTextResIDs(win_csid));
EDT_PageData *pageData = EDT_GetPageData( fContext );
if ( pageData )
{
titleField->SetDescriptor( CtoPstr(pageData->pTitle) );
EDT_FreePageData( pageData );
}
}
CStr255 locationCStr = CPrefs::GetString(CPrefs::PublishLocation);
if (locationCStr.Length())
fDefaultLocation->Enable();
else
fDefaultLocation->Disable();
TurnOn(fImageFiles);
}
char *CPublish::DocName()
{
History_entry * pEntry = SHIST_GetCurrent(&fContext->hist);
if (pEntry == NULL || pEntry->address == NULL) return NULL;
if (!NET_IsLocalFileURL(pEntry->address)) return NULL;
char *filename = NULL;
XP_ConvertUrlToLocalFile( pEntry->address, &filename );
return filename;
}
Boolean CPublish::CommitChanges( Boolean /* isAllPanes */ )
{
char *BrowseLoc = NULL;
CStr255 outText;
fPublishLocation->GetDescriptor( outText );
int type = NET_URL_Type(outText);
if (type != FTP_TYPE_URL && type != HTTP_TYPE_URL && type != SECURE_HTTP_TYPE_URL) {
ErrorManager::PlainAlert( INVALID_PUBLISH_LOC );
return FALSE;
}
// Tell user the URL they are publishing to looks like it might be wrong.
// e.g. ends in a slash or does not have a file extension.
// Give the user the option of attempting to publish to the
// specified URL even if it looks suspicious.
if ( !EDT_CheckPublishURL( fContext, (char*)outText ) ) {
// XP will put up alert
return FALSE;
}
/* set the page title */
EDT_PageData *pageData = EDT_GetPageData( fContext );
if ( pageData )
{
CLargeEditField *titleField = (CLargeEditField *)FindPaneByID( 'Titl' );
if ( titleField )
pageData->pTitle = titleField->GetLongDescriptor();
if ( pageData->pTitle && pageData->pTitle[0] == 0 )
{
XP_FREE( pageData->pTitle );
pageData->pTitle = NULL;
}
if ( pageData->pTitle == NULL )
pageData->pTitle = strdup( " " );
EDT_SetPageData( fContext, pageData );
EDT_FreePageData( pageData );
}
/* get the userID and password to create the internal URL */
CStr255 user;
CStr255 pass;
fUserID->GetDescriptor( user );
fPassword->GetDescriptor( pass );
if (!NET_MakeUploadURL(&BrowseLoc, outText, user, pass) || BrowseLoc == NULL)
return TRUE; // must be an out of memory problem, but we return TRUE so the user can try to recover
/* look for related files to also publish */
int count = 0;
int i;
for (i = fFileList->NumItems() - 1; i >= 0; i--)
if (fFileList->IsSelected(i))
count++;
char **allFiles = (char **) XP_CALLOC((count + 2), sizeof(char *));
if (allFiles == NULL) {
XP_FREE(BrowseLoc);
return TRUE; // must be an out of memory problem, but we return TRUE so the user can try to recover
}
allFiles[count + 1] = NULL;
allFiles[0] = XP_STRDUP(outText); // we are actually copying the doc name as well as the localDir here
int allFilesIndex = 1;
for (i = 0; i < count; i++)
{
if (fFileList->IsSelected(i))
{
CStr255 lookFor;
fFileList->GetItem(lookFor, i);
if (allFilesIndex < count + 1) // sanity check
allFiles[ allFilesIndex ] = XP_STRDUP( lookFor );
else
XP_ASSERT(0);
allFilesIndex++;
}
}
/* get preferences and current URL */
XP_Bool bKeepImages;
PREF_GetBoolPref("editor.publish_keep_images",&bKeepImages);
XP_Bool bKeepLinks;
PREF_GetBoolPref("editor.publish_keep_links",&bKeepLinks);
char *pSrcURL;
History_entry * pEntry = SHIST_GetCurrent(&fContext->hist);
if (pEntry && pEntry->address && *pEntry->address) {
pSrcURL = pEntry->address;
}
else {
// no source name.
pSrcURL = XP_NEW_DOC_NAME;
}
/* actually publish--finally! */
EDT_PublishFile( fContext, ED_FINISHED_REVERT_BUFFER, pSrcURL,
allFiles, BrowseLoc, bKeepImages, bKeepLinks, false ); // this will eventually free allFiles, when we are done publishing....
XP_FREE(BrowseLoc);
BrowseLoc = NULL;
// add this new location to our history...known bugs in this area
if (fSavePassword->GetValue())
{
char *result;
result = HG99875(pass);
if ( result && (strcmp( result, pass ) == 0) )
{
// munging didn't do anything so we'll write out ""
pass = "";
}
else
pass = result;
}
else
pass = "";
if (NET_MakeUploadURL(&BrowseLoc, outText, user, pass) && BrowseLoc) {
CPublishHistory::AddPublishHistoryEntry(BrowseLoc);
XP_FREE(BrowseLoc);
}
// Ask the user if he/she wants to browse to the page. Only browse when the answer is "yes."
switch ( HandleModalDialog ( EDITDLG_BROWSE_PUBLISHED, NULL, NULL ) )
{
case msg_OK:
CStr255 urlString = CPrefs::GetString( CPrefs::PublishBrowseLocation );
if ( urlString != CStr255::sEmptyString )
CFrontApp::DoGetURL( (unsigned char*)urlString );
break;
case msg_Cancel:
break;
}
return TRUE;
}
void CPublish::Help()
{
ShowHelp( HELP_PUBLISH_FILES );
}
void CPublish::ListenToMessage( MessageT inMessage, void* ioParam )
{
switch ( inMessage )
{
case 'None': // deselect everything in file list
fFileList->DeselectAll();
break;
case 'SAll': // select everything in file list
fFileList->SelectAll();
break;
case 'Pub1': // add all document images to list
if (fImageFiles->GetValue()) {
fFileList->RemoveAllItems();
XP_Bool bKeepImages;
PREF_GetBoolPref("editor.publish_keep_images",&bKeepImages);
XP_Bool *bSelectionArray = NULL;
char *images = EDT_GetAllDocumentFilesSelected( fContext,
&bSelectionArray, bKeepImages );
if (images) {
char *next = images;
int index = 0;
while (*next) {
fFileList->AddItem(next, bSelectionArray[ index++ ]);
next += strlen(next) + 1;
}
XP_FREE(images);
}
if ( bSelectionArray )
XP_FREE( bSelectionArray );
}
break;
case 'Pub2': // add all images in folder to list
/* this should not be enabled if remote document or new document (file:///Untitled) */
if (fFolderFiles->GetValue())
{
fFileList->RemoveAllItems();
History_entry * pEntry = SHIST_GetCurrent(&fContext->hist);
if (pEntry && pEntry->address && NET_IsLocalFileURL(pEntry->address))
{
char *URLDir = XP_STRDUP( pEntry->address );
if ( URLDir )
{
char *pSlash = strrchr(URLDir, '/');
if (pSlash) // is there is a slash, chop off everything after the last slash
*++pSlash = '\0';
char **images = NET_AssembleAllFilesInDirectory( fContext, URLDir );
if (images)
{
char **next = images; // go through the list and add them all
while (*next)
{
if (strcmp(*next, pEntry->address)) // don't add current file
{
// char *path = strstr(*next, URLDir);
// if (path)
// fFileList->AddItem( path + strlen(URLDir), false );
// else
// fFileList->AddItem( *next, false );
// char *absURL = NET_MakeAbsoluteURL( pEntry->address, *next );
fFileList->AddItem( *next, false );
}
next++;
}
next = images; // now free them all... what a waste
while (*next) XP_FREE(*next++);
XP_FREE(images);
}
XP_FREE( URLDir );
}
}
}
break;
case 'Pub6': // extract one of the history entries and put in publish location
CStr255 text = CPublishHistory::GetPublishHistoryCharPtr(mHistoryList->GetValue() - 2);
// reset it now, because we don't know when the user might modify the textedit
// field making the selected menu item no longer valid.
mHistoryList->SetValue(1);
if ((char *) text && *(char *)text) {
char *location = NULL;
char *user = NULL;
char *pass = NULL;
if (NET_ParseUploadURL(text, &location, &user, &pass)) {
if (pass && *pass) {
char *newpass = HG99876(pass);
XP_FREE(pass);
pass = newpass;
}
fPublishLocation->SetDescriptor( CtoPstr(location) );
fUserID->SetDescriptor( CtoPstr(user) );
fPassword->SetDescriptor( CtoPstr(pass) );
if (pass && *pass)
fSavePassword->SetValue(1);
else
fSavePassword->SetValue(0);
XP_FREE(location);
XP_FREE(user);
XP_FREE(pass);
}
}
break;
case 'Dflt': // put in default publish location
char *BrowseLoc = CPrefs::GetString(CPrefs::PublishLocation);
if (BrowseLoc && *BrowseLoc) {
char *location = NULL;
char *user = NULL;
char *pass = NULL;
if (NET_ParseUploadURL(BrowseLoc, &location, &user, &pass)) {
if (pass && *pass) {
char *newpass = HG99876(pass);
XP_FREE(pass);
pass = newpass;
}
fPublishLocation->SetDescriptor( CtoPstr(location) );
fUserID->SetDescriptor( CtoPstr(user) );
fPassword->SetDescriptor( CtoPstr(pass) );
XP_FREE(location);
XP_FREE(user);
XP_FREE(pass);
}
}
break;
case msg_ControlClicked:
if ( ioParam )
{
LControl *c = (LControl *)ioParam;
if ( c )
ListenToMessage( c->GetValueMessage(), NULL );
}
break;
default:
LDialogBox::ListenToMessage( inMessage, ioParam );
break;
}
}
/**********************************************************/
#pragma mark CLineProp
CLineProp::CLineProp( LStream* inStream ): CEditDialog( inStream )
{
ErrorManager::PrepareToInteract();
UDesktop::Deactivate();
}
CLineProp::~CLineProp()
{
UDesktop::Activate();
}
#define kPixelsItem 1
#define kPercentOfWindowItem 2
void CLineProp::FinishCreateSelf()
{
fLeftAlign = NULL;
fCenterAlign = NULL;
fRightAlign = NULL;
fHeightEditText = NULL;
fWidthEditText = NULL;
fPixelPercent = NULL;
fShading = NULL;
CEditDialog::FinishCreateSelf();
}
void CLineProp::InitializeDialogControls()
{
// Find Controls
fHeightEditText = (LGAEditField*)this->FindPaneByID( 'ELPh' );
fWidthEditText = (LGAEditField*)this->FindPaneByID( 'ELPw' );
fLeftAlign = (LControl*)this->FindPaneByID( 'Left' );
fCenterAlign = (LControl*)this->FindPaneByID( 'Cntr' );
fRightAlign = (LControl*)this->FindPaneByID( 'Rght' );
fPixelPercent = (LControl*)this->FindPaneByID( 'eppp' );
fShading = (LControl*)this->FindPaneByID( 'ELPs' );
this->SetLatentSub( fHeightEditText );
fHeightEditText->SelectAll();
// Set control values
EDT_HorizRuleData* fData;
if (EDT_GetCurrentElementType(fContext) == ED_ELEMENT_HRULE)
fData = EDT_GetHorizRuleData(fContext);
else
fData = EDT_NewHorizRuleData();
ThrowIfNil_(fData);
fHeightEditText->SetValue(fData->size);
fWidthEditText->SetValue(fData->iWidth);
if (fData->align == ED_ALIGN_LEFT)
TurnOn( fLeftAlign );
else if ( fData->align == ED_ALIGN_RIGHT)
TurnOn( fRightAlign );
else
TurnOn( fCenterAlign );
fPixelPercent->SetValue( (fData->bWidthPercent) ? kPercentOfWindowItem : kPixelsItem );
fShading->SetValue(fData->bNoShade == FALSE);
pExtra = fData->pExtra; // we'll reuse this pointer
fData->pExtra = NULL; // don't want to free it!
EDT_FreeHorizRuleData(fData);
}
Boolean CLineProp::CommitChanges( Boolean /* allPanes */ )
{
if ( !IsEditFieldWithinLimits(fHeightEditText, 1, 100))
{
SwitchTarget( fHeightEditText );
fHeightEditText->SelectAll();
return false;
}
if ( fPixelPercent->GetValue() != kPercentOfWindowItem
&& !IsEditFieldWithinLimits(fWidthEditText, 1, 10000))
{
SwitchTarget( fWidthEditText );
fWidthEditText->SelectAll();
return false;
}
if (fPixelPercent->GetValue() == kPercentOfWindowItem
&& !IsEditFieldWithinLimits(fWidthEditText, 1, 100))
{
SwitchTarget( fWidthEditText );
fWidthEditText->SelectAll();
return false;
}
if ( !mUndoInited )
{
EDT_BeginBatchChanges( fContext );
mUndoInited = true;
}
EDT_HorizRuleData* fData;
if (EDT_GetCurrentElementType(fContext) == ED_ELEMENT_HRULE)
fData = EDT_GetHorizRuleData(fContext);
else
fData = EDT_NewHorizRuleData();
ThrowIfNil_(fData);
if (fLeftAlign->GetValue())
fData->align = ED_ALIGN_LEFT;
else if (fCenterAlign->GetValue())
fData->align = ED_ALIGN_DEFAULT;
else if (fRightAlign->GetValue())
fData->align = ED_ALIGN_RIGHT;
fData->size = fHeightEditText->GetValue();
fData->iWidth = fWidthEditText->GetValue();
fData->bWidthPercent = (fPixelPercent->GetValue() == kPercentOfWindowItem);
fData->bNoShade = !fShading->GetValue();
if ( fData->pExtra )
XP_FREE( fData->pExtra );
fData->pExtra = ( pExtra ) ? XP_STRDUP( pExtra ) : NULL;
if (EDT_GetCurrentElementType(fContext) == ED_ELEMENT_HRULE)
EDT_SetHorizRuleData( fContext, fData );
else
EDT_InsertHorizRule( fContext, fData );
EDT_FreeHorizRuleData(fData);
return true;
}
void CLineProp::Help()
{
ShowHelp( HELP_PROPS_HRULE );
}
/**********************************************************/
#pragma mark -
#pragma mark CEditTabSwitcher
CEditTabSwitcher::CEditTabSwitcher(LStream* inStream) : CTabSwitcher(inStream)
{
fLinkName = NULL;
}
CEditTabSwitcher::~CEditTabSwitcher()
{
XP_FREEIF(fLinkName);
}
void CEditTabSwitcher::SetData(MWContext* context, Boolean insert)
{
fContext = context;
fInsert = insert;
}
void CEditTabSwitcher::Help()
{
CEditContain* page = (CEditContain*)mCurrentPage;
if ( page )
page->Help();
}
void CEditTabSwitcher::DoPostLoad(LView* inLoadedPage, Boolean inFromCache)
{
CEditContain * freshPane = (CEditContain*) inLoadedPage;
XP_ASSERT(freshPane);
freshPane->SetContext(fContext);
freshPane->SetInsertFlag(fInsert);
freshPane->SetLinkToLinkName(&fLinkName);
freshPane->SetExtraHTMLString( NULL );
if (!inFromCache) // don't blast the contents of the text edit fields if there is something already there.
freshPane->ControlsFromPref();
}
/**********************************************************/
#pragma mark -
#pragma mark CTabbedDialog
CTabbedDialog::CTabbedDialog( LStream* inStream ): CEditDialog( inStream )
{
ErrorManager::PrepareToInteract();
UDesktop::Deactivate();
}
CTabbedDialog::~CTabbedDialog()
{
UDesktop::Activate();
}
void CTabbedDialog::FinishCreateSelf()
{
mTabControl = NULL;
mTabSwitcher = NULL;
LDialogBox::FinishCreateSelf();
}
void CTabbedDialog::InitializeDialogControls()
{
LControl *ApplyButton = (LControl*)FindPaneByID('APPY');
if (fInsert && ApplyButton)
ApplyButton->Disable();
SetDefaultButton('OKOK');
mTabControl = (CTabControl*)FindPaneByID(CTabControl::class_ID);
ThrowIfNULL_(mTabControl);
mTabSwitcher = (CEditTabSwitcher*)FindPaneByID(CTabSwitcher::class_ID);
ThrowIfNULL_(mTabSwitcher);
mTabSwitcher->SetData(fContext, fInsert);
mTabControl->DoLoadTabs(fInWindowID);
mTabControl->SetValue(fInitTabValue);
}
void CTabbedDialog::RegisterViewTypes()
{
#ifdef COOL_IMAGE_RADIO_BUTTONS
RegisterClass_( CImageAlignButton);
#endif
RegisterClass_( CLargeEditField);
RegisterClass_( CLargeEditFieldBroadcast);
RegisterClass_( CTabControl);
RegisterClass_( CTabbedDialog);
RegisterClass_( CEDCharacterContain);
RegisterClass_( CEDParagraphContain);
RegisterClass_( CEDLinkContain);
RegisterClass_( CEDImageContain);
RegisterClass_( CEDDocPropGeneralContain);
RegisterClass_( CEDDocPropAppearanceContain);
RegisterClass_( CEDDocPropAdvancedContain);
RegisterClass_( LToggleButton);
RegisterClass_( CUnknownTag);
RegisterClass_( CPublish);
RegisterClass_( CTableInsertDialog);
RegisterClass_( CEditTabSwitcher);
RegisterClass_( CEDTableContain);
RegisterClass_( CEDTableCellContain);
RegisterClass_( CEDDocAppearanceNoTab);
RegisterClass_( CFormatMsgColorAndImageDlog);
}
Boolean CTabbedDialog::CommitChanges(Boolean allPanes)
{
if ( !allPanes )
{
MessageT thePageMessage = mTabControl->GetMessageForValue(mTabControl->GetValue());
CEditContain* thePage = (CEditContain*)mTabSwitcher->FindPageByID(thePageMessage);
if (thePage && !thePage->AllFieldsOK())
return FALSE;
if (thePage != NULL)
{
if ( !mUndoInited )
{
EDT_BeginBatchChanges( fContext );
mUndoInited = true;
}
thePage->PrefsFromControls();
}
return true;
}
Int32 start = 1;
Int32 end = mTabControl->GetMaxValue();
// First, lets make sure that all the panes are happy.
for (int i = start; i <= end; i ++ ) {
MessageT thePageMessage = mTabControl->GetMessageForValue(i);
CEditContain* thePage = (CEditContain*)mTabSwitcher->FindPageByID(thePageMessage);
if (thePage && !thePage->AllFieldsOK())
{
mTabControl->SetValue(i); // go to the offending pane.
return FALSE;
}
}
// If the CImagesLocal pane is up, commit that one first (in case we are doing an insert)
if ( !mUndoInited )
{
EDT_BeginBatchChanges( fContext );
mUndoInited = true;
}
for (int i = start; i <= end; i ++ )
{
MessageT thePageMessage = mTabControl->GetMessageForValue(i);
CEditContain* thePage = (CEditContain*)mTabSwitcher->FindPageByID(thePageMessage);
if (thePage && (thePage->GetUserCon() == CEDImageContain::class_ID ))
thePage->PrefsFromControls();
}
// If the CEDLinkContain pane is up, commit that one next (in case we are doing an insert)
for (int i = start; i <= end; i ++ )
{
MessageT thePageMessage = mTabControl->GetMessageForValue(i);
CEditContain* thePage = (CEditContain*)mTabSwitcher->FindPageByID(thePageMessage);
if (thePage && (thePage->GetUserCon() == CEDLinkContain::class_ID ))
thePage->PrefsFromControls();
}
// If the CEDDocPropAppearanceContain pane is up, commit that one first (in case we are doing a doc properties)
for (int i = start; i <= end; i ++ )
{
MessageT thePageMessage = mTabControl->GetMessageForValue(i);
CEditContain* thePage = (CEditContain*)mTabSwitcher->FindPageByID(thePageMessage);
if (thePage && (thePage->GetUserCon() == CEDDocPropAppearanceContain::class_ID ))
thePage->PrefsFromControls();
}
// If the CEDDocPropGeneralContain pane is up, commit that one next (in case we are doing a doc properties)
for (int i = start; i <= end; i ++ )
{
MessageT thePageMessage = mTabControl->GetMessageForValue(i);
CEditContain* thePage = (CEditContain*)mTabSwitcher->FindPageByID(thePageMessage);
if (thePage && (thePage->GetUserCon() == CEDDocPropGeneralContain::class_ID ))
thePage->PrefsFromControls();
}
// commit the rest
for (int i = start; i <= end; i ++ )
{
MessageT thePageMessage = mTabControl->GetMessageForValue(i);
CEditContain* thePage = (CEditContain*)mTabSwitcher->FindPageByID(thePageMessage);
if (thePage && (thePage->GetUserCon() != CEDImageContain::class_ID ) && (thePage->GetUserCon() != CEDLinkContain::class_ID ) &&
(thePage->GetUserCon() != CEDDocPropAppearanceContain::class_ID ) && (thePage->GetUserCon() != CEDDocPropGeneralContain::class_ID ))
thePage->PrefsFromControls();
}
// I admit this is not a very clean design... May cause button flicker when you hit "Insert"
//
// When you are inserting an image or a link and you hit "Apply", the "Insert" button should change to "OK"
// For simplicity, we do it anytime the user hits "Apply", "Insert" or "OK" since the other 2 times the dlog will soon disappear anyway.
LControl *OKButton = (LControl*)FindPaneByID('OKOK');
if (OKButton)
OKButton->Show();
return TRUE;
}
void CTabbedDialog::Help()
{
mTabSwitcher->Help();
}
/**********************************************************/
#pragma mark -
#pragma mark Table Dialogs
static void GetTableDataFromControls( EDT_TableData *fData, LControl *borderCheckBox, LGAEditField *borderWidth,
LGAEditField *cellSpacing, LGAEditField *cellPadding,
LControl *customWidth, LControl *isWPercent, LGAEditField *widthSize,
LControl *customHeight, LControl *isHPercent, LGAEditField *heightSize,
LControl *hasColor, CColorButton *customColor, LO_Color *backgroundColor,
LControl *fastLayout, LGAPopup *alignmentMenu,
LControl *useImage, CLargeEditField *imageName, LControl *leaveImage, char *pExtra )
{
fData->bBorderWidthDefined = borderCheckBox->GetValue();
if ( fData->bBorderWidthDefined )
fData->iBorderWidth = borderWidth->GetValue();
else
fData->iBorderWidth = 0;
fData->iCellSpacing = cellSpacing->GetValue();
fData->iCellPadding = cellPadding->GetValue();
if ( customWidth->GetValue() )
{
fData->bWidthDefined = TRUE;
fData->bWidthPercent = isWPercent->GetValue() == kPercentOfWindowItem;
fData->iWidth = widthSize->GetValue();
}
else
fData->bWidthDefined = FALSE;
if (customHeight->GetValue())
{
fData->bHeightDefined = TRUE;
fData->bHeightPercent = isHPercent->GetValue() == kPercentOfWindowItem;
fData->iHeight = heightSize->GetValue();
}
else
fData->bHeightDefined = FALSE;
if (fData->pColorBackground)
XP_FREE(fData->pColorBackground); // we'll replace it with our own if we use it at all.
fData->pColorBackground = NULL;
if (hasColor->GetValue())
{
*backgroundColor = UGraphics::MakeLOColor(customColor->GetColor());
fData->pColorBackground = backgroundColor; // I hope that EDT_SetTableData() doesn't hang onto this pointer for long...
}
switch ( alignmentMenu->GetValue() )
{
default:
case 1: fData->align = ED_ALIGN_LEFT; break;
case 2: fData->align = ED_ALIGN_ABSCENTER; break;
case 3: fData->align = ED_ALIGN_RIGHT; break;
}
fData->bUseCols = fastLayout->GetValue();
if ( fData->pBackgroundImage )
{
XP_FREE( fData->pBackgroundImage );
fData->pBackgroundImage = NULL;
}
if ( useImage->GetValue() )
fData->pBackgroundImage = imageName->GetLongDescriptor();
fData->bBackgroundNoSave = leaveImage->GetValue();
if ( fData->pExtra )
XP_FREE( fData->pExtra );
fData->pExtra = pExtra; // temporarily assign; we don't want to free it though!
}
CTableInsertDialog::CTableInsertDialog( LStream* inStream ) : CEditDialog( inStream )
{
ErrorManager::PrepareToInteract();
UDesktop::Deactivate();
}
CTableInsertDialog::~CTableInsertDialog()
{
UDesktop::Activate();
}
void CTableInsertDialog::FinishCreateSelf()
{
// Create Controls
CEditDialog::FinishCreateSelf();
UReanimator::LinkListenerToControls( this, this, 5115 ); // the table guts are in RIDL 5115
// Find Controls
fNumRowsEditText = (LGAEditField*)FindPaneByID( 'rows' );
fNumColsEditText = (LGAEditField*)FindPaneByID( 'cols' );
fBorderCheckBox = (LControl*)FindPaneByID( 'BrdW' );
fBorderCheckBox->SetValueMessage( 'BrdW' );
fBorderWidthEditText = (LGAEditField*)FindPaneByID( 'brdw' );
fCellSpacingEditText = (LGAEditField*)FindPaneByID( 'clsp' );
fCellPaddingEditText = (LGAEditField*)FindPaneByID( 'clpd' );
fCustomWidth = (LControl*)FindPaneByID( 'twth' );
fWidthEditText = (LGAEditField*)FindPaneByID( 'wdth' );
fWidthPopup = (LControl*)FindPaneByID( 'WdPU' );
fCustomHeight = (LControl*)FindPaneByID( 'thgt' );
fHeightEditText = (LGAEditField*)FindPaneByID( 'hght' );
fHeightPopup = (LControl*)FindPaneByID( 'HtPU' );
fCustomColor = (LControl*)FindPaneByID( 'tclr' );
fColorCustomColor = (CColorButton*)FindPaneByID( 'Colo' );
fCaptionAboveBelow = (LControl*)FindPaneByID( 'cPop' );
mTableAlignment = (LGAPopup *)FindPaneByID( 'HzPU' );
mFastLayout = (LControl *)FindPaneByID( 'FLay' );
mUseImage = (LControl*)FindPaneByID( 'UseI' );
mImageFileName = (CLargeEditField *)FindPaneByID( 'TImg' );
mImageFileName->AddListener(this);
mLeaveImage = (LControl *)FindPaneByID( 'LvIm' );
// Set control values
EDT_TableData *fData = EDT_NewTableData();
if (fData != NULL)
{
fNumRowsEditText->SetValue( fData->iRows );
fNumColsEditText->SetValue( fData->iColumns );
fBorderCheckBox->SetValue( fData->bBorderWidthDefined );
fBorderWidthEditText->SetValue( fData->iBorderWidth );
fCellSpacingEditText->SetValue( fData->iCellSpacing );
fCellPaddingEditText->SetValue( fData->iCellPadding );
fCustomWidth->SetValue( fData->bWidthDefined );
fWidthEditText->SetValue( fData->iWidth );
fWidthPopup->SetValue( fData->bWidthPercent ? kPercentOfWindowItem : kPixelsItem );
fCustomHeight->SetValue( fData->bHeightDefined );
fHeightEditText->SetValue( fData->iHeight );
fHeightPopup->SetValue( fData->bHeightPercent ? kPercentOfWindowItem : kPixelsItem );
mUseImage->SetValue( fData->pBackgroundImage != NULL );
if ( fData->pBackgroundImage )
mImageFileName->SetLongDescriptor( fData->pBackgroundImage );
mLeaveImage->SetValue( fData->bBackgroundNoSave );
int value;
switch ( fData->align )
{
default:
case ED_ALIGN_LEFT: value = 1; break;
case ED_ALIGN_ABSCENTER: value = 2; break;
case ED_ALIGN_RIGHT: value = 3; break;
}
mTableAlignment->SetValue( value );
mFastLayout->SetValue( fData->bUseCols );
pExtra = fData->pExtra; // don't bother to make our own copy
fData->pExtra = NULL; // set to NULL so backend doesn't delete
EDT_FreeTableData( fData );
}
RGBColor macColor;
fCustomColor->SetValue(FALSE); // no custom color
macColor.red = 0xFFFF; // but start with white if they pick one.
macColor.green = 0xFFFF;
macColor.blue = 0xFFFF;
fColorCustomColor->SetColor(macColor);
fCaptionAboveBelow->SetValue( 1 );
SetLatentSub( fNumRowsEditText );
fNumRowsEditText->SelectAll();
AdjustEnable();
}
void CTableInsertDialog::InitializeDialogControls()
{
short resID;
StringHandle titleH;
if (EDT_IsInsertPointInTable(fContext))
resID = EDITOR_PERCENT_PARENT_CELL;
else
resID = EDITOR_PERCENT_WINDOW;
titleH = GetString( resID );
if (titleH)
{
SInt8 hstate = HGetState( (Handle)titleH );
HLock( (Handle)titleH );
MenuHandle menuh = ((LGAPopup *)fWidthPopup)->GetMacMenuH();
if (menuh)
{
SetMenuItemText( menuh, kPercentOfWindowItem, *titleH );
((LGAPopup *)fWidthPopup)->SetMacMenuH( menuh ); // resets menu width
}
menuh = ((LGAPopup *)fHeightPopup)->GetMacMenuH();
if (menuh)
{
SetMenuItemText( menuh, kPercentOfWindowItem, *titleH );
((LGAPopup *)fHeightPopup)->SetMacMenuH( menuh ); // resets menu width
}
HSetState( (Handle)titleH, hstate );
}
}
void CTableInsertDialog::AdjustEnable()
{
LView *bordercaption = (LView *)FindPaneByID(1);
if ( fBorderCheckBox->GetValue() )
{
bordercaption->Enable();
fBorderWidthEditText->Enable();
}
else
{
bordercaption->Disable();
fBorderWidthEditText->Disable();
}
if (fCustomWidth->GetValue()) {
fWidthEditText->Enable();
fWidthPopup->Enable();
} else {
fWidthEditText->Disable();
fWidthPopup->Disable();
}
if (fCustomHeight->GetValue()) {
fHeightEditText->Enable();
fHeightPopup->Enable();
} else {
fHeightEditText->Disable();
fHeightPopup->Disable();
}
if ( mUseImage->GetValue() )
mLeaveImage->Enable();
else
mLeaveImage->Disable();
}
Boolean CTableInsertDialog::CommitChanges(Boolean /* allPanes */ )
{
if (!IsEditFieldWithinLimits(fNumRowsEditText, 1, 100)) {
SwitchTarget( fNumRowsEditText );
fNumRowsEditText->SelectAll();
return FALSE;
}
if (!IsEditFieldWithinLimits(fNumColsEditText, 1, 100)) {
SwitchTarget( fNumColsEditText );
fNumColsEditText->SelectAll();
return FALSE;
}
if ( fBorderCheckBox->GetValue() )
{
if (!IsEditFieldWithinLimits(fBorderWidthEditText, 0, 10000)) {
SwitchTarget( fBorderWidthEditText );
fBorderWidthEditText->SelectAll();
return FALSE;
}
}
if (!IsEditFieldWithinLimits(fCellSpacingEditText, 0, 10000)) {
SwitchTarget( fCellSpacingEditText );
fCellSpacingEditText->SelectAll();
return FALSE;
}
if (!IsEditFieldWithinLimits(fCellPaddingEditText, 0, 10000)) {
SwitchTarget( fCellPaddingEditText );
fCellPaddingEditText->SelectAll();
return FALSE;
}
if (fCustomWidth->GetValue()) {
if (fWidthPopup->GetValue() == kPixelsItem && !IsEditFieldWithinLimits(fWidthEditText, 1, 10000)) {
SwitchTarget( fWidthEditText );
fWidthEditText->SelectAll();
return FALSE;
}
if (fWidthPopup->GetValue() == kPercentOfWindowItem && !IsEditFieldWithinLimits(fWidthEditText, 1, 100)) {
SwitchTarget( fWidthEditText );
fWidthEditText->SelectAll();
return FALSE;
}
}
if (fCustomHeight->GetValue()) {
if (fHeightPopup->GetValue() == kPixelsItem && !IsEditFieldWithinLimits(fHeightEditText, 1, 10000)) {
SwitchTarget( fHeightEditText );
fHeightEditText->SelectAll();
return FALSE;
}
if (fHeightPopup->GetValue() == kPercentOfWindowItem && !IsEditFieldWithinLimits(fHeightEditText, 1, 100)) {
SwitchTarget( fHeightEditText );
fHeightEditText->SelectAll();
return FALSE;
}
}
LO_Color backgroundColor;
EDT_TableData *fData = EDT_NewTableData();
if (fData == NULL)
return FALSE;
EDT_BeginBatchChanges( fContext );
fData->iRows = fNumRowsEditText->GetValue();
fData->iColumns = fNumColsEditText->GetValue();
GetTableDataFromControls( fData, fBorderCheckBox, fBorderWidthEditText,
fCellSpacingEditText, fCellPaddingEditText,
fCustomWidth, fWidthPopup, fWidthEditText,
fCustomHeight, fHeightPopup, fHeightEditText,
fCustomColor, fColorCustomColor, &backgroundColor,
mFastLayout, mTableAlignment,
mUseImage, mImageFileName, mLeaveImage, pExtra );
EDT_InsertTable( fContext, fData );
fData->pExtra = NULL; // don't free this! we still use it!
fData->pColorBackground = NULL; // no need to free this, it is our local variable!
EDT_FreeTableData(fData);
if (fCaptionAboveBelow->GetValue() != 1)
{
EDT_TableCaptionData* fCaptionData;
fCaptionData = EDT_NewTableCaptionData();
if (fCaptionData)
{
if ( fCaptionAboveBelow->GetValue() == 2 )
fCaptionData->align = ED_ALIGN_ABSTOP;
else if ( fCaptionAboveBelow->GetValue() == 3 )
fCaptionData->align = ED_ALIGN_ABSBOTTOM; // got this constant from CEditTableElement::SetCaption();
EDT_InsertTableCaption( fContext, fCaptionData );
EDT_FreeTableCaptionData( fCaptionData );
}
}
EDT_EndBatchChanges( fContext );
return TRUE;
}
void CTableInsertDialog::Help()
{
ShowHelp( HELP_NEW_TABLE_PROPS );
}
void CTableInsertDialog::ListenToMessage( MessageT inMessage, void* ioParam )
{
switch ( inMessage )
{
case 'BrdW':
case 'twth':
case 'thgt':
case 'tclr':
case 'cptn':
AdjustEnable();
break;
case msg_LinkColorChange:
fCustomColor->SetValue(TRUE);
break;
case 'UseI':
if (mUseImage->GetValue() == 1)
{ // we are trying to set the image
CStr255 url;
mImageFileName->GetDescriptor(url);
if (url == CStr255::sEmptyString)
{ // but it doesn't exist
ChooseImageFile( mImageFileName ); // so try to get it
mImageFileName->GetDescriptor( url );
if (url == CStr255::sEmptyString) // but, if we were unsuccessful
mUseImage->SetValue( 0 ); // revert back.
}
}
AdjustEnable();
break;
case 'wst1':
{
ChooseImageFile( mImageFileName ); // try to get it
CStr255 url2;
mImageFileName->GetDescriptor( url2 );
if (url2 == CStr255::sEmptyString) // if we were unsuccessful
mUseImage->SetValue( 0 ); // don't try to use image
else
mUseImage->SetValue( 1 );
}
AdjustEnable();
break;
case msg_EditField2:
{
CStr255 url3;
mImageFileName->GetDescriptor( url3 );
mUseImage->SetValue( url3[ 0 ] ? Button_On : Button_Off );
}
break;
case 'Xtra':
char * newExtraHTML = NULL;
Boolean canceled = !GetExtraHTML( pExtra, &newExtraHTML ,GetWinCSID() );
if (!canceled)
{
if ( pExtra )
XP_FREE( pExtra );
pExtra = newExtraHTML;
}
break;
default:
LDialogBox::ListenToMessage( inMessage, ioParam );
break;
}
}
void CEDTableContain::FinishCreateSelf()
{
// Find Controls
fNumRowsEditText = (LGAEditField*)this->FindPaneByID( 'rows' );
fNumColsEditText = (LGAEditField*)this->FindPaneByID( 'cols' );
fBorderCheckBox = (LControl*)FindPaneByID( 'BrdW' );
fBorderCheckBox->SetValueMessage( 'BrdW' );
fBorderWidthEditText = (LGAEditField*)this->FindPaneByID( 'brdw' );
fCellSpacingEditText = (LGAEditField*)this->FindPaneByID( 'clsp' );
fCellPaddingEditText = (LGAEditField*)this->FindPaneByID( 'clpd' );
fCustomWidth = (LControl*)this->FindPaneByID( 'twth' );
fWidthEditText = (LGAEditField*)this->FindPaneByID( 'wdth' );
fWidthPopup = (LControl*)this->FindPaneByID( 'WdPU' );
fCustomHeight = (LControl*)this->FindPaneByID( 'thgt' );
fHeightEditText = (LGAEditField*)this->FindPaneByID( 'hght' );
fHeightPopup = (LControl*)this->FindPaneByID( 'HtPU' );
fCustomColor = (LControl*)this->FindPaneByID( 'tclr' );
fColorCustomColor = (CColorButton*)FindPaneByID( 'Colo' );
fCaptionAboveBelow = (LControl*)this->FindPaneByID( 'cPop' );
mTableAlignment = (LGAPopup *)FindPaneByID( 'HzPU' );
mFastLayout = (LControl *)FindPaneByID( 'FLay' );
mUseImage = (LControl*)FindPaneByID( 'UseI' );
mImageFileName = (CLargeEditField *)FindPaneByID( 'TImg' );
mImageFileName->AddListener(this);
mLeaveImage = (LControl *)FindPaneByID( 'LvIm' );
pExtra = NULL;
UReanimator::LinkListenerToControls( this, this, 5115 );
SetLatentSub( fBorderWidthEditText );
fBorderWidthEditText->SelectAll();
}
void CEDTableContain::Help()
{
ShowHelp( HELP_TABLE_PROPS_TABLE );
}
void CEDTableContain::AdjustEnable()
{
LView *bordercaption = (LView *)FindPaneByID(1);
if ( fBorderCheckBox->GetValue() )
{
bordercaption->Enable();
fBorderWidthEditText->Enable();
}
else
{
bordercaption->Disable();
fBorderWidthEditText->Disable();
}
if (fCustomWidth->GetValue()) {
fWidthEditText->Enable();
fWidthPopup->Enable();
} else {
fWidthEditText->Disable();
fWidthPopup->Disable();
}
if (fCustomHeight->GetValue()) {
fHeightEditText->Enable();
fHeightPopup->Enable();
} else {
fHeightEditText->Disable();
fHeightPopup->Disable();
}
if ( mUseImage->GetValue() )
mLeaveImage->Enable();
else
mLeaveImage->Disable();
}
void CEDTableContain::PrefsFromControls()
{
EDT_TableData *fData = EDT_GetTableData(fContext);
if (fData == NULL)
return;
LO_Color backgroundColor;
fData->iRows = fNumRowsEditText->GetValue();
fData->iColumns = fNumColsEditText->GetValue();
GetTableDataFromControls( fData, fBorderCheckBox, fBorderWidthEditText,
fCellSpacingEditText, fCellPaddingEditText,
fCustomWidth, fWidthPopup, fWidthEditText,
fCustomHeight, fHeightPopup, fHeightEditText,
fCustomColor, fColorCustomColor, &backgroundColor,
mFastLayout, mTableAlignment,
mUseImage, mImageFileName, mLeaveImage, pExtra );
EDT_SetTableData( fContext, fData );
fData->pExtra = NULL; // don't free this! we still use it!
fData->pColorBackground = NULL; // no need to free this, it is our local variable!
EDT_FreeTableData(fData);
// deal with caption
EDT_TableCaptionData* fCaptionData = EDT_GetTableCaptionData(fContext); // find out if we have a caption....
if (fCaptionAboveBelow->GetValue() == 1) /* no caption */
{
if (fCaptionData)
{
EDT_DeleteTableCaption(fContext); // there is one, but we don't want it.
EDT_FreeTableCaptionData(fCaptionData);
}
}
else
{
if (fCaptionData)
{ // we want one, and there is one!!!
if ( fCaptionAboveBelow->GetValue() == 1 )
fCaptionData->align = ED_ALIGN_ABSTOP;
else
fCaptionData->align = ED_ALIGN_ABSBOTTOM;
EDT_SetTableCaptionData( fContext, fCaptionData );
}
else
{
fCaptionData = EDT_NewTableCaptionData(); // we want one and there isn't one!!
if (fCaptionData)
{
if ( fCaptionAboveBelow->GetValue() == 1 )
fCaptionData->align = ED_ALIGN_ABSTOP;
else
fCaptionData->align = ED_ALIGN_ABSBOTTOM;
EDT_InsertTableCaption( fContext, fCaptionData );
}
}
if (fCaptionData)
EDT_FreeTableCaptionData(fCaptionData); // we have to check this, because EDT_NewTableCaptionData() may have returned NULL
}
}
// Initialize from preferences
void CEDTableContain::ControlsFromPref()
{
short resID;
StringHandle titleH;
if (EDT_IsInsertPointInNestedTable(fContext))
resID = EDITOR_PERCENT_PARENT_CELL;
else
resID = EDITOR_PERCENT_WINDOW;
titleH = GetString( resID );
if (titleH)
{
SInt8 hstate = HGetState( (Handle)titleH );
HLock( (Handle)titleH );
HSetState( (Handle)titleH, hstate );
MenuHandle menuh = ((LGAPopup *)fWidthPopup)->GetMacMenuH();
if (menuh)
{
SetMenuItemText( menuh, kPercentOfWindowItem, *titleH );
((LGAPopup *)fWidthPopup)->SetMacMenuH( menuh ); // resets menu width
}
menuh = ((LGAPopup *)fHeightPopup)->GetMacMenuH();
if (menuh)
{
SetMenuItemText( menuh, kPercentOfWindowItem, *titleH );
((LGAPopup *)fHeightPopup)->SetMacMenuH( menuh ); // resets menu width
}
}
EDT_TableData* fData = EDT_GetTableData(fContext);
if (fData == NULL)
return;
fNumColsEditText->SetValue( fData->iColumns );
fNumColsEditText->Enable();
fNumRowsEditText->SetValue( fData->iRows );
fNumRowsEditText->Enable();
switch (fData->align)
{
default:
case ED_ALIGN_LEFT: mTableAlignment->SetValue( 1 ); break;
case ED_ALIGN_ABSCENTER: mTableAlignment->SetValue( 2 ); break;
case ED_ALIGN_RIGHT: mTableAlignment->SetValue( 3 ); break;
}
mFastLayout->SetValue( fData->bUseCols );
fBorderCheckBox->SetValue( fData->bBorderWidthDefined );
fBorderWidthEditText->SetValue( fData->iBorderWidth );
fCellSpacingEditText->SetValue( fData->iCellSpacing );
fCellPaddingEditText->SetValue( fData->iCellPadding );
fCustomWidth->SetValue( fData->bWidthDefined );
fWidthEditText->SetValue( fData->iWidth );
fWidthPopup->SetValue( fData->bWidthPercent ? kPercentOfWindowItem : kPixelsItem );
fCustomHeight->SetValue( fData->bHeightDefined );
fHeightEditText->SetValue( fData->iHeight );
fHeightPopup->SetValue( fData->bHeightPercent ? kPercentOfWindowItem : kPixelsItem );
RGBColor macColor;
fCustomColor->SetValue( fData->pColorBackground != NULL );
if (fData->pColorBackground)
macColor = UGraphics::MakeRGBColor(*fData->pColorBackground);
else
macColor = UGraphics::MakeRGBColor(255, 255, 255);
fColorCustomColor->SetColor( macColor );
if ( fData->pBackgroundImage )
{
mImageFileName->SetLongDescriptor( fData->pBackgroundImage );
// turn on after we set the descriptor so we don't handle as click when msg is broadcast
TurnOn( mUseImage );
}
mLeaveImage->SetValue( fData->bBackgroundNoSave );
pExtra = fData->pExtra;
fData->pExtra = NULL; // we'll take over this copy; don't let backend dispose of it
EDT_FreeTableData(fData);
// check the caption....
EDT_TableCaptionData* fCaptionData = EDT_GetTableCaptionData( fContext );
if (fCaptionData)
{
if (fCaptionData->align != ED_ALIGN_ABSBOTTOM)
fCaptionAboveBelow->SetValue( 2 );
else
fCaptionAboveBelow->SetValue( 3 );
EDT_FreeTableCaptionData(fCaptionData);
}
else
{
fCaptionAboveBelow->SetValue( 1 );
}
AdjustEnable();
}
Boolean CEDTableContain::AllFieldsOK()
{
EDT_TableData* fData = EDT_GetTableData(fContext);
if (fData == NULL)
return FALSE;
int upperBoundRows = fData->iRows > 100 ? fData->iRows : 100; // just in case iRows is over 100
if (!IsEditFieldWithinLimits(fNumRowsEditText, fData->iRows, upperBoundRows)) {
SwitchTarget( fNumRowsEditText );
fNumRowsEditText->SelectAll();
return FALSE;
}
int upperBoundCols = fData->iColumns > 100 ? fData->iColumns : 100;
if (!IsEditFieldWithinLimits(fNumColsEditText, fData->iColumns, upperBoundCols)) {
SwitchTarget( fNumColsEditText );
fNumColsEditText->SelectAll();
return FALSE;
}
if ( fBorderCheckBox->GetValue() )
{
if (!IsEditFieldWithinLimits(fBorderWidthEditText, 0, 10000)) {
SwitchTarget( fBorderWidthEditText );
fBorderWidthEditText->SelectAll();
return FALSE;
}
}
if (!IsEditFieldWithinLimits(fCellSpacingEditText, 0, 10000)) {
SwitchTarget( fCellSpacingEditText );
fCellSpacingEditText->SelectAll();
return FALSE;
}
if (!IsEditFieldWithinLimits(fCellPaddingEditText, 0, 10000)) {
SwitchTarget( fCellPaddingEditText );
fCellPaddingEditText->SelectAll();
return FALSE;
}
if (fCustomWidth->GetValue()) {
if (fWidthPopup->GetValue() == kPixelsItem && !IsEditFieldWithinLimits(fWidthEditText, 1, 10000)) {
SwitchTarget( fWidthEditText );
fWidthEditText->SelectAll();
return FALSE;
}
if (fWidthPopup->GetValue() == kPercentOfWindowItem && !IsEditFieldWithinLimits(fWidthEditText, 1, 100)) {
SwitchTarget( fWidthEditText );
fWidthEditText->SelectAll();
return FALSE;
}
}
if (fCustomHeight->GetValue()) {
if (fHeightPopup->GetValue() == kPixelsItem && !IsEditFieldWithinLimits(fHeightEditText, 1, 10000)) {
SwitchTarget( fHeightEditText );
fHeightEditText->SelectAll();
return FALSE;
}
if (fHeightPopup->GetValue() == kPercentOfWindowItem && !IsEditFieldWithinLimits(fHeightEditText, 1, 100)) {
SwitchTarget( fHeightEditText );
fHeightEditText->SelectAll();
return FALSE;
}
}
return TRUE;
}
void CEDTableContain::ListenToMessage( MessageT inMessage, void* /* ioParam */ )
{
//Intercept messages we should act on....
switch (inMessage)
{
case 'BrdW':
case 'twth':
case 'thgt':
case 'tclr':
case 'cptn':
AdjustEnable();
break;
case msg_LinkColorChange:
fCustomColor->SetValue(TRUE);
break;
case 'UseI':
if (mUseImage->GetValue() == 1)
{ // we are trying to set the image
CStr255 url;
mImageFileName->GetDescriptor(url);
if (url == CStr255::sEmptyString)
{ // but it doesn't exist
CEditDialog::ChooseImageFile( mImageFileName ); // so try to get it
mImageFileName->GetDescriptor( url );
if (url == CStr255::sEmptyString) // but, if we were unsuccessful
mUseImage->SetValue( 0 ); // revert back.
}
}
AdjustEnable();
break;
case 'wst1':
{
CEditDialog::ChooseImageFile( mImageFileName ); // try to get it
CStr255 url2;
mImageFileName->GetDescriptor( url2 );
if (url2 == CStr255::sEmptyString) // if we were unsuccessful
mUseImage->SetValue( 0 ); // don't try to use image
else
mUseImage->SetValue( 1 );
}
AdjustEnable();
break;
case msg_EditField2:
{
CStr255 url3;
mImageFileName->GetDescriptor( url3 );
mUseImage->SetValue( url3[ 0 ] ? Button_On : Button_Off );
}
break;
case 'Xtra':
char * newExtraHTML = NULL;
Boolean canceled = !GetExtraHTML( pExtra, &newExtraHTML ,GetWinCSID() );
if (!canceled)
{
if ( pExtra )
XP_FREE( pExtra );
pExtra = newExtraHTML;
}
break;
}
// Pass all messages on...
}
void CEDTableCellContain::FinishCreateSelf()
{
fRowSpanEditText = (LGAEditField*)this->FindPaneByID( 'rows' );
fColSpanEditText = (LGAEditField*)this->FindPaneByID( 'cols' );
spanCaption = (LGACaption*)FindPaneByID( 'span' );
rowCaption = (LGACaption*)FindPaneByID( 'rCap' );
colCaption = (LGACaption*)FindPaneByID( 'cCap' );
fHorizontalAlignment = (LGAPopup *)this->FindPaneByID( 'HzPU' );
fVerticalAlignment = (LGAPopup *)this->FindPaneByID( 'VtPU' );
fHeaderStyle = (LControl*)this->FindPaneByID( 'head' );
fWrapText = (LControl*)this->FindPaneByID( 'wrap' );
fCustomWidth = (LControl*)this->FindPaneByID( 'cwth' );
fWidthEditText = (LGAEditField*)this->FindPaneByID( 'wdth' );
fWidthPopup = (LControl*)this->FindPaneByID( 'WdPU' ); // popup menu
fCustomHeight = (LControl*)this->FindPaneByID( 'chgt' );
fHeightEditText = (LGAEditField*)this->FindPaneByID( 'hght' );
fHeightPopup = (LControl*)this->FindPaneByID( 'HtPU' ); // popup menu
fCustomColor = (LControl*)this->FindPaneByID( 'cclr' );
fColorCustomColor = (CColorButton*)FindPaneByID( 'Colo' );
mNextButton = (LControl*)this->FindPaneByID( 'NEXT' );
mPreviousButton = (LControl*)this->FindPaneByID( 'PREV' );
mUseImage = (LControl*)FindPaneByID( 'UseI' );
mImageFileName = (CLargeEditField *)FindPaneByID( 'TImg' );
mImageFileName->AddListener(this);
mLeaveImage = (LControl *)FindPaneByID( 'LvIm' );
pExtra = NULL;
UReanimator::LinkListenerToControls( this, this, mPaneID );
}
void CEDTableCellContain::Help()
{
ShowHelp( HELP_TABLE_PROPS_CELL );
}
void CEDTableCellContain::AdjustEnable()
{
ETriState rowEnableState = fRowSpanEditText->GetEnabledState();
ETriState colEnableState = fColSpanEditText->GetEnabledState();
// We do not use IsEnabled() because it returns false when we display the dialog box for
// the first time. The two edit fields' mVisibles are Tri_Latent in the beginning. Since
// the superview is not yet visible, the edit fields are not visible either. The code
// here will activate the captions as long as fRowSpanEditText and fColSpanEditText are not
// triState_Off.
if ( rowEnableState != triState_Off || colEnableState != triState_Off )
spanCaption->Activate();
else
spanCaption->Deactivate();
if ( rowEnableState != triState_Off )
rowCaption->Activate();
else
rowCaption->Deactivate();
if ( colEnableState != triState_Off )
colCaption->Activate();
else
colCaption->Deactivate();
if (fCustomWidth->GetValue())
{
fWidthEditText->Enable();
fWidthPopup->Enable();
}
else
{
fWidthEditText->Disable();
fWidthPopup->Disable();
}
if (fCustomHeight->GetValue())
{
fHeightEditText->Enable();
fHeightPopup->Enable();
}
else
{
fHeightEditText->Disable();
fHeightPopup->Disable();
}
if ( mUseImage->GetValue() )
mLeaveImage->Enable();
else
mLeaveImage->Disable();
}
void CEDTableCellContain::PrefsFromControls()
{
EDT_TableCellData* cellData = EDT_GetTableCellData( fContext );
if (cellData == NULL)
return;
if ( fRowSpanEditText->IsEnabled() ) /* assume CF_ROWSPAN bit already set properly */
cellData->iRowSpan = fRowSpanEditText->GetValue();
if ( fColSpanEditText->IsEnabled() ) /* assume CF_COLSPAN bit already set properly */
cellData->iColSpan = fColSpanEditText->GetValue();
int curValue;
curValue = fHorizontalAlignment->GetValue();
if ( !(cellData->mask & CF_ALIGN ) && curValue != 4 )
cellData->mask |= CF_ALIGN;
switch ( curValue )
{
default:
case 1: cellData->align = ED_ALIGN_LEFT; break;
case 2: cellData->align = ED_ALIGN_ABSCENTER; break;
case 3: cellData->align = ED_ALIGN_RIGHT; break;
case 4: break; // mixed state; don't reset
}
curValue = fVerticalAlignment->GetValue();
if ( !(cellData->mask & CF_VALIGN ) && curValue != 5 )
cellData->mask |= CF_VALIGN;
switch ( curValue )
{
default:
case 1: cellData->valign = ED_ALIGN_ABSTOP; break;
case 2: cellData->valign = ED_ALIGN_ABSCENTER; break;
case 3: cellData->valign = ED_ALIGN_BASELINE; break;
case 4: cellData->valign = ED_ALIGN_ABSBOTTOM; break;
case 5: break; // mixed state; don't reset
}
curValue = fHeaderStyle->GetValue();
if ( curValue != 2 )
{
if ( !(cellData->mask & CF_HEADER ) )
cellData->mask |= CF_HEADER;
cellData->bHeader = curValue;
}
curValue = fWrapText->GetValue();
if ( curValue != 2 )
{
if ( !(cellData->mask & CF_NOWRAP ) )
cellData->mask |= CF_NOWRAP;
cellData->bNoWrap = curValue;
}
curValue = fCustomWidth->GetValue();
if ( !(cellData->mask & CF_WIDTH ) && curValue != 2 )
cellData->mask |= CF_WIDTH;
if ( curValue == 1 )
{
cellData->bWidthDefined = TRUE;
cellData->bWidthPercent = fWidthPopup->GetValue() == kPercentOfWindowItem;
cellData->iWidth = fWidthEditText->GetValue();
}
else if ( curValue == 0 )
cellData->bWidthDefined = FALSE;
curValue = fCustomHeight->GetValue();
if ( !(cellData->mask & CF_HEIGHT ) && curValue != 2 )
cellData->mask |= CF_HEIGHT;
if ( curValue == 1 )
{
cellData->bHeightDefined = TRUE;
cellData->bHeightPercent = fHeightPopup->GetValue() == kPercentOfWindowItem;
cellData->iHeight = fHeightEditText->GetValue();
}
else if ( curValue == 0 )
cellData->bHeightDefined = FALSE;
XP_FREEIF( cellData->pColorBackground ); // we'll replace it with our own if we use it at all.
cellData->pColorBackground = NULL;
LO_Color pColor;
curValue = fCustomColor->GetValue();
if ( curValue != 2 && !(cellData->mask & CF_BACK_COLOR ) )
cellData->mask |= CF_BACK_COLOR;
if ( curValue == 1 )
{
pColor = UGraphics::MakeLOColor(fColorCustomColor->GetColor());
cellData->pColorBackground = &pColor;
}
else if ( curValue == 0 )
cellData->pColorBackground = NULL;
XP_FREEIF( cellData->pBackgroundImage );
cellData->pBackgroundImage = NULL;
curValue = mUseImage->GetValue();
if ( !(cellData->mask & CF_BACK_IMAGE ) && curValue != 2 )
cellData->mask |= CF_BACK_IMAGE;
if ( curValue == 1 )
cellData->pBackgroundImage = mImageFileName->GetLongDescriptor();
curValue = mLeaveImage->GetValue();
if ( curValue != 2 )
{
if ( !(cellData->mask & CF_BACK_NOSAVE ) )
cellData->mask |= CF_BACK_NOSAVE;
cellData->bBackgroundNoSave = curValue;
}
LView* extrahtmlbutton = (LView *)FindPaneByID( 'Xtra' );
XP_ASSERT( extrahtmlbutton != NULL );
if ( !(cellData->mask & CF_EXTRA_HTML ) )
XP_ASSERT( 1 );
if ( extrahtmlbutton && extrahtmlbutton->IsEnabled() )
{
XP_FREEIF( cellData->pExtra );
cellData->pExtra = pExtra;
}
else
cellData->pExtra = NULL; /* this is probably not the right thing to do but... */
EDT_SetTableCellData( fContext, cellData );
cellData->pColorBackground = NULL; // don't try to free our local variable.
cellData->pExtra = NULL; // this is our copy; don't let backend delete!
EDT_FreeTableCellData( cellData );
}
// Initialize from preferences
void CEDTableCellContain::ControlsFromPref()
{
EDT_TableCellData* cellData = EDT_GetTableCellData( fContext );
if (cellData == NULL)
return;
// set popup menus depending if nested in another table or just in window
short resID;
StringHandle titleH;
if (EDT_IsInsertPointInNestedTable(fContext))
resID = EDITOR_PERCENT_PARENT_CELL;
else
resID = EDITOR_PERCENT_WINDOW;
titleH = GetString( resID );
if (titleH)
{
SInt8 hstate = HGetState( (Handle)titleH );
HLock( (Handle)titleH );
HSetState( (Handle)titleH, hstate );
MenuHandle menuh = ((LGAPopup *)fWidthPopup)->GetMacMenuH();
if (menuh)
{
SetMenuItemText( menuh, kPercentOfWindowItem, *titleH );
((LGAPopup *)fWidthPopup)->SetMacMenuH( menuh ); // resets menu width
}
menuh = ((LGAPopup *)fHeightPopup)->GetMacMenuH();
if (menuh)
{
SetMenuItemText( menuh, kPercentOfWindowItem, *titleH );
((LGAPopup *)fHeightPopup)->SetMacMenuH( menuh ); // resets menu width
}
}
/* col span */
if ( (cellData->mask & CF_COLSPAN) )
{
fColSpanEditText->SetValue( cellData->iColSpan );
fColSpanEditText->Enable();
}
else
fColSpanEditText->Disable();
/* row span */
if ( (cellData->mask & CF_ROWSPAN) )
{
fRowSpanEditText->SetValue( cellData->iRowSpan );
fRowSpanEditText->Enable();
}
else
fRowSpanEditText->Disable();
/* horizontal alignment */
if ( (cellData->mask & CF_ALIGN) )
{
switch ( cellData->align )
{
case ED_ALIGN_DEFAULT:
case ED_ALIGN_LEFT: fHorizontalAlignment->SetValue( 1 ); break;
case ED_ALIGN_ABSCENTER: fHorizontalAlignment->SetValue( 2 ); break;
case ED_ALIGN_RIGHT: fHorizontalAlignment->SetValue( 3 ); break;
}
}
else
fHorizontalAlignment->SetValue( 4 );
/* vertical alignment */
if ( (cellData->mask & CF_VALIGN) )
{
switch ( cellData->valign )
{
case ED_ALIGN_ABSTOP: fVerticalAlignment->SetValue( 1 ); break;
case ED_ALIGN_ABSCENTER: fVerticalAlignment->SetValue( 2 ); break;
case ED_ALIGN_BASELINE: fVerticalAlignment->SetValue( 3 ); break;
case ED_ALIGN_ABSBOTTOM: fVerticalAlignment->SetValue( 4 ); break;
}
}
else
fVerticalAlignment->SetValue( 5 );
/* text */
fHeaderStyle->SetValue( (cellData->mask & CF_HEADER) ? cellData->bHeader : 2 );
fWrapText->SetValue( (cellData->mask & CF_NOWRAP) ? cellData->bNoWrap : 2 );
fCustomWidth->SetValue( (cellData->mask & CF_WIDTH) ? cellData->bWidthDefined : 2 );
if ( cellData->bWidthDefined )
{
fWidthEditText->SetValue( cellData->iWidth );
fWidthPopup->SetValue( (cellData->bWidthPercent) ? kPercentOfWindowItem : kPixelsItem );
}
else
{
fWidthEditText->SetValue(20); // where do we get the default value?
fWidthPopup->SetValue( kPercentOfWindowItem );
}
fCustomHeight->SetValue( (cellData->mask & CF_HEIGHT) ? cellData->bHeightDefined : 2 );
if ( cellData->bHeightDefined )
{
fHeightEditText->SetValue(cellData->iHeight);
fHeightPopup->SetValue( (cellData->bHeightPercent) ? kPercentOfWindowItem : kPixelsItem );
}
else
{
fHeightEditText->SetValue(20); // where do we get the default value?
fHeightPopup->SetValue( kPercentOfWindowItem );
}
fCustomColor->SetValue( (cellData->mask & CF_BACK_COLOR) ? cellData->pColorBackground != NULL : 2 );
RGBColor rgb;
if ( cellData->pColorBackground )
rgb = UGraphics::MakeRGBColor( *cellData->pColorBackground );
else
rgb = UGraphics::MakeRGBColor( 0xFF, 0xFF, 0xFF ); // something pretty... (or, better yet, get the default color - yeah, right!)
fColorCustomColor->SetColor( rgb );
fColorCustomColor->Refresh(); // CColorButton::SetColor does not refresh automatically, so we call refresh
mImageFileName->SetLongDescriptor( cellData->pBackgroundImage ? cellData->pBackgroundImage : "" );
mUseImage->SetValue( (cellData->mask & CF_BACK_IMAGE) ? cellData->pBackgroundImage != NULL : 2 );
mLeaveImage->SetValue( (cellData->mask & CF_BACK_NOSAVE) ? cellData->bBackgroundNoSave : 2 );
LView* extrahtmlbutton = (LView *)FindPaneByID( 'Xtra' );
XP_ASSERT( extrahtmlbutton != NULL );
if ( (cellData->mask & CF_EXTRA_HTML) )
{
extrahtmlbutton->Enable();
pExtra = cellData->pExtra;
cellData->pExtra = NULL; // don't let backend free!
}
else
{
/* don't agree; disable for now */
extrahtmlbutton->Disable();
pExtra = NULL;
}
EDT_FreeTableCellData(cellData);
AdjustEnable();
}
Boolean CEDTableCellContain::AllFieldsOK()
{
if ( fRowSpanEditText->IsEnabled()
&& !IsEditFieldWithinLimits( fRowSpanEditText, 1, 100 ) )
{
SwitchTarget( fRowSpanEditText );
fRowSpanEditText->SelectAll();
return FALSE;
}
if ( fColSpanEditText->IsEnabled()
&& !IsEditFieldWithinLimits(fColSpanEditText, 1, 100 ) )
{
SwitchTarget( fColSpanEditText );
fColSpanEditText->SelectAll();
return FALSE;
}
if ( fCustomWidth->GetValue() == 1 )
{
int popupValue = fWidthPopup->GetValue();
if (popupValue == kPercentOfWindowItem && !IsEditFieldWithinLimits(fWidthEditText, 1, 100)) {
SwitchTarget( fWidthEditText );
fWidthEditText->SelectAll();
return FALSE;
}
if (popupValue == kPixelsItem && !IsEditFieldWithinLimits(fWidthEditText, 1, 10000)) {
SwitchTarget( fWidthEditText );
fWidthEditText->SelectAll();
return FALSE;
}
}
if ( fCustomHeight->GetValue() == 1 )
{
int popupValue = fHeightPopup->GetValue();
if (popupValue == kPercentOfWindowItem && !IsEditFieldWithinLimits(fHeightEditText, 1, 100)) {
SwitchTarget( fHeightEditText );
fHeightEditText->SelectAll();
return FALSE;
}
if (popupValue == kPixelsItem && !IsEditFieldWithinLimits(fHeightEditText, 1, 10000)) {
SwitchTarget( fHeightEditText );
fHeightEditText->SelectAll();
return FALSE;
}
}
return TRUE;
}
void CEDTableCellContain::ListenToMessage( MessageT inMessage, void* /* ioParam */ )
{
switch ( inMessage )
{
case 'TsPU': /* popup menu item was changed */
case 'PREV':
case 'NEXT':
/* approprate selection */
ED_HitType moveType = ED_HIT_SEL_CELL;
LGAPopup * tableSelectionPopup = (LGAPopup*)FindPaneByID( 'TsPU' );
if ( tableSelectionPopup )
{
switch ( tableSelectionPopup->GetValue() )
{
case 1: /* cell */
moveType = ED_HIT_SEL_CELL;
break;
case 2: /* row */
moveType = ED_HIT_SEL_ROW;
break;
case 3: /* column */
moveType = ED_HIT_SEL_COL;
break;
}
}
ED_MoveSelType moveDirection;
if (inMessage == 'PREV')
moveDirection = ED_MOVE_PREV;
else if (inMessage == 'NEXT')
moveDirection = ED_MOVE_NEXT;
else if (inMessage == 'TsPU')
moveDirection = ED_MOVE_NONE;
if ( AllFieldsOK() )
{
EDT_BeginBatchChanges( fContext );
PrefsFromControls();
EDT_EndBatchChanges( fContext);
EDT_ChangeTableSelection( fContext, moveType, moveDirection, NULL );
ControlsFromPref(); // fill in new data
}
break; // if fields are not ok, don't change anything
case 'cwth':
case 'chgt':
case 'cclr':
AdjustEnable();
break;
case msg_LinkColorChange:
fCustomColor->SetValue( TRUE );
break;
case 'UseI':
if (mUseImage->GetValue() == 1)
{ // we are trying to set the image
CStr255 url;
mImageFileName->GetDescriptor(url);
if (url == CStr255::sEmptyString)
{ // but it doesn't exist
CEditDialog::ChooseImageFile( mImageFileName ); // so try to get it
mImageFileName->GetDescriptor( url );
if (url == CStr255::sEmptyString) // but, if we were unsuccessful
mUseImage->SetValue( 0 ); // revert back.
}
}
AdjustEnable();
break;
case 'wst1':
{
CEditDialog::ChooseImageFile( mImageFileName ); // try to get it
CStr255 url2;
mImageFileName->GetDescriptor( url2 );
if (url2 == CStr255::sEmptyString) // if we were unsuccessful
mUseImage->SetValue( 0 ); // don't try to use image
else
mUseImage->SetValue( 1 );
}
AdjustEnable();
break;
case msg_EditField2:
{
CStr255 url3;
mImageFileName->GetDescriptor( url3 );
mUseImage->SetValue( url3[ 0 ] ? Button_On : Button_Off );
}
break;
case 'Xtra':
char * newExtraHTML = NULL;
Boolean canceled = !GetExtraHTML( pExtra, &newExtraHTML ,GetWinCSID() );
if (!canceled)
{
if ( pExtra )
XP_FREE( pExtra );
pExtra = newExtraHTML;
}
break;
}
}
/**********************************************************/
#pragma mark -
#pragma mark Standard Editor Dialogs
void CEDCharacterContain::FinishCreateSelf()
{
fTextSizePopup = (LControl*)FindPaneByID( 'txsz' );
mFontMenu = (LControl*)FindPaneByID( 'Font' );
mFontChanged = false;
fColorDefaultRadio = (LControl*)FindPaneByID( 'DocD' );
fColorCustomRadio = (LControl*)FindPaneByID( 'CstC' );
fColorCustomColor = (CColorButton*)FindPaneByID( 'ChCr' );
fTextBoldCheck = (LControl*)FindPaneByID( 'Bold' );
fTextItalicCheck = (LControl*)FindPaneByID( 'Ital' );
fTextSuperscriptCheck = (LControl*)FindPaneByID( 'Supe' );
fTextSubscriptCheck = (LControl*)FindPaneByID( 'Subs' );
fTextNoBreaksCheck = (LControl*)FindPaneByID( 'NoBR' );
fTextUnderlineCheck = (LControl*)FindPaneByID( 'Unln' );
fTextStrikethroughCheck = (LControl*)FindPaneByID( 'Stri' );
fTextBlinkingCheck = (LControl*)FindPaneByID( 'Blin' );
fClearTextStylesButton = (LControl*)FindPaneByID( 'CTSB' );
fClearAllStylesButton = (LControl*)FindPaneByID( 'CASB' );
LView::FinishCreateSelf();
UReanimator::LinkListenerToControls( this, this, mPaneID );
fTextSizePopup->Show();
}
void CEDCharacterContain::PrefsFromControls()
{
LO_Color pColor; // we pass EDT_SetCharacterData() a pointer to this, so it has to be around for awhile.
if (EDT_GetCurrentElementType(fContext) != ED_ELEMENT_TEXT
&& EDT_GetCurrentElementType(fContext) != ED_ELEMENT_SELECTION)
return;
EDT_CharacterData* better = EDT_NewCharacterData();
if (better == NULL)
return;
better->mask = TF_NONE;
better->values = TF_NONE;
if (fColorChanged) {
better->mask |= TF_FONT_COLOR;
if (fColorDefaultRadio->GetValue()) {
better->pColor = NULL;
} else {
better->values |= TF_FONT_COLOR;
pColor = UGraphics::MakeLOColor(fColorCustomColor->GetColor());
better->pColor = &pColor; // I hope that EDT_SetCharacterData() doesn't hang onto this pointer for long...
}
}
if (fSizeChanged) {
better->mask |= TF_FONT_SIZE;
better->values |= TF_FONT_SIZE; // I'm not supposed to set this if we are using the default font size. But how do I know? An extra menu item??
better->iSize = fTextSizePopup->GetValue();
}
if ( mFontChanged )
{
better->mask |= TF_FONT_FACE;
if ( better->pFontFace )
{
XP_FREE( better->pFontFace );
better->pFontFace = NULL;
}
int menuitem = mFontMenu->GetValue();
if ( menuitem == 1 || menuitem == 2 ) // default menu items
{
better->values &= ~TF_FONT_FACE; // I'm supposed to clear TF_FONT_FACE if we are using the default font.
if ( menuitem == 2 ) // if fixed width, do it differently
better->values |= TF_FIXED;
else
better->values &= ~TF_FIXED; // not fixed if we have a font!
}
else
{
better->values |= TF_FONT_FACE;
better->values &= ~TF_FIXED; // not fixed if we have a font!
Str255 s;
s[ 0 ] = 0;
((LGAPopup *)mFontMenu)->GetCurrentItemTitle( s );
p2cstr( s );
better->pFontFace = XP_STRDUP( (char *)s );
}
}
if (fTextBoldCheck->GetValue() == 1) better->values |= TF_BOLD; // what values to set to
if (fTextItalicCheck->GetValue() == 1) better->values |= TF_ITALIC;
if (fTextSuperscriptCheck->GetValue() == 1) better->values |= TF_SUPER;
if (fTextSubscriptCheck->GetValue() == 1) better->values |= TF_SUB;
if (fTextNoBreaksCheck->GetValue() == 1) better->values |= TF_NOBREAK;
if (fTextUnderlineCheck->GetValue() == 1) better->values |= TF_UNDERLINE;
if (fTextStrikethroughCheck->GetValue() == 1) better->values |= TF_STRIKEOUT;
if (fTextBlinkingCheck->GetValue() == 1) better->values |= TF_BLINK;
if (fTextBoldCheck->GetValue() != 2) better->mask |= TF_BOLD; // if the checkbox is still mixed, don't set anything
if (fTextItalicCheck->GetValue() != 2) better->mask |= TF_ITALIC;
if (fTextSuperscriptCheck->GetValue() != 2) better->mask |= TF_SUPER;
if (fTextSubscriptCheck->GetValue() != 2) better->mask |= TF_SUB;
if (fTextNoBreaksCheck->GetValue() != 2) better->mask |= TF_NOBREAK;
if (fTextUnderlineCheck->GetValue() != 2) better->mask |= TF_UNDERLINE;
if (fTextStrikethroughCheck->GetValue() != 2) better->mask |= TF_STRIKEOUT;
if (fTextBlinkingCheck->GetValue() != 2) better->mask |= TF_BLINK;
EDT_SetFontFace( fContext, better, -1, better->pFontFace );
// EDT_SetCharacterData(fContext, better);
better->pColor = NULL; // this is ours. Don't free it.
EDT_FreeCharacterData(better);
}
static void SetFontMenuItemByString( LGAPopup *menu, char *font )
{
if ( font == NULL )
{
menu->SetValue( 1 );
return;
}
Str255 str;
int i, maxitem;
maxitem = menu->GetMaxValue();
MenuHandle popupMenu = menu->GetMacMenuH ();
for ( i = 1; i <= maxitem; i++ )
{
::GetMenuItemText ( popupMenu, i, str );
p2cstr(str);
if ( XP_STRSTR( font, (char *)str ) != NULL )
{
menu->SetValue( i );
::SetItemMark( popupMenu, i, '-' );
break;
}
}
}
// Initialize from preferences
void CEDCharacterContain::ControlsFromPref()
{
if (EDT_GetCurrentElementType(fContext) != ED_ELEMENT_TEXT
&& EDT_GetCurrentElementType(fContext) != ED_ELEMENT_SELECTION) return;
EDT_CharacterData* better = EDT_GetCharacterData( fContext );
if (better == NULL) return;
fTextBoldCheck->SetValue(better->values & TF_BOLD ? 1 : 0);
fTextItalicCheck->SetValue(better->values & TF_ITALIC ? 1 : 0);
fTextSuperscriptCheck->SetValue(better->values & TF_SUPER ? 1 : 0);
fTextSubscriptCheck->SetValue(better->values & TF_SUB ? 1 : 0);
fTextNoBreaksCheck->SetValue(better->values & TF_NOBREAK ? 1 : 0);
fTextUnderlineCheck->SetValue(better->values & TF_UNDERLINE ? 1 : 0);
fTextStrikethroughCheck->SetValue(better->values & TF_STRIKEOUT ? 1 : 0);
fTextBlinkingCheck->SetValue(better->values & TF_BLINK ? 1 : 0);
if (!(better->mask & TF_BOLD)) fTextBoldCheck->SetValue(2);
if (!(better->mask & TF_ITALIC)) fTextItalicCheck->SetValue(2);
if (!(better->mask & TF_SUPER)) fTextSuperscriptCheck->SetValue(2);
if (!(better->mask & TF_SUB)) fTextSubscriptCheck->SetValue(2);
if (!(better->mask & TF_NOBREAK)) fTextNoBreaksCheck->SetValue(2);
if (!(better->mask & TF_UNDERLINE)) fTextUnderlineCheck->SetValue(2);
if (!(better->mask & TF_STRIKEOUT)) fTextStrikethroughCheck->SetValue(2);
if (!(better->mask & TF_BLINK)) fTextBlinkingCheck->SetValue(2);
if (better->mask & TF_FONT_SIZE)
fTextSizePopup->SetValue(better->iSize);
else
fTextSizePopup->SetValue(EDT_GetFontSize( fContext ));
fSizeChanged = FALSE;
if ( better->values & TF_FONT_FACE )
SetFontMenuItemByString( (LGAPopup *)mFontMenu, better->pFontFace );
else if ( better->values & TF_FIXED )
mFontMenu->SetValue( 2 );
else
mFontMenu->SetValue( 1 );
mFontChanged = false;
LO_Color pColor = {0, 0, 0};
if (better->mask & TF_FONT_COLOR) { // consistant
if (better->pColor) {
pColor = *better->pColor;
TurnOn( fColorCustomRadio );
} else {
TurnOn( fColorDefaultRadio );
EDT_PageData *pagedata = EDT_GetPageData( fContext );
if (pagedata && pagedata->pColorText)
pColor = *pagedata->pColorText;
EDT_FreePageData( pagedata );
}
} else { // inconsistant
if (EDT_GetFontColor(fContext, &pColor))
TurnOn( fColorCustomRadio );
else {
TurnOn( fColorDefaultRadio );
// get default color
EDT_PageData *pagedata = EDT_GetPageData( fContext );
pColor = *pagedata->pColorText;
EDT_FreePageData( pagedata );
}
}
fColorCustomColor->SetColor(UGraphics::MakeRGBColor(pColor));
fColorChanged = FALSE;
EDT_FreeCharacterData(better);
}
void CEDCharacterContain::Help()
{
ShowHelp( HELP_PROPS_CHARACTER );
}
void CEDCharacterContain::ListenToMessage( MessageT inMessage, void* /* ioParam */ )
{
//Intercept messages we should act on....
switch (inMessage)
{
case msg_Font_Face_Changed:
mFontChanged = true;
break;
case 'Supe':
if (fTextSuperscriptCheck->GetValue())
fTextSubscriptCheck->SetValue(0);
break;
case 'Subs':
if (fTextSubscriptCheck->GetValue())
fTextSuperscriptCheck->SetValue(0);
break;
case msg_Clear_Text_Styles:
fTextBoldCheck->SetValue(0);
fTextItalicCheck->SetValue(0);
fTextSuperscriptCheck->SetValue(0);
fTextSubscriptCheck->SetValue(0);
fTextNoBreaksCheck->SetValue(0);
fTextUnderlineCheck->SetValue(0);
fTextStrikethroughCheck->SetValue(0);
fTextBlinkingCheck->SetValue(0);
break;
case msg_Clear_All_Styles:
fTextBoldCheck->SetValue(0);
fTextItalicCheck->SetValue(0);
fTextSuperscriptCheck->SetValue(0);
fTextSubscriptCheck->SetValue(0);
fTextNoBreaksCheck->SetValue(0);
fTextUnderlineCheck->SetValue(0);
fTextStrikethroughCheck->SetValue(0);
fTextBlinkingCheck->SetValue(0);
if ( fTextSizePopup->GetValue() != 3 )
{
fSizeChanged = true;
fTextSizePopup->SetValue(3);
}
TurnOn( fColorDefaultRadio );
fColorChanged = TRUE;
if ( mFontMenu->GetValue() != 1 )
mFontChanged = true;
mFontMenu->SetValue( 1 );
break;
case msg_LinkColorChange:
fColorChanged = TRUE;
TurnOn( fColorCustomRadio );
break;
case msg_Default_Color_Radio:
fColorChanged = TRUE;
break;
case msg_Custom_Color_Radio:
fColorChanged = TRUE;
break;
case msg_Font_Size_Changed:
fSizeChanged = TRUE;
break;
}
// Pass all messages on...
}
/**********************************************************/
// There is no other good place for these. These correspond to menu item numbers which are
// in a resource (not a rez file)
#define ED_NO_CONTAINER 1
#define ED_LIST_ITEM 2
#define ED_BLOCKQUOTE 3
void CEDParagraphContain::FinishCreateSelf()
{
fParagraphStylePopup = (LControl*)FindPaneByID( 'pspu' );
fContainerStylePopup = (LControl*)FindPaneByID( 'cspu' );
fListStylePopup = (LControl*)FindPaneByID( 'lspu' );
fNumberPopup = (LControl*)FindPaneByID( 'nobp' );
fBulletPopup = (LControl*)FindPaneByID( 'bulp' );
fStartNumberCaption = (LControl*)FindPaneByID( 'junk' );
fStartNumberEditText = (LGAEditField*)FindPaneByID( 'snet' );
fLeftAlignRadio = (LControl*)FindPaneByID( 'Left' );
fCenterAlignRadio = (LControl*)FindPaneByID( 'Cent' );
fRightAlignRadio = (LControl*)FindPaneByID( 'Righ' );
LView::FinishCreateSelf();
UReanimator::LinkListenerToControls( this, this, mPaneID );
fParagraphStylePopup->Show();
fContainerStylePopup->Show();
fListStylePopup->Show();
fLeftAlignRadio->Show();
fCenterAlignRadio->Show();
fRightAlignRadio->Show();
}
void CEDParagraphContain::PrefsFromControls()
{
// This only differs from the Windows FE code in two ways:
// 1) EDT_MorphContainer is called BEFORE the EDT_Outdent "while" loop instead of AFTER
// 2) if fContainerStylePopup->GetValue() == ED_NO_CONTAINER we NEVER call EDT_SetListData(); the windows code DOES if list != NULL.
if (fLeftAlignRadio->GetValue())
EDT_SetParagraphAlign(fContext, ED_ALIGN_LEFT);
else if (fRightAlignRadio->GetValue())
EDT_SetParagraphAlign(fContext, ED_ALIGN_RIGHT);
else
EDT_SetParagraphAlign(fContext, ED_ALIGN_CENTER);
switch (fParagraphStylePopup->GetValue()) {
case 1: EDT_MorphContainer( fContext, P_PARAGRAPH); break;
case 2: EDT_MorphContainer( fContext, P_HEADER_1); break;
case 3: EDT_MorphContainer( fContext, P_HEADER_2); break;
case 4: EDT_MorphContainer( fContext, P_HEADER_3); break;
case 5: EDT_MorphContainer( fContext, P_HEADER_4); break;
case 6: EDT_MorphContainer( fContext, P_HEADER_5); break;
case 7: EDT_MorphContainer( fContext, P_HEADER_6); break;
case 8: EDT_MorphContainer( fContext, P_ADDRESS); break;
case 9: EDT_MorphContainer( fContext, P_PREFORMAT); break;
case 10: EDT_MorphContainer( fContext, P_LIST_ITEM); break;
case 11: EDT_MorphContainer( fContext, P_DESC_TITLE); break;
case 12: EDT_MorphContainer( fContext, P_DESC_TEXT); break;
}
if (fContainerStylePopup->GetValue() == ED_NO_CONTAINER)
{
EDT_ListData * pListData = EDT_GetListData(fContext); // remove
while (pListData) {
EDT_FreeListData(pListData);
EDT_Outdent(fContext);
pListData = EDT_GetListData(fContext);
}
}
else
{
EDT_ListData *list = EDT_GetListData( fContext );
if (list == NULL)
{ // do we need to create a container?
EDT_Indent( fContext );
list = EDT_GetListData( fContext );
if (list == NULL)
return; // assert?
}
list->eType = ED_LIST_TYPE_DEFAULT; // defaults
list->iStart = 1;
if (fContainerStylePopup->GetValue() == ED_BLOCKQUOTE)
list->iTagType = P_BLOCKQUOTE;
else
{
switch (fListStylePopup->GetValue()) {
case 1: list->iTagType = P_UNUM_LIST; break;
case 2: list->iTagType = P_NUM_LIST; break;
case 3: list->iTagType = P_DIRECTORY; break;
case 4: list->iTagType = P_MENU; break;
case 5: list->iTagType = P_DESC_LIST; break;
}
if (list->iTagType == P_UNUM_LIST) {
switch (fBulletPopup->GetValue()) {
case 1: list->eType = ED_LIST_TYPE_DEFAULT; break;
case 2: list->eType = ED_LIST_TYPE_DISC; break;
case 3: list->eType = ED_LIST_TYPE_CIRCLE; break;
case 4: list->eType = ED_LIST_TYPE_SQUARE; break;
}
} else if (list->iTagType == P_NUM_LIST) {
switch (fNumberPopup->GetValue()) {
case 1: list->eType = ED_LIST_TYPE_DEFAULT; break;
case 2: list->eType = ED_LIST_TYPE_DIGIT; break;
case 3: list->eType = ED_LIST_TYPE_BIG_ROMAN; break;
case 4: list->eType = ED_LIST_TYPE_SMALL_ROMAN; break;
case 5: list->eType = ED_LIST_TYPE_BIG_LETTERS; break;
case 6: list->eType = ED_LIST_TYPE_SMALL_LETTERS; break;
}
list->iStart = fStartNumberEditText->GetValue();
}
}
EDT_SetListData(fContext, list);
EDT_FreeListData(list);
}
}
// Initialize from preferences
void CEDParagraphContain::ControlsFromPref()
{
switch (EDT_GetParagraphAlign(fContext)) {
case ED_ALIGN_LEFT: TurnOn(fLeftAlignRadio); break;
case ED_ALIGN_RIGHT: TurnOn(fRightAlignRadio); break;
default: TurnOn(fCenterAlignRadio); break;
}
fParagraphStylePopup->SetValue(1);
switch (EDT_GetParagraphFormatting(fContext)) {
case P_HEADER_1: fParagraphStylePopup->SetValue(2); break;
case P_HEADER_2: fParagraphStylePopup->SetValue(3); break;
case P_HEADER_3: fParagraphStylePopup->SetValue(4); break;
case P_HEADER_4: fParagraphStylePopup->SetValue(5); break;
case P_HEADER_5: fParagraphStylePopup->SetValue(6); break;
case P_HEADER_6: fParagraphStylePopup->SetValue(7); break;
case P_ADDRESS: fParagraphStylePopup->SetValue(8); break;
case P_PREFORMAT: fParagraphStylePopup->SetValue(9); break;
case P_LIST_ITEM: fParagraphStylePopup->SetValue(10); break;
case P_DESC_TITLE: fParagraphStylePopup->SetValue(11); break;
case P_DESC_TEXT: fParagraphStylePopup->SetValue(12); break;
}
EDT_ListData *list = EDT_GetListData( fContext );
fContainerStylePopup->SetValue(ED_NO_CONTAINER);
if (list) {
if (list->iTagType == P_BLOCKQUOTE)
fContainerStylePopup->SetValue(ED_BLOCKQUOTE);
else
fContainerStylePopup->SetValue(ED_LIST_ITEM); // list item
}
fListStylePopup->SetValue(1); // set up default values
fBulletPopup->SetValue(1);
fNumberPopup->SetValue(1);
fStartNumberEditText->SetValue(1);
if (fContainerStylePopup->GetValue() == ED_LIST_ITEM) { // list item
switch (list->iTagType) {
case P_UNUM_LIST: fListStylePopup->SetValue(1); break;
case P_NUM_LIST: fListStylePopup->SetValue(2); break;
case P_DIRECTORY: fListStylePopup->SetValue(3); break;
case P_MENU: fListStylePopup->SetValue(4); break;
case P_DESC_LIST: fListStylePopup->SetValue(5); break;
default: fListStylePopup->SetValue(1); break; // assert?
}
if (list->iTagType == P_UNUM_LIST) {
switch (list->eType) {
case ED_LIST_TYPE_DEFAULT: fBulletPopup->SetValue(1); break;
case ED_LIST_TYPE_DISC: fBulletPopup->SetValue(2); break;
case ED_LIST_TYPE_CIRCLE: fBulletPopup->SetValue(3); break;
case ED_LIST_TYPE_SQUARE: fBulletPopup->SetValue(4); break;
default: fBulletPopup->SetValue(1); break; // assert?
}
}
if (list->iTagType == P_NUM_LIST) {
switch (list->eType) {
case ED_LIST_TYPE_DEFAULT: fNumberPopup->SetValue(1); break;
case ED_LIST_TYPE_DIGIT: fNumberPopup->SetValue(2); break;
case ED_LIST_TYPE_BIG_ROMAN: fNumberPopup->SetValue(3); break;
case ED_LIST_TYPE_SMALL_ROMAN: fNumberPopup->SetValue(4); break;
case ED_LIST_TYPE_BIG_LETTERS: fNumberPopup->SetValue(5); break;
case ED_LIST_TYPE_SMALL_LETTERS: fNumberPopup->SetValue(6); break;
default: fNumberPopup->SetValue(1); break; // assert?
}
fStartNumberEditText->SetValue(list->iStart);
}
}
if (list) EDT_FreeListData(list);
AdjustPopupsVisibility();
}
void CEDParagraphContain::AdjustPopupsVisibility()
{
if (fContainerStylePopup->GetValue() != ED_LIST_ITEM) { // list item
fListStylePopup->Disable();
fStartNumberCaption->Hide();
fStartNumberEditText->Hide();
switch (fListStylePopup->GetValue()) {
case 1: // Unumbered List
fNumberPopup->Hide();
fBulletPopup->Disable();
fBulletPopup->Show();
break;
case 2: // Numbered List
fNumberPopup->Disable();
fNumberPopup->Show();
fBulletPopup->Hide();
break;
default:
fNumberPopup->Hide();
fBulletPopup->Hide();
break;
}
} else {
fListStylePopup->Enable();
switch (fListStylePopup->GetValue()) {
case 1: // Unnumbered List
fNumberPopup->Hide();
fBulletPopup->Enable();
fBulletPopup->Show();
fStartNumberCaption->Hide();
fStartNumberEditText->Hide();
break;
case 2: // Numbered List
fNumberPopup->Enable();
fNumberPopup->Show();
fBulletPopup->Hide();
fStartNumberCaption->Show();
fStartNumberEditText->Show();
break;
default:
fNumberPopup->Hide();
fBulletPopup->Hide();
fStartNumberCaption->Hide();
fStartNumberEditText->Hide();
break;
}
}
}
void CEDParagraphContain::Help()
{
ShowHelp( HELP_PROPS_PARAGRAPH );
}
Boolean CEDParagraphContain::AllFieldsOK()
{
if ( fStartNumberEditText->IsVisible() && fStartNumberEditText->IsEnabled()
&& !IsEditFieldWithinLimits( fStartNumberEditText, 1, 2000000000 ) )
{
SwitchTarget( fStartNumberEditText );
fStartNumberEditText->SelectAll();
return FALSE;
}
return true;
}
void CEDParagraphContain::ListenToMessage( MessageT inMessage, void* /* ioParam */ )
{
//Intercept messages we should act on....
switch (inMessage) {
case msg_Paragraph_Style_Popup:
if (fParagraphStylePopup->GetValue() == 10) // "List item" menu item
fContainerStylePopup->SetValue(ED_LIST_ITEM); // "List" menu item (doesn't seem to be necessary)
else if (fContainerStylePopup->GetValue() == ED_LIST_ITEM)
fContainerStylePopup->SetValue(ED_NO_CONTAINER); // (IS necessary)
AdjustPopupsVisibility();
break;
case msg_Paragraph_Addtnl_Style_Popup:
if (fContainerStylePopup->GetValue() == ED_LIST_ITEM) // "List" menu item
fParagraphStylePopup->SetValue(10); // "List item" menu item
// else if (fParagraphStylePopup->GetValue() == 10)
// fParagraphStylePopup->SetValue(1); // windows FE doesn't do this. Do we know what we're doing?
AdjustPopupsVisibility();
break;
case msg_List_Style_Popup:
AdjustPopupsVisibility();
break;
}
// Pass all messages on...
}
/**********************************************************/
void CEDLinkContain::FinishCreateSelf()
{
fLinkedTextEdit = (CLargeEditField *)FindPaneByID( 'LTte' );
fChooseFileLinkButton = (LControl*)FindPaneByID( 'CFLb' );
fRemoveLinkButton = (LControl*)FindPaneByID( 'RLbt' );
fLinkPageTextEdit = (CLargeEditField *)FindPaneByID( 'LPte' );
fCurrentDocumentRadio = (LControl*)FindPaneByID( 'CDro' );
fSelectedFileRadio = (LControl*)FindPaneByID( 'SFro' );
fTargetList = (OneRowLListBox*)FindPaneByID( 'TAli' );
LView::FinishCreateSelf();
UReanimator::LinkListenerToControls( this, this, mPaneID );
fTargs = NULL;
}
void CEDLinkContain::PrefsFromControls()
{
if (fInsert && LO_GetSelectionText(fContext) == NULL)
{
char *link = fLinkPageTextEdit->GetLongDescriptor();
if (link && XP_STRLEN(link))
{
char *anchor = fLinkedTextEdit->GetLongDescriptor();
if ( anchor && XP_STRLEN(anchor) )
{
if ( EDT_PasteHREF( fContext, &link, &anchor, 1 ) != EDT_COP_OK )
ErrorManager::PlainAlert( CUT_ACROSS_CELLS );
}
else if ( EDT_PasteHREF( fContext, &link, &link, 1 ) != EDT_COP_OK )
{
// use the link as the anchor if there is no anchor
ErrorManager::PlainAlert( CUT_ACROSS_CELLS );
}
XP_FREEIF( anchor);
}
XP_FREEIF( link );
}
else // if ( EDT_CanSetHREF( fContext ) ) // should always be true
{
EDT_HREFData *linkdata = EDT_GetHREFData( fContext );
if ( linkdata )
{
if ( linkdata->pURL )
{
XP_FREE( linkdata->pURL );
linkdata->pURL = NULL;
}
linkdata->pURL = fLinkPageTextEdit->GetLongDescriptor();
if ( linkdata->pExtra )
{
XP_FREE( linkdata->pExtra );
linkdata->pExtra = NULL;
}
if ( pExtra )
linkdata->pExtra = XP_STRDUP( pExtra );
EDT_SetHREFData( fContext, linkdata );
EDT_FreeHREFData( linkdata );
}
}
}
void CEDLinkContain::Show()
{
if ( *fLinkName )
fLinkedTextEdit->SetDescriptor( CStr255(*fLinkName) );
CEditContain::Show();
}
void CEDLinkContain::Hide()
{
if ( *fLinkName )
XP_FREE( *fLinkName );
*fLinkName = fLinkedTextEdit->GetLongDescriptor();
CEditContain::Hide();
}
#define msg_ClickOnTarget 23000
#define msg_DblClickOnTarget 23001
#define msg_ClickOnTarget2 23002 /* really should put these in resgui.h or similar */
#define msg_DblClickOnTarget2 23003
// Initialize from preferences
void CEDLinkContain::ControlsFromPref()
{
SetTextTraitsIDByCsid(fLinkedTextEdit, GetWinCSID());
if ( *fLinkName )
{ // image pane has already been here
fLinkedTextEdit->SetDescriptor( CStr255(*fLinkName) );
fLinkedTextEdit->Disable();
SwitchTarget( fLinkPageTextEdit );
fLinkPageTextEdit->SelectAll();
}
else
{
char *selection = (char*)LO_GetSelectionText( fContext );
if ( selection )
fLinkedTextEdit->SetDescriptor( CtoPstr(selection) );
if ( fInsert && selection == NULL )
{
fLinkedTextEdit->Enable();
SwitchTarget( fLinkedTextEdit );
fLinkedTextEdit->SelectAll();
}
else
{
fLinkedTextEdit->Disable();
SwitchTarget( fLinkPageTextEdit );
fLinkPageTextEdit->SelectAll();
}
XP_FREEIF( selection );
}
EDT_HREFData *linkdata = EDT_GetHREFData( fContext );
if ( linkdata )
{
if ( linkdata->pURL )
fLinkPageTextEdit->SetDescriptor( CtoPstr(linkdata->pURL) );
pExtra = linkdata->pExtra; // let's not realloc
linkdata->pExtra = NULL; // don't dispose of this!
EDT_FreeHREFData( linkdata );
}
TurnOn( fCurrentDocumentRadio );
CurrentFileTargs();
fTargetList->FocusDraw();
fTargetList->SetDoubleClickMessage( msg_DblClickOnTarget );
fTargetList->SetSingleClickMessage( msg_ClickOnTarget );
fTargetList->AddListener( this );
fTargetList->SetValue(-1);
}
CEDLinkContain::~CEDLinkContain()
{
if ( fTargs )
XP_FREE( fTargs );
if ( pExtra )
XP_FREE( pExtra );
pExtra = NULL;
}
void CEDLinkContain::Help()
{
ShowHelp( HELP_PROPS_LINK );
}
void CEDLinkContain::SelectedFileUpdate()
{
// clear list
while ( fTargetList->GetRows() )
fTargetList->RemoveRow(0);
if ( fTargs )
XP_FREE(fTargs);
fTargs = NULL;
// get file to retrieve targets from
char *link = fLinkPageTextEdit->GetLongDescriptor();
if ( link == NULL )
return;
// I assume a pound would only confuse things; remove it if present
char *pound = XP_STRCHR(link, '#');
if ( pound )
*pound = '\0';
// need to pass an xpURL format "link" below ***FIX***THIS***
fTargs = EDT_GetAllDocumentTargetsInFile( fContext, link );
XP_FREE( link );
char *parse = fTargs;
int16 rowNum = fTargetList->GetRows(); // add to the bottom?
while ( parse && *parse )
{
fTargetList->AddRow( rowNum++, parse, XP_STRLEN(parse) );
parse += XP_STRLEN(parse) + 1;
}
}
void CEDLinkContain::CurrentFileTargs()
{
while (fTargetList->GetRows())
fTargetList->RemoveRow(0);
if ( fTargs )
XP_FREE( fTargs );
fTargs = EDT_GetAllDocumentTargets(fContext);
char *parse = fTargs;
int16 rowNum = fTargetList->GetRows(); // add to the bottom?
while (parse && *parse)
{
fTargetList->AddRow( rowNum++, parse, XP_STRLEN(parse));
parse += XP_STRLEN(parse) + 1;
}
}
void CEDLinkContain::ListenToMessage( MessageT inMessage, void* /* ioParam */ )
{
//Intercept messages we should act on....
switch (inMessage)
{
case 'CDro': // targets from current document radio button
if ( fCurrentDocumentRadio->GetValue() )
CurrentFileTargs();
break;
case 'SFro': // targets from selected file radio button
if ( fSelectedFileRadio->GetValue() )
SelectedFileUpdate();
break;
case msg_Link_Clear_Link:
fLinkPageTextEdit->SetDescriptor("\p");
break;
case msg_Link_Browse_File:
{
StPrepareForDialog preparer;
StandardFileReply reply;
Point loc = { -1, -1 };
OSType types[ 4 ];
types[ 0 ] = 'GIFf';
types[ 1 ] = 'TEXT';
types[ 2 ] = 'JPEG';
::StandardGetFile( NULL, 3, types, &reply );
if ( reply.sfGood )
{
char *fileLink = CFileMgr::GetURLFromFileSpec( reply.sfFile );
if ( fileLink )
{
if (CPrefs::GetBoolean( CPrefs::PublishMaintainLinks ))
{
char *abs = NULL; // let's try making it relative
if (NET_MakeRelativeURL( LO_GetBaseURL( fContext ), fileLink, &abs) != NET_URL_FAIL && abs)
{
XP_FREE( fileLink );
fileLink = abs;
abs = NULL;
}
XP_FREEIF( abs );
}
fLinkPageTextEdit->SetLongDescriptor( fileLink );
XP_FREE( fileLink );
if ( fSelectedFileRadio->GetValue() )
SelectedFileUpdate();
}
}
}
break;
case msg_DblClickOnTarget:
case msg_ClickOnTarget:
int16 index = fTargetList->GetValue();
// first take care of the case where the user tries to "deselect" the item in the list..
if (index == -1)
{
char *file = fLinkPageTextEdit->GetLongDescriptor(); // we are going to save the url if it exists
if ( file )
{
char *pound = XP_STRCHR( file, '#' );
if ( pound )
{
*pound = '\0';
fLinkPageTextEdit->SetLongDescriptor( file );
}
XP_FREE( file );
}
break;
}
char *parse = fTargs;
while ( parse && *parse && index-- )
parse += XP_STRLEN(parse) + 1;
if ( parse && *parse )
{ // why is it that I have no other way to do this?
CStr255 temp = "";
if (fSelectedFileRadio->GetValue())
{
char *file2 = fLinkPageTextEdit->GetLongDescriptor(); // we are going to save the url if it exists
if ( file2 )
{
char *pound = XP_STRCHR(file2, '#');
if ( pound )
*pound = '\0';
temp = file2;
XP_FREE( file2 );
}
}
temp += '#';
temp += parse;
fLinkPageTextEdit->SetDescriptor(temp);
}
if ( inMessage == msg_DblClickOnTarget )
ListenToMessage( msg_OK, NULL );
break;
case 'Xtra':
char * newExtraHTML = NULL;
Boolean canceled = !GetExtraHTML( pExtra, &newExtraHTML, GetWinCSID() );
if (!canceled)
{
XP_FREEIF( pExtra );
pExtra = newExtraHTML;
}
break;
}
// Pass all messages on...
}
#ifdef COOL_IMAGE_RADIO_BUTTONS
#pragma mark -
// ---------------------------------------------------------------------------
// <09> SetValue
// ---------------------------------------------------------------------------
// Turn a ToggleButton on or off
void
CImageAlignButton::SetValue( Int32 inValue )
{
if (inValue != mValue)
{
LControl::SetValue(inValue);
Refresh();
}
// If turning RadioButton on, broadcast message so that the RadioGroup
// (if present) will turn off the other RadioButtons in the group.
if (inValue == Button_On)
BroadcastMessage( msg_ControlClicked, (void*) this );
}
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
// <09> HotSpotAction
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
void CImageAlignButton::HotSpotAction(short /* inHotSpot */, Boolean inCurrInside, Boolean inPrevInside)
{
if ( GetValue() == 0 )
{
if ( inCurrInside != inPrevInside )
{
SetTrackInside( inCurrInside );
Draw( NULL );
SetTrackInside( false );
}
}
}
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
// <09> HotSpotResult
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
void CImageAlignButton::HotSpotResult(Int16 inHotSpot)
{
SetValue(1);
// Although value doesn't change, send message to inform Listeners
// that button was clicked
// BroadcastValueMessage();
}
#endif
/**********************************************************/
CEDImageContain::CEDImageContain( LStream* inStream ) : CEditContain( inStream )
{
fSrcStr = NULL;
fLowSrcStr = NULL;
fLooseImageMap = FALSE;
mBorderUnspecified = false;
}
CEDImageContain::~CEDImageContain()
{
XP_FREEIF( fSrcStr );
XP_FREEIF( fLowSrcStr );
XP_FREEIF( pExtra );
pExtra = NULL;
}
void CEDImageContain::FinishCreateSelf()
{
fImageFileName = (CLargeEditField *)FindPaneByID( 'WST1' );
fImageFileName->AddListener(this);
fImageAltTextEdit = (CLargeEditField *)FindPaneByID( 'WST5' );
fImageAltTextEdit->AddListener(this);
fHeightTextEdit = (LGAEditField*)FindPaneByID( 'WSTd' );
fHeightTextEdit->AddListener( this );
fWidthTextEdit = (LGAEditField*)FindPaneByID( 'WSTf' );
fWidthTextEdit->AddListener( this );
fImageLockedCheckBox = (LControl *)FindPaneByID( 'Lock' ); // constrain
fLeftRightBorderTextEdit = (LGAEditField*)FindPaneByID( 'WSTh' );
fTopBottomBorderTextEdit = (LGAEditField*)FindPaneByID( 'WSTi' );
fSolidBorderTextEdit = (LGAEditField*)FindPaneByID( 'WSTj' );
fSolidBorderTextEdit->AddListener( this );
fCopyImageCheck = (LControl*)FindPaneByID( 'WSTl' );
fBackgroundImageCheck = (LControl*)FindPaneByID( 'Bkgd' );
fRemoveImageMapButton = (LControl*)FindPaneByID( 'WSTm' );
fEditImageButton = (LControl*)FindPaneByID( 'WSTn' );
mImageAlignmentPopup = (LControl*)FindPaneByID( 'ImgA' );
LView::FinishCreateSelf();
UReanimator::LinkListenerToControls( this, this, mPaneID );
}
void CEDImageContain::AdjustEnable()
{
Boolean allEmpty = false; // assume at least one has text unless proven otherwise
Str255 str;
LGACaption* textCaption = (LGACaption*)FindPaneByID( 'text' );
fImageFileName->GetDescriptor( str );
if ( str[0] == 0 )
{
fCopyImageCheck->Disable();
fEditImageButton->Disable();
fBackgroundImageCheck->Disable();
// SetOkButtonState (false);
textCaption->Deactivate();
fImageAltTextEdit->Disable();
allEmpty = true;
}
else
{
fCopyImageCheck->Enable();
fEditImageButton->Enable();
fBackgroundImageCheck->Enable();
// SetOkButtonState (true);
textCaption->Activate();
fImageAltTextEdit->Enable();
}
LView* dimensions = (LView *)FindPaneByID( 'C003' );
LView* spacearound = (LView *)FindPaneByID( 'C004' );
LView* aligncaption = (LView *)FindPaneByID( 'Cptn' ); // alignment caption
LView* extrahtmlbutton = (LView *)FindPaneByID( 'Xtra' );
if ( allEmpty || fBackgroundImageCheck->GetValue() )
{
dimensions->Disable();
spacearound->Disable();
extrahtmlbutton->Disable();
mImageAlignmentPopup->Disable();
if ( aligncaption )
aligncaption->Disable();
}
else
{
dimensions->Enable();
spacearound->Enable();
extrahtmlbutton->Enable();
mImageAlignmentPopup->Enable();
if ( aligncaption )
aligncaption->Enable();
// can't constrain if it's original size or if either/both are "% of window"
Boolean doEnable = false;
LControl *control = (LControl *)FindPaneByID( 'Orig' );
if ( control && ( control->GetValue() == 0 ) )
{
LGAPopup *widthPopup = (LGAPopup *)FindPaneByID( 'WdPU' );
LGAPopup *heightPopup = (LGAPopup *)FindPaneByID( 'HtPU' );
doEnable = ( widthPopup->GetValue() != kPercentOfWindowItem )
&& ( heightPopup->GetValue() != kPercentOfWindowItem );
}
if ( doEnable )
fImageLockedCheckBox->Enable();
else
fImageLockedCheckBox->Disable();
}
}
EDT_ImageData *CEDImageContain::ImageDataFromControls()
{
EDT_ImageData *image;
if (fInsert)
image = EDT_NewImageData();
else
{
if ( EDT_GetCurrentElementType(fContext) != ED_ELEMENT_IMAGE )
return NULL;
image = EDT_GetImageData( fContext );
}
if (image == NULL)
return NULL;
// what about ED_ALIGN_BOTTOM & ED_ALIGN_ABSTOP
image->align = ED_ALIGN_DEFAULT;
switch (mImageAlignmentPopup->GetValue())
{
case 1: image->align = ED_ALIGN_TOP; break;
case 2: image->align = ED_ALIGN_ABSCENTER; break;
case 3: image->align = ED_ALIGN_CENTER; break;
case 4: image->align = ED_ALIGN_BASELINE; break;
case 5: image->align = ED_ALIGN_ABSBOTTOM; break;
case 6: image->align = ED_ALIGN_LEFT; break;
case 7: image->align = ED_ALIGN_RIGHT; break;
}
image->bNoSave = fCopyImageCheck->GetValue();
XP_FREEIF( image->pSrc );
image->pSrc = fImageFileName->GetLongDescriptor();
XP_FREEIF( image->pAlt );
image->pAlt = fImageAltTextEdit->GetLongDescriptor();
XP_FREEIF( image->pExtra );
image->pExtra = ( pExtra ) ? XP_STRDUP( pExtra ) : NULL;
// we need a valid URL for this image (for instance, something that starts with 'file://'
/* char *absURL;
if (image->pSrc && (absURL = NET_MakeAbsoluteURL( LO_GetBaseURL( fContext ), image->pSrc ))) {
XP_FREE(image->pSrc);
image->pSrc = absURL;
}
if (image->pLowSrc && (absURL = NET_MakeAbsoluteURL( LO_GetBaseURL( fContext ), image->pLowSrc ))) {
XP_FREE(image->pLowSrc);
image->pLowSrc = absURL;
}
FSSpec file;
char *path;
file = fImageFileName->GetFSSpec();
if (file.vRefNum != 0 || file.parID != 0 || file.name[0] != 0) {
char *path = CFileMgr::GetURLFromFileSpec(file);
if (path) {
if (fSrcStr == NULL || strcmp(path, fSrcStr)) {
if (image->pSrc) XP_FREE(image->pSrc);
image->pSrc = path;
} else XP_FREE(path);
}
}
file = fImageAltFileName->GetFSSpec();
if (file.vRefNum != 0 || file.parID != 0 || file.name[0] != 0) {
char *path = CFileMgr::GetURLFromFileSpec(file);
if (path) {
if (fLowSrcStr == NULL || strcmp(path, fLowSrcStr)) {
if (image->pLowSrc) XP_FREE(image->pLowSrc);
image->pLowSrc = path;
} else XP_FREE(path);
}
}
*/
LControl *useCustomSize = (LControl*)FindPaneByID( 'Cust' );
if ( useCustomSize->GetValue() )
{
LGAPopup *popup = (LGAPopup *)FindPaneByID( 'HtPU' );
image->bHeightPercent = (popup ? popup->GetValue() == kPercentOfWindowItem : false);
image->iHeight = fHeightTextEdit->GetValue();
popup = (LGAPopup *)FindPaneByID( 'WdPU' );
image->bWidthPercent = (popup ? popup->GetValue() == kPercentOfWindowItem : false);
image->iWidth = fWidthTextEdit->GetValue();
}
else
{
image->iWidth = 0;
image->iHeight = 0;
image->bWidthPercent = false;
image->bHeightPercent = false;
}
image->iHSpace = fLeftRightBorderTextEdit->GetValue();
image->iVSpace = fTopBottomBorderTextEdit->GetValue();
if ( mBorderUnspecified )
image->iBorder = -1;
else
image->iBorder = fSolidBorderTextEdit->GetValue();
// Mac "remove image map" button now removes ISMAP instead of USEMAP
// Stupid behavior, but that's what Win and UNIX do.
if ( fLooseImageMap && image->bIsMap )
{
image->bIsMap = false;
}
return image;
}
void CEDImageContain::PrefsFromControls()
{
// if background image--do it and return
if ( fBackgroundImageCheck->GetValue() )
{
EDT_PageData *pageData = EDT_GetPageData( fContext );
if (pageData == NULL)
return;
if (pageData->pBackgroundImage)
{
XP_FREE( pageData->pBackgroundImage );
pageData->pBackgroundImage = NULL;
}
char *url = fImageFileName->GetLongDescriptor();
if ( url && XP_STRLEN( url ) )
pageData->pBackgroundImage = url;
else if ( url )
XP_FREE( url );
EDT_SetPageData(fContext, pageData);
EDT_FreePageData(pageData);
return;
}
EDT_ImageData *image = ImageDataFromControls();
if (image)
{
if (fInsert)
EDT_InsertImage( fContext, image, fCopyImageCheck->GetValue() );
else
EDT_SetImageData( fContext, image, fCopyImageCheck->GetValue() );
EDT_FreeImageData(image);
}
}
// Initialize from preferences
void CEDImageContain::ControlsFromPref()
{
SetTextTraitsIDByCsid(fImageAltTextEdit, GetWinCSID());
fCopyImageCheck->Enable();
fCopyImageCheck->SetValue( false );
fOriginalWidth = 0;
fOriginalHeight = 0;
fEditImageButton->Disable();
Boolean amInsertingNewImage = ( EDT_GetCurrentElementType(fContext) != ED_ELEMENT_IMAGE );
EDT_ImageData *image = ( amInsertingNewImage ) ? NULL : EDT_GetImageData( fContext );
// set alignment
int value = 4; // default == ED_ALIGN_BASELINE
if ( image )
{
switch (image->align)
{ // what about ED_ALIGN_BOTTOM & ED_ALIGN_ABSTOP
case ED_ALIGN_TOP: value = 1; break;
case ED_ALIGN_ABSCENTER: value = 2; break;
case ED_ALIGN_CENTER: value = 3; break;
case ED_ALIGN_BASELINE: value = 4; break;
case ED_ALIGN_ABSBOTTOM: value = 5; break;
case ED_ALIGN_LEFT: value = 6; break;
case ED_ALIGN_RIGHT: value = 7; break;
default: break;
}
}
mImageAlignmentPopup->SetValue( value );
if ( image )
{
fCopyImageCheck->SetValue( image->bNoSave );
if (image->pSrc)
fImageFileName->SetLongDescriptor( image->pSrc );
if ( image->pAlt )
fImageAltTextEdit->SetLongDescriptor( image->pAlt );
LControl *customSize = (LControl *)FindPaneByID( 'Cust' );
if ( image->iOriginalWidth == 0 )
{
// we know for sure we have custom if either h or w is %
customSize->SetValue( image->bHeightPercent || image->bWidthPercent );
fOriginalWidth = image->iWidth;
fOriginalHeight = image->iHeight;
}
else
{
if ( image->iWidth == 0 && image->iHeight == 0 )
{
image->iHeight = image->iOriginalHeight;
image->iWidth = image->iOriginalWidth;
}
customSize->SetValue( image->iOriginalWidth != image->iWidth
|| image->iOriginalHeight != image->iHeight);
fOriginalWidth = image->iOriginalWidth; /* Width and Height we got on initial loading */
fOriginalHeight = image->iOriginalHeight;
}
fHeightTextEdit->SetValue(image->iHeight);
fWidthTextEdit->SetValue(image->iWidth);
fLeftRightBorderTextEdit->SetValue(image->iHSpace);
fTopBottomBorderTextEdit->SetValue(image->iVSpace);
// This is weird. If the cross platform code gives us a -1, then we are "default"
// "default" is zero if there is no link or two if there is.
// why doesn't the XP set this up for us? I don't know...
if (image->iBorder == -1)
{
mBorderUnspecified = true;
image->iBorder = EDT_GetDefaultBorderWidth( fContext );
}
else
mBorderUnspecified = false;
fSolidBorderTextEdit->SetValue( image->iBorder );
pExtra = image->pExtra; // let's not realloc
image->pExtra = NULL; // don't dispose of this!
}
// assume "Original Size" radio button is default
LGAPopup *popup = (LGAPopup *)FindPaneByID( 'HtPU' );
if ( popup )
popup->SetValue( image && image->bHeightPercent ? kPercentOfWindowItem : kPixelsItem );
popup = (LGAPopup *)FindPaneByID( 'WdPU' );
if ( popup )
popup->SetValue( image && image->bWidthPercent ? kPercentOfWindowItem : kPixelsItem );
// edit image logic
if (image == NULL || (image->pSrc == NULL || XP_STRLEN(image->pSrc) < 1))
fEditImageButton->Disable();
else
fEditImageButton->Enable();
// image map button
if ( image == NULL )
fRemoveImageMapButton->Disable();
else
{
// we already have image in document; don't copy to background
fBackgroundImageCheck->Hide();
if ( image->bIsMap )
fRemoveImageMapButton->Enable();
else
fRemoveImageMapButton->Disable();
}
if ( image )
EDT_FreeImageData(image);
// select the editField for the main image file name
SwitchTarget( fImageFileName );
fImageFileName->SelectAll();
AdjustEnable();
}
void CEDImageContain::Show()
{
if (*fLinkName)
fImageFileName->SetLongDescriptor( *fLinkName );
CEditContain::Show();
}
void CEDImageContain::Hide()
{
if ( *fLinkName )
XP_FREE( *fLinkName );
*fLinkName = fImageFileName->GetLongDescriptor();
/* FSSpec file;
file = fImageFileName->GetFSSpec();
if (file.vRefNum != 0 || file.parID != 0 || file.name[0] != 0) {
*fLinkName = CFileMgr::GetURLFromFileSpec(file);
if (*fLinkName) {
char *temp = FE_URLToLocalName(NET_UnEscape(*fLinkName));
if (temp) {
XP_FREE(*fLinkName);
*fLinkName = temp;
}
}
} else {
*fLinkName = (char *)XP_ALLOC(sizeof(char)*2); // just fill with some filler so the link pane won't mess with us!
if (*fLinkName) XP_STRCPY(*fLinkName, "-");
}
*/
CEditContain::Hide();
}
void CEDImageContain::Help()
{
ShowHelp( HELP_PROPS_IMAGE );
}
Boolean CEDImageContain::AllFieldsOK()
{
Str255 str;
fImageFileName->GetDescriptor( str );
if ( str[0] == 0 )
{
SwitchTarget( fImageFileName );
return false;
}
// if it's a background image we're done!
if ( fBackgroundImageCheck->GetValue() )
return true;
LControl *customSize = (LControl *)FindPaneByID( 'Cust' );
if ( customSize->GetValue() )
{
LGAPopup *popup = (LGAPopup *)FindPaneByID( 'HtPU' );
if ( popup && popup->GetValue() == kPercentOfWindowItem )
{
if ( !IsEditFieldWithinLimits( fHeightTextEdit, 1, 100 ) )
{
SwitchTarget( fHeightTextEdit );
fHeightTextEdit->SelectAll();
return FALSE;
}
}
else
{
if ( !IsEditFieldWithinLimits( fHeightTextEdit, 1, 10000 ) )
{
SwitchTarget( fHeightTextEdit );
fHeightTextEdit->SelectAll();
return FALSE;
}
}
popup = (LGAPopup *)FindPaneByID( 'WdPU' );
if ( popup && popup->GetValue() == kPercentOfWindowItem )
{
if ( !IsEditFieldWithinLimits( fWidthTextEdit, 1, 100 ) )
{
SwitchTarget( fWidthTextEdit );
fWidthTextEdit->SelectAll();
return FALSE;
}
}
else
{
if ( !IsEditFieldWithinLimits( fWidthTextEdit, 1, 10000 ) )
{
SwitchTarget( fWidthTextEdit );
fWidthTextEdit->SelectAll();
return FALSE;
}
}
}
if ( !IsEditFieldWithinLimits( fLeftRightBorderTextEdit, 0, 10000 ) )
{
SwitchTarget( fLeftRightBorderTextEdit );
fLeftRightBorderTextEdit->SelectAll();
return FALSE;
}
if ( !IsEditFieldWithinLimits( fTopBottomBorderTextEdit, 0, 10000 ) )
{
SwitchTarget( fTopBottomBorderTextEdit );
fTopBottomBorderTextEdit->SelectAll();
return FALSE;
}
if ( !IsEditFieldWithinLimits( fSolidBorderTextEdit, 0, 10000 ) )
{
SwitchTarget( fSolidBorderTextEdit );
fSolidBorderTextEdit->SelectAll();
return FALSE;
}
return TRUE;
}
void CEDImageContain::ListenToMessage( MessageT inMessage, void* ioParam )
{
switch (inMessage)
{
case 'HtPU':
case 'WdPU':
// set radio button to custom size (not original anymore)
LControl *customSize = (LControl *)FindPaneByID( 'Cust' );
if ( customSize && customSize->GetValue() == 0 )
customSize->SetValue( true );
// continue below
case 'Calc':
AdjustEnable();
break;
case 'WSTk': // Original Size Button
LControl *origSizeButton = (LControl *)FindPaneByID( 'Orig' );
if ( origSizeButton->GetValue() )
{
fHeightTextEdit->SetValue(fOriginalHeight); // these are not set by the XP yet, apparently.
fWidthTextEdit->SetValue(fOriginalWidth);
}
AdjustEnable();
break;
case 'WSTm': // Remove Image Map Button
fLooseImageMap = TRUE;
fRemoveImageMapButton->Disable();
break;
case msg_EditField2:
if ( ioParam == NULL )
return;
if ( ioParam == fHeightTextEdit || ioParam == fWidthTextEdit )
{
LControl *customSize = (LControl *)FindPaneByID( 'Cust' );
if ( customSize && customSize->GetValue() == 0 )
customSize->SetValue( true );
// don't divide by 0!
if ( fOriginalWidth == 0 || fOriginalHeight == 0 )
return;
if ( fImageLockedCheckBox->IsEnabled() && fImageLockedCheckBox->GetValue() )
{
int h, w;
if ( ioParam == fHeightTextEdit )
{
h = fHeightTextEdit->GetValue();
w = h * fOriginalWidth / fOriginalHeight;
fWidthTextEdit->SetValue( w );
}
else
{
w = fWidthTextEdit->GetValue();
h = w * fOriginalHeight / fOriginalWidth;
fHeightTextEdit->SetValue( h );
}
}
}
else
AdjustEnable(); // typing in a different edit field; adjust controls appropriately
break;
case 'wst1': // "Choose File..." image
CEditDialog::ChooseImageFile(fImageFileName);
AdjustEnable();
break;
case 'WSTn': // Edit Image Button
char *imageURL = fImageFileName->GetLongDescriptor();
if ( imageURL && XP_STRLEN(imageURL) < 1 )
{
XP_FREE( imageURL );
imageURL = NULL;
}
if ( imageURL == NULL )
break;
char *absURL = NET_MakeAbsoluteURL( LO_GetBaseURL( fContext ), imageURL );
XP_FREE(imageURL);
Boolean isImageLocal = false;
if (absURL && XP_STRSTR(absURL, "file://") == absURL)
{
FSSpec theImage;
if (CFileMgr::FSSpecFromLocalUnixPath(absURL + XP_STRLEN("file://"), &theImage, FALSE) == noErr)
{ // Skip file://
isImageLocal = true;
// Get the FSSpec for the editor
FSSpec theApplication;
XP_Bool hasEditor = false;
PREF_GetBoolPref( "editor.use_image_editor", &hasEditor );
if ( hasEditor )
theApplication = CPrefs::GetFolderSpec(CPrefs::ImageEditor);
// Oops, the user has not picked an app in the preferences yet.
if ( !hasEditor || (theApplication.vRefNum == -1 && theApplication.parID == -1 ) )
{
ErrorManager::PlainAlert( NO_IMG_EDITOR_PREF_SET );
CPrefsDialog::EditPrefs( CPrefsDialog::eExpandEditor,
PrefPaneID::eEditor_Main, CPrefsDialog::eIgnore);
}
else if ( StartDocInApp(theImage, theApplication) == noErr )
;
}
}
if ( !isImageLocal )
ErrorManager::PlainAlert( EDITOR_ERROR_EDIT_REMOTE_IMAGE );
XP_FREEIF(absURL);
break;
case 'WSTj':
mBorderUnspecified = false;
break;
case 'Xtra':
char * newExtraHTML = NULL;
Boolean canceled = !GetExtraHTML( pExtra, &newExtraHTML ,GetWinCSID() );
if (!canceled)
{
if ( pExtra )
XP_FREE( pExtra );
pExtra = newExtraHTML;
}
break;
}
}
/**********************************************************/
#pragma mark -
#pragma mark Document Properties
void CEDDocPropGeneralContain::FinishCreateSelf()
{
fLocation = (CLargeEditField *)FindPaneByID( 'Loca' );
fTitle = (CLargeEditField *)FindPaneByID( 'Titl' );
fAuthor = (CLargeEditField *)FindPaneByID( 'Auth' );
fDescription = (CLargeEditField *)FindPaneByID( 'Desc' );
fKeywords = (CLargeEditField *)FindPaneByID( 'Keyw' );
fClassification = (CLargeEditField *)FindPaneByID( 'Clas' );
UReanimator::LinkListenerToControls( this, this, mPaneID );
}
void CEDDocPropGeneralContain::AddMeta(char *Name, CLargeEditField* value)
{
EDT_MetaData *metaData = EDT_NewMetaData(); // it seems like we could
if (metaData == NULL)
return;
metaData->bHttpEquiv = FALSE;
metaData->pName = Name;
metaData->pContent = value->GetLongDescriptor();
/* if we try to SetMetaData with an empty string for pContent, then "(null)" is used instead; which is ugly. */
if ( metaData->pContent == NULL || XP_STRLEN(metaData->pContent) == 0 )
EDT_DeleteMetaData( fContext, metaData ); // hopefully it won't be a problem if this doesn't exist already.
else
EDT_SetMetaData( fContext, metaData );
metaData->pName = NULL; // don't free this, please
EDT_FreeMetaData( metaData );
}
void CEDDocPropGeneralContain::PrefsFromControls()
{
EDT_PageData *pageData = EDT_GetPageData(fContext);
if ( pageData )
{
if ( pageData->pTitle )
XP_FREE( pageData->pTitle );
pageData->pTitle = fTitle->GetLongDescriptor();
EDT_SetPageData(fContext, pageData);
EDT_FreePageData(pageData);
}
AddMeta("Author", fAuthor);
AddMeta("Description", fDescription);
AddMeta("KeyWords", fKeywords);
AddMeta("Classification", fClassification);
}
// Initialize from preferences
void CEDDocPropGeneralContain::ControlsFromPref()
{
int16 win_csid = GetWinCSID();
SetTextTraitsIDByCsid(fTitle, win_csid);
SetTextTraitsIDByCsid(fAuthor, win_csid);
SetTextTraitsIDByCsid(fDescription, win_csid);
SetTextTraitsIDByCsid(fKeywords, win_csid);
SetTextTraitsIDByCsid(fClassification, win_csid);
History_entry * hist_ent = SHIST_GetCurrent( &fContext->hist );
if ( hist_ent && hist_ent->address )
fLocation->SetLongDescriptor( hist_ent->address );
EDT_PageData *pageData = EDT_GetPageData( fContext );
if ( pageData )
{
if ( pageData->pTitle )
fTitle->SetLongDescriptor( pageData->pTitle );
EDT_FreePageData( pageData );
}
// Get data from meta tags:
int count = EDT_MetaDataCount(fContext);
for ( int i = 0; i < count; i++ )
{
EDT_MetaData* pData = EDT_GetMetaData(fContext, i);
if ( !pData->bHttpEquiv )
{
if (strcasecomp(pData->pName, "Author") == 0)
fAuthor->SetLongDescriptor( pData->pContent );
else if (strcasecomp(pData->pName, "Description") == 0)
fDescription->SetLongDescriptor( pData->pContent );
else if (strcasecomp(pData->pName, "KeyWords") == 0)
fKeywords->SetLongDescriptor( pData->pContent );
else if (strcasecomp(pData->pName, "Classification") == 0)
fClassification->SetLongDescriptor( pData->pContent );
}
EDT_FreeMetaData( pData );
}
}
void CEDDocPropGeneralContain::Help()
{
ShowHelp( HELP_DOC_PROPS_GENERAL );
}
static void AddNewColorData( XP_List *pSchemeData, int r1, int g1, int b1, int r2, int g2, int b2, int r3, int g3, int b3, int r4, int g4, int b4, int r5, int g5, int b5 );
static void AddNewColorData( XP_List *pSchemeData, int r1, int g1, int b1, int r2, int g2, int b2, int r3, int g3, int b3, int r4, int g4, int b4, int r5, int g5, int b5 )
{
EDT_ColorSchemeData * pColorData = XP_NEW( EDT_ColorSchemeData );
if ( !pColorData )
return;
memset(pColorData, 0, sizeof(EDT_ColorSchemeData));
XP_ListAddObjectToEnd( pSchemeData, pColorData );
pColorData->ColorText.red = r1;
pColorData->ColorText.green = g1;
pColorData->ColorText.blue = b1;
pColorData->ColorLink.red = r3;
pColorData->ColorLink.green = g3;
pColorData->ColorLink.blue = b3;
pColorData->ColorActiveLink.red = r5;
pColorData->ColorActiveLink.green = g5;
pColorData->ColorActiveLink.blue = b5;
pColorData->ColorFollowedLink.red = r4;
pColorData->ColorFollowedLink.green = g4;
pColorData->ColorFollowedLink.blue = b4;
pColorData->ColorBackground.red = r2;
pColorData->ColorBackground.green = g2;
pColorData->ColorBackground.blue = b2;
}
void AppearanceContain::FinishCreateSelf()
{
fCustomColor = (LControl*)FindPaneByID( 'Cust' );
fBrowserColor = (LControl*)FindPaneByID( 'Brow' );
fColorScheme = (LControl*)FindPaneByID( 'Sche' );
fExampleView = (CChameleonView*)FindPaneByID( 'Exam' );
fNormalText = (CColorButton*)FindPaneByID( 'Norm' );
fLinkedText = (CColorButton*)FindPaneByID( 'Link' );
fActiveLinkedText = (CColorButton*)FindPaneByID( 'Acti' );
fFollowedLinkedText = (CColorButton*)FindPaneByID( 'Foll' );
fExampleNormalText = (CChameleonCaption*)FindPaneByID( 'norm' );
fExampleLinkedTex = (CChameleonCaption*)FindPaneByID( 'link' );
fExampleActiveLinkedText = (CChameleonCaption*)FindPaneByID( 'actv' );
fExampleFollowedLinkedText = (CChameleonCaption*)FindPaneByID( 'fllw' );
fSolidColor = (CColorButton*)FindPaneByID( 'Choo' );
fImageFile = (LControl*)FindPaneByID( 'Imag' );
fImageFileName = (CLargeEditField *)FindPaneByID( 'bthr' );
UReanimator::LinkListenerToControls( this, this, mPaneID );
LO_Color colorBackground = UGraphics::MakeLOColor( CPrefs::GetColor( CPrefs::WindowBkgnd ) );
LO_Color colorText = UGraphics::MakeLOColor( CPrefs::GetColor( CPrefs::Black ) );
LO_Color colorLink = UGraphics::MakeLOColor( CPrefs::GetColor( CPrefs::Blue ) );
LO_Color colorActiveLink = UGraphics::MakeLOColor( CPrefs::GetColor( CPrefs::Blue ) ); // this must be the same as colorLink ?!
LO_Color colorFollowedLink = UGraphics::MakeLOColor( CPrefs::GetColor( CPrefs::Magenta ) );
fSchemeData = XP_ListNew();
AddNewColorData( fSchemeData,
colorText.red, colorText.green, colorText.blue,
colorBackground.red, colorBackground.green, colorBackground.blue,
colorLink.red, colorLink.green, colorLink.blue,
colorFollowedLink.red, colorFollowedLink.green, colorFollowedLink.blue,
colorActiveLink.red, colorActiveLink.green, colorActiveLink.blue);
AddNewColorData( fSchemeData, 0,0,0, 255,240,240, 255,0,0, 128,0,128, 0,0,255 );
AddNewColorData( fSchemeData, 0,0,0, 255,255,192, 0,0,255, 128,0,128, 255,0,255 );
AddNewColorData( fSchemeData, 64,0,64, 255,255,128, 0,0,255, 0,128,0, 255,0,128 );
AddNewColorData( fSchemeData, 0,0,0, 192,192,255, 0,0,255, 128,0,128, 255,0,128 );
AddNewColorData( fSchemeData, 0,0,0, 128,128,192, 255,255,255, 128,0,128, 255,255,0 );
AddNewColorData( fSchemeData, 0,0,128, 255,192,64, 0,0,255, 0,128,0, 0,255,255 );
AddNewColorData( fSchemeData, 255,255,255, 0,0,0, 255,255,0, 192,192,192, 192,255,192 );
AddNewColorData( fSchemeData, 255,255,255, 0,64,0, 255,255,0, 128,255,128, 0,255,64 );
AddNewColorData( fSchemeData, 255,255,255, 0,0,128, 255,255,0, 128,128,255, 255,0,255 );
AddNewColorData( fSchemeData, 255,255,255, 128,0,128, 0,255,255, 128,255,255, 0,255,0 );
fColorScheme->SetValue(2); // Netscape default
ListenToMessage('Sche', NULL);
}
void AppearanceContain::UpdateTheWholeDamnDialogBox()
{
RGBColor color;
RGBColor backColor;
backColor = fSolidColor->GetColor(); // what about the default??
fExampleView->SetColor( backColor );
color = fNormalText->GetColor();
fExampleNormalText->SetColor( color, backColor );
color = fLinkedText->GetColor();
fExampleLinkedTex->SetColor( color, backColor );
color = fActiveLinkedText->GetColor();
fExampleActiveLinkedText->SetColor( color, backColor );
color = fFollowedLinkedText->GetColor();
fExampleFollowedLinkedText->SetColor( color, backColor );
fExampleView->Refresh();
fNormalText->Refresh();
fLinkedText->Refresh();
fActiveLinkedText->Refresh();
fFollowedLinkedText->Refresh();
fSolidColor->Refresh();
if (fBrowserColor->GetValue())
{
fColorScheme->Disable();
fExampleView->Disable();
fNormalText->Disable();
fLinkedText->Disable();
fActiveLinkedText->Disable();
fFollowedLinkedText->Disable();
fSolidColor->Disable();
}
else
{
fColorScheme->Enable();
fExampleView->Enable();
fNormalText->Enable();
fLinkedText->Enable();
fActiveLinkedText->Enable();
fFollowedLinkedText->Enable();
fSolidColor->Enable();
}
}
void AppearanceContain::ListenToMessage( MessageT inMessage, void* /* ioParam */ )
{
switch (inMessage)
{
case 'Norm':
case 'Link':
case 'Acti':
case 'Foll':
case 'Choo':
fColorScheme->SetValue(1); // custom
ListenToMessage('Sche', NULL);
case 'Cust':
case 'Brow':
UpdateTheWholeDamnDialogBox();
break;
case 'Imag':
if (fImageFile->GetValue() == 1)
{ // we are trying to set the image
CStr255 url;
fImageFileName->GetDescriptor(url);
if (url == CStr255::sEmptyString)
{ // but it doesn't exist
CEditDialog::ChooseImageFile( fImageFileName ); // so try to get it
fImageFileName->GetDescriptor(url);
if (url == CStr255::sEmptyString) // but, if we were unsuccessful
fImageFile->SetValue(0); // revert back.
}
}
break;
case 'wst1':
CEditDialog::ChooseImageFile( fImageFileName ); // try to get it
CStr255 url;
fImageFileName->GetDescriptor(url);
if (url == CStr255::sEmptyString) // if we were unsuccessful
fImageFile->SetValue(0); // don't try to use
else
fImageFile->SetValue(1); // ok
break;
case 'Sche':
int scheme = fColorScheme->GetValue();
scheme--;
if (scheme)
{
EDT_ColorSchemeData * pColorData = (EDT_ColorSchemeData *)XP_ListGetObjectNum(fSchemeData, scheme);
if (pColorData)
{
fSolidColor-> SetColor(UGraphics::MakeRGBColor(pColorData->ColorBackground));
fNormalText-> SetColor(UGraphics::MakeRGBColor(pColorData->ColorText));
fLinkedText-> SetColor(UGraphics::MakeRGBColor(pColorData->ColorLink));
fActiveLinkedText-> SetColor(UGraphics::MakeRGBColor(pColorData->ColorActiveLink));
fFollowedLinkedText-> SetColor(UGraphics::MakeRGBColor(pColorData->ColorFollowedLink));
}
fImageFile->SetValue(0); // no background
UpdateTheWholeDamnDialogBox();
}
break;
}
}
CEDDocPropAppearanceContain::~CEDDocPropAppearanceContain()
{
if ( fSchemeData )
{
EDT_ColorSchemeData *pColorData;
XP_List * list_ptr = fSchemeData;
pColorData = (EDT_ColorSchemeData *)XP_ListNextObject(list_ptr);
while ( pColorData )
{
XP_FREE(pColorData);
pColorData = (EDT_ColorSchemeData *)XP_ListNextObject(list_ptr);
}
XP_ListDestroy(fSchemeData);
// XP_FREE(fSchemeData); already done by XP_ListDestroy()!!
}
}
void CEDDocPropAppearanceContain::PrefsFromControls()
{
LControl *prefCheckBox = (LControl *)FindPaneByID( 'Dflt' );
if ( prefCheckBox && prefCheckBox->GetValue() && prefCheckBox->IsVisible() )
{
PREF_SetBoolPref( "editor.use_custom_colors", fCustomColor->GetValue() );
if ( fCustomColor->GetValue() )
{
LO_Color colorBackground = UGraphics::MakeLOColor(fSolidColor->GetColor());
LO_Color colorText = UGraphics::MakeLOColor(fNormalText->GetColor());
LO_Color colorLink = UGraphics::MakeLOColor(fLinkedText->GetColor());
LO_Color colorActiveLink = UGraphics::MakeLOColor(fActiveLinkedText->GetColor());
LO_Color colorFollowedLink = UGraphics::MakeLOColor(fFollowedLinkedText->GetColor());
PREF_SetColorPref( "editor.background_color",
colorBackground.red,
colorBackground.green,
colorBackground.blue );
PREF_SetColorPref( "editor.text_color",
colorText.red,
colorText.green,
colorText.blue );
PREF_SetColorPref( "editor.link_color",
colorLink.red,
colorLink.green,
colorLink.blue );
PREF_SetColorPref( "editor.active_link_color",
colorActiveLink.red,
colorActiveLink.green,
colorActiveLink.blue );
PREF_SetColorPref( "editor.followed_link_color",
colorFollowedLink.red,
colorFollowedLink.green,
colorFollowedLink.blue );
}
PREF_SetBoolPref( "editor.use_background_image", fImageFile->GetValue());
if (fImageFile->GetValue())
{
char *url = fImageFileName->GetLongDescriptor();
if ( url && XP_STRLEN( url ) )
PREF_SetCharPref("editor.background_image", url);
XP_FREEIF( url );
}
}
EDT_PageData *pageData = EDT_GetPageData( fContext );
if (pageData == NULL)
return;
if (pageData->pColorBackground) XP_FREE(pageData->pColorBackground); // don't care about the old values...
if (pageData->pColorText) XP_FREE(pageData->pColorText);
if (pageData->pColorLink) XP_FREE(pageData->pColorLink);
if (pageData->pColorActiveLink) XP_FREE(pageData->pColorActiveLink);
if (pageData->pColorFollowedLink) XP_FREE(pageData->pColorFollowedLink);
if (pageData->pBackgroundImage)
{
XP_FREE( pageData->pBackgroundImage );
pageData->pBackgroundImage = NULL;
}
if ( fImageFile->GetValue() )
{
char *url = fImageFileName->GetLongDescriptor();
if ( url && XP_STRLEN( url ) )
pageData->pBackgroundImage = url;
else if ( url )
XP_FREE( url );
}
if (fBrowserColor->GetValue())
{
pageData->pColorBackground = NULL;
pageData->pColorText = NULL;
pageData->pColorLink = NULL;
pageData->pColorActiveLink = NULL;
pageData->pColorFollowedLink = NULL;
}
else
{
LO_Color colorBackground = UGraphics::MakeLOColor(fSolidColor->GetColor());
LO_Color colorText = UGraphics::MakeLOColor(fNormalText->GetColor());
LO_Color colorLink = UGraphics::MakeLOColor(fLinkedText->GetColor());
LO_Color colorActiveLink = UGraphics::MakeLOColor(fActiveLinkedText->GetColor());
LO_Color colorFollowedLink = UGraphics::MakeLOColor(fFollowedLinkedText->GetColor());
pageData->pColorBackground = &colorBackground;
pageData->pColorText = &colorText;
pageData->pColorLink = &colorLink;
pageData->pColorActiveLink = &colorActiveLink;
pageData->pColorFollowedLink = &colorFollowedLink;
}
EDT_SetPageData( fContext, pageData );
pageData->pColorBackground = NULL; // of course, we don't want to FREE these...
pageData->pColorText = NULL;
pageData->pColorLink = NULL;
pageData->pColorActiveLink = NULL;
pageData->pColorFollowedLink = NULL;
EDT_FreePageData( pageData );
}
static
inline
bool operator==( const LO_Color& lhs, const LO_Color& rhs )
{
return lhs.red == rhs.red
&& lhs.green == rhs.green
&& lhs.blue == rhs.blue;
}
void CEDDocPropAppearanceContain::ControlsFromPref()
{
EDT_PageData *pageData = EDT_GetPageData( fContext );
if (pageData == NULL)
return;
if (pageData->pColorBackground
|| pageData->pColorLink
|| pageData->pColorText
|| pageData->pColorFollowedLink
|| pageData->pColorActiveLink)
{
TurnOn(fCustomColor);
fColorScheme->SetValue(1); // switch to custom by default
int scheme;
for ( scheme = 0; scheme < fColorScheme->GetMaxValue(); scheme++ )
{
EDT_ColorSchemeData * pColorData = (EDT_ColorSchemeData *)XP_ListGetObjectNum( fSchemeData, scheme );
if ( pColorData && (pColorData->ColorBackground == *(pageData->pColorBackground))
&& (pColorData->ColorText == *(pageData->pColorText))
&& (pColorData->ColorLink == *(pageData->pColorLink))
&& (pColorData->ColorActiveLink == *(pageData->pColorActiveLink))
&& (pColorData->ColorFollowedLink == *(pageData->pColorFollowedLink)) )
{
fColorScheme->SetValue( scheme + 1 );
break;
}
}
}
else
{
TurnOn(fBrowserColor);
}
fImageFile->SetValue(0);
if (pageData->pBackgroundImage && XP_STRLEN(pageData->pBackgroundImage) > 0)
{
fImageFileName->SetLongDescriptor( pageData->pBackgroundImage );
fImageFile->SetValue(1);
}
if (pageData->pColorBackground)
fSolidColor->SetColor(UGraphics::MakeRGBColor(*pageData->pColorBackground));
if (pageData->pColorText)
fNormalText->SetColor(UGraphics::MakeRGBColor(*pageData->pColorText));
if (pageData->pColorLink)
fLinkedText->SetColor(UGraphics::MakeRGBColor(*pageData->pColorLink));
if (pageData->pColorActiveLink)
fActiveLinkedText->SetColor(UGraphics::MakeRGBColor(*pageData->pColorActiveLink));
if (pageData->pColorFollowedLink)
fFollowedLinkedText->SetColor(UGraphics::MakeRGBColor(*pageData->pColorFollowedLink));
EDT_FreePageData( pageData );
UpdateTheWholeDamnDialogBox();
}
void CEDDocPropAppearanceContain::Help()
{
ShowHelp( HELP_DOC_PROPS_APPEARANCE );
}
/* TO DO:
Well, this is somewhat of a mess because:
1) we store the name and value together separated only by a '='. Easily screwed up if one or the other contains a '='
2) We don't remove spaces or any other white space.
3) we don't handle quotes at all. Shouldn't we do something about escaping '"' chanacters?
4) The UI needs work.
5) could use stack space for the majority of small META tags and only resort to malloc in exceptional cases
6) when the page is reloaded, we re-blast in the meta values starting from cell number 1 without first clearing the table
7) no UI for user who tries to insert an "Author" meta tag, etc.
8) not too sure what we are supposed to do about case. layout uses case insensitive tags. EDT_GetMetaData() uses case sensitive tags.
*/
CEDDocPropAdvancedContain::~CEDDocPropAdvancedContain()
{
XP_FREEIF( fbuffer );
}
void CEDDocPropAdvancedContain::FinishCreateSelf()
{
fbufferlen = 1000;
fbuffer = (char *)malloc( fbufferlen ); // we'll keep this fbuffer for temp use for various things as long as dlog is around.
if ( fbuffer == NULL )
fbufferlen = 0;
fSystemVariables = (OneRowLListBox*)FindPaneByID( 'Syst' );
fUserVariables = (OneRowLListBox*)FindPaneByID( 'User' );
fName = (CLargeEditField *)FindPaneByID( 'Name' );
fValue = (CLargeEditField *)FindPaneByID( 'Valu' );
UReanimator::LinkListenerToControls( this, this, mPaneID );
}
void CEDDocPropAdvancedContain::PrefsFromControls()
{
if (fbuffer == NULL)
return; // the fbuffer is now as big or bigger (it grows) than all MetaData and all cell entries in the table. Don't worry about the size anymore.
EDT_MetaData* pData;
int16 i, count;
// First, clear METAs all out because we are going to rebuild the lists from scratch.
count = EDT_MetaDataCount(fContext);
for (i = count - 1; i >= 0; i-- )
{
pData = EDT_GetMetaData(fContext, i);
if (strcasecomp(pData->pName, "Author") && // Skip the fields used in General Info page
strcasecomp(pData->pName, "Description") &&
strcasecomp(pData->pName, "Generator") &&
strcasecomp(pData->pName, "Last-Modified") &&
strcasecomp(pData->pName, "Created") &&
strcasecomp(pData->pName, "Classification") &&
strcasecomp(pData->pName, "Keywords"))
EDT_DeleteMetaData( fContext, pData ); // remove all the other ones.
EDT_FreeMetaData( pData );
}
pData = EDT_NewMetaData();
// Do the system METAs first, bHttpEquiv = FALSE;
pData->bHttpEquiv = FALSE;
count = fSystemVariables->GetRows();
for (i = 0; i < count; i++)
{
int16 len = fbufferlen;
fSystemVariables->GetCell(i, fbuffer, &len);
fbuffer[len] = '\0';
pData->pName = fbuffer;
char *equal = strchr(fbuffer, '='); // look for the '='. Of course this screws up if the stupid user put an '=' in the TEditField
if (equal)
{
*equal++ = '\0';
pData->pContent = equal;
EDT_SetMetaData( fContext, pData );
}
else
{
pData->pContent = NULL; // I should check if this is valid....
EDT_DeleteMetaData( fContext, pData ); // you might wonder why I'm calling EDT_DeleteMetaData() if all Tags are supposed to be gone.... Well, what if a user wanted to delete the "Author" tag here by defining it to be NULL?!
}
}
// Do the user METAs next, bHttpEquiv = TRUE;
pData->bHttpEquiv = TRUE;
count = fUserVariables->GetRows();
for (i = 0; i < count; i++)
{
int16 len = fbufferlen;
fUserVariables->GetCell(i, fbuffer, &len);
fbuffer[len] = '\0';
pData->pName = fbuffer;
char *equal = strchr(fbuffer, '=');
if (equal)
{
*equal++ = '\0';
pData->pContent = equal;
}
else
pData->pContent = NULL; // I should check if this is valid....
EDT_SetMetaData( fContext, pData );
}
pData->pName = NULL; // we don't want EDT_FreeMetaData() to free our fbuffer for us.
pData->pContent = NULL; // we don't want EDT_FreeMetaData() to free our fbuffer for us.
EDT_FreeMetaData(pData);
}
void CEDDocPropAdvancedContain::ControlsFromPref()
{
int16 sysRowNum = fSystemVariables->GetRows(); // add to the bottom? shouldn't we clear the tables first and skip this?
int16 usrRowNum = fUserVariables->GetRows(); // add to the bottom? shouldn't we clear the tables first and skip this?
sysRowNum = 1; // forget what is in the table now. We'll start from the beginning.
usrRowNum = 1;
int newlength;
int count = EDT_MetaDataCount(fContext);
for ( int i = 0; i < count; i++ )
{
EDT_MetaData* pData = EDT_GetMetaData(fContext, i);
newlength = XP_STRLEN(pData->pName) + 1 + XP_STRLEN(pData->pContent) + 1;
if ( fbuffer && newlength > fbufferlen )
{ // grow fbuffer if necessary
fbuffer = (char *) XP_REALLOC(&fbuffer, fbufferlen);
if ( fbuffer )
fbufferlen = newlength;
else
fbufferlen = 0;
}
if ( fbuffer )
{
sprintf(fbuffer, "%s=%s", pData->pName, pData->pContent);
if ( pData->bHttpEquiv )
{ // which table do we put it in?
fSystemVariables->AddRow( sysRowNum++, fbuffer, XP_STRLEN(fbuffer) );
}
else if (strcasecomp(pData->pName, "Author") && // Skip the fields used in General Info page
strcasecomp(pData->pName, "Description") &&
strcasecomp(pData->pName, "Generator") &&
strcasecomp(pData->pName, "Last-Modified") &&
strcasecomp(pData->pName, "Created") &&
strcasecomp(pData->pName, "Classification") &&
strcasecomp(pData->pName, "Keywords"))
{
// TODO: PUT META STRINGS IN RESOURCES?
fUserVariables->AddRow( usrRowNum++, fbuffer, XP_STRLEN(fbuffer) );
}
}
EDT_FreeMetaData( pData );
}
fSystemVariables->FocusDraw();
fSystemVariables->SetDoubleClickMessage( msg_DblClickOnTarget );
fSystemVariables->SetSingleClickMessage(msg_ClickOnTarget);
fSystemVariables->AddListener( this );
fSystemVariables->SetValue(-1);
fUserVariables->FocusDraw();
fUserVariables->SetDoubleClickMessage( msg_DblClickOnTarget2 );
fUserVariables->SetSingleClickMessage( msg_ClickOnTarget2 );
fUserVariables->AddListener( this );
fUserVariables->SetValue(-1);
}
void CEDDocPropAdvancedContain::PutStringsInBuffer()
{
if (fbuffer == NULL)
return;
char *name = fName->GetLongDescriptor();
if ( name == NULL )
return;
char *value = fValue->GetLongDescriptor();
if ( value == NULL )
{
XP_FREE( name );
return;
}
if ( XP_STRLEN(name) + 1 + XP_STRLEN(value) + 1 > fbufferlen )
{ // grow the fbuffer if necessary
fbuffer = (char *) XP_REALLOC(&fbuffer, fbufferlen);
if ( fbuffer )
fbufferlen = XP_STRLEN( name ) + 1 + XP_STRLEN( value ) + 1;
else
fbufferlen = 0;
}
if ( fbuffer )
sprintf(fbuffer, "%s=%s", name, value);
XP_FREE( name );
XP_FREE( value );
}
Boolean CEDDocPropAdvancedContain::BufferUnique()
{
if (fbuffer == NULL) return false;
if (!fSystemVariables->IsTarget() && !fUserVariables->IsTarget())
return false; // we compare against the target: at least one must be target
OneRowLListBox* lBox;
if (fSystemVariables->IsTarget())
lBox = fSystemVariables;
else
lBox = fUserVariables;
int16 count = lBox->GetRows();
char *tempbuff = (char *)malloc(fbufferlen); // we need to copy the strings out of the table one at a time to compare with them. don't copy more than bufflen since they wouldn't be equal then anyway.
if (tempbuff == NULL)
return false;
int16 i;
for (i = 0; i < count; i++) {
int16 len = fbufferlen;
lBox->GetCell(i, tempbuff, &len);
tempbuff[len] = '\0';
if (XP_STRCMP(tempbuff, fbuffer) == NULL)
{ // we should probably do a case insensitive compare on the Name and a case sensitive compare on the Value. What a pain.
XP_FREE(tempbuff);
return false;
}
}
XP_FREE(tempbuff);
return true; // no matches; must be unique
}
void CEDDocPropAdvancedContain::Help()
{
ShowHelp( HELP_DOC_PROPS_ADVANCED );
}
void CEDDocPropAdvancedContain::ListenToMessage( MessageT inMessage, void* /* ioParam */ )
{
switch (inMessage) {
case msg_Doc_Advanced_Prop_New_Tag:
PutStringsInBuffer();
if (BufferUnique()) {
if (fSystemVariables->IsTarget())
fSystemVariables->AddRow(fSystemVariables->GetRows(),fbuffer,strlen(fbuffer));
if (fUserVariables->IsTarget())
fUserVariables->AddRow(fUserVariables->GetRows(),fbuffer,strlen(fbuffer));
}
break;
case msg_Doc_Advanced_Prop_Set_Tag:
PutStringsInBuffer();
if (BufferUnique()) {
if (fSystemVariables->IsTarget() && fSystemVariables->GetValue() != -1)
fSystemVariables->SetCell(fSystemVariables->GetValue(),fbuffer,strlen(fbuffer));
if (fUserVariables->IsTarget() && fUserVariables->GetValue() != -1)
fUserVariables->SetCell(fUserVariables->GetValue(),fbuffer,strlen(fbuffer));
}
break;
case msg_Doc_Advanced_Prop_Delete_Tag:
if (fSystemVariables->IsTarget() && fSystemVariables->GetValue() != -1)
fSystemVariables->RemoveRow(fSystemVariables->GetValue());
if (fUserVariables->IsTarget() && fUserVariables->GetValue() != -1)
fUserVariables->RemoveRow(fUserVariables->GetValue());
break;
case msg_ClickOnTarget:
case msg_DblClickOnTarget:
if (fbuffer && fSystemVariables->GetValue() != -1)
{
int16 len = fbufferlen;
fSystemVariables->GetCell(fSystemVariables->GetValue(), fbuffer, &len);
fbuffer[len] = '\0';
char *equal = strchr(fbuffer, '=');
if ( equal )
{
*equal++ = '\0';
fValue->SetLongDescriptor( equal );
}
else
fValue->SetLongDescriptor( "" );
fName->SetLongDescriptor( fbuffer );
}
break;
case msg_ClickOnTarget2:
case msg_DblClickOnTarget2:
if (fbuffer && fUserVariables->GetValue() != -1)
{
int16 len = fbufferlen;
fUserVariables->GetCell(fUserVariables->GetValue(), fbuffer, &len);
fbuffer[len] = '\0';
char *equal = strchr(fbuffer, '=');
if (equal)
{
*equal++ = '\0';
fValue->SetLongDescriptor( equal );
}
else
fValue->SetLongDescriptor( "" );
fName->SetLongDescriptor( fbuffer );
}
break;
}
}
void CEDDocAppearanceNoTab::DrawSelf()
{
// we don't want to draw any frame/bevel border in this case because it is going to
// go into a dialog all by itself (not in a tabbed dialog)
// the following is copied from CPrefContain::DrawSelf() and #if'd out
#if 0
Rect theFrame;
if (CalcLocalFrameRect(theFrame))
{
StColorPenState theSaver;
theSaver.Normalize();
SBevelColorDesc theDesc;
UGraphicGizmos::LoadBevelTraits(5000, theDesc);
::PmForeColor(theDesc.fillColor);
::PaintRect(&theFrame);
StClipRgnState theClipSaver(theFrame);
StColorState::Normalize();
theFrame.top -= 5;
::FrameRect(&theFrame);
SBooleanRect theBevelSides = { true, false, true, true };
UGraphicGizmos::BevelPartialRect(theFrame, 1, eStdGrayBlack, eStdGrayBlack, theBevelSides);
::InsetRect(&theFrame, 1, 1);
UGraphicGizmos::BevelPartialRect(theFrame, 2, theDesc.topBevelColor, theDesc.bottomBevelColor, theBevelSides);
}
#endif
}
void CFormatMsgColorAndImageDlog::InitializeDialogControls()
{
LControl *prefCheckBox = (LControl *)FindPaneByID( 'Dflt' );
if ( prefCheckBox )
prefCheckBox->Hide();
CEDDocPropAppearanceContain *contain = (CEDDocPropAppearanceContain *)FindPaneByID( 5210 );
if ( contain )
{
contain->SetContext( GetContext() );
contain->ControlsFromPref();
}
}
Boolean CFormatMsgColorAndImageDlog::CommitChanges( Boolean /* allPanes */ )
{
CEDDocPropAppearanceContain *contain = (CEDDocPropAppearanceContain *)FindPaneByID( 5210 );
if ( contain )
{
EDT_BeginBatchChanges( fContext );
contain->PrefsFromControls();
EDT_EndBatchChanges( fContext );
}
return true;
}
void CFormatMsgColorAndImageDlog::Help()
{
ShowHelp( HELP_DOC_PROPS_APPEARANCE );
}
/**********************************************************/
#pragma mark -
#pragma mark Modal Dialogs
// This is a total hack because I'm in a hurry and this has to be a modal dialog. Please rewrite soon!
void SetItemValue(DialogRef theDialog, short itemNo, short value);
void SetItemValue(DialogRef theDialog, short itemNo, short value)
{
Rect so;
ControlHandle theControl;
short type;
GetDialogItem(theDialog, itemNo, &type, (Handle *)&theControl, &so);
if (type != kCheckBoxDialogItem) return;
SetControlValue(theControl, value);
}
static void InformOfLimit(int min, int max)
{
Str31 minstr, maxstr;
NumToString( min, minstr );
NumToString( max, maxstr );
HandleModalDialog( EDITDLG_LIMITS, minstr, maxstr);
}
static Boolean IsEditFieldWithinLimits(LGAEditField* editField, int minVal, int maxVal )
{
short value = editField->GetValue();
if ( value < minVal || value > maxVal )
{
InformOfLimit( minVal, maxVal );
return FALSE;
}
return TRUE;
}
#define ED_SAVE_OVERWRITE_THIS_BUTTON 1
#define ED_SAVE_OVERWRITE_ALL_BUTTON 2
#define ED_SAVE_DONT_OVERWRITE_THIS_BUTTON 3
#define ED_SAVE_DONT_OVERWRITE_ALL_BUTTON 4
#define ED_SAVE_CANCEL_BUTTON 5
ED_SaveOption FE_SaveFileExistsDialog( MWContext * /* pContext */, char* pFileName )
{
Str255 pFileNameCopy;
if ( pFileName )
{ // should use the string classes and manipulation routines and clean up this mess!!!
char *shorter = WH_FileName(pFileName, xpURL);
if (!shorter)
return ED_SAVE_CANCEL;
BlockMoveData(shorter, pFileNameCopy, strlen(shorter) + 1);
XP_FREE(shorter);
c2pstr((char*)pFileNameCopy);
}
switch (HandleModalDialog( EDITDLG_SAVE_FILE_EXISTS, pFileNameCopy, NULL ))
{
case ED_SAVE_OVERWRITE_THIS_BUTTON: return ED_SAVE_OVERWRITE_THIS; break;
case ED_SAVE_OVERWRITE_ALL_BUTTON: return ED_SAVE_OVERWRITE_ALL; break;
case ED_SAVE_DONT_OVERWRITE_THIS_BUTTON: return ED_SAVE_DONT_OVERWRITE_THIS; break;
case ED_SAVE_DONT_OVERWRITE_ALL_BUTTON: return ED_SAVE_DONT_OVERWRITE_ALL; break;
case ED_SAVE_CANCEL_BUTTON: return ED_SAVE_CANCEL; break;
}
return ED_SAVE_CANCEL; // shouldn't get here...
}