mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-06 08:31:25 +00:00
52bb18a74f
anywhere any more. * Cleaned up split and join undo/redo. * Added TypeInState, a data struct that remembers things about text properties for collapsed selections, so you can type * Ctrl-B with an insertion point and the next character will be bold. * Added all the logic to handle inline vs. block elements when setting text properties. * Added some support for italic and underline as well. Adding these things is pretty easy now. Ctrl-B, Ctrl-I, Ctrl-U for testing bold, italic, underline. * Added all the logic to make sure we only add style tags where they're needed, so you should never get the same style tag nested within itself, except as needed for block elements. * Added methods for testing a node to see if a particular style is set. This isn't 100% done yet, but with very little work we could have toolbar buttons that respond to selection changed notification that show the state of bold, italic, underline, etc. in real time. Supports tri-state: whole selection is bold, some of selection is bold, none of selection is bold, ... * Fully undoable and redoable. * Added some debug printfs to transactions and editors. all controlled by a gNoisy static in each module. helps me track down undo/redo problems. if the output bugs people enough, I'll shut it off and re-enable it in my local tree. Noticably missing: make un-bold, make un-italic, etc. This is coming soon.
97 lines
2.7 KiB
C++
97 lines
2.7 KiB
C++
/* -*- Mode: C++; tab-width: 2; 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.
|
|
*/
|
|
|
|
#ifndef JoinElementTxn_h__
|
|
#define JoinElementTxn_h__
|
|
|
|
#include "EditTxn.h"
|
|
#include "nsIDOMNode.h"
|
|
#include "nsCOMPtr.h"
|
|
#include "nsIEditor.h"
|
|
|
|
#define JOIN_ELEMENT_TXN_IID \
|
|
{/* 9bc5f9f0-ac48-11d2-86d8-000064657374 */ \
|
|
0x9bc5f9f0, 0xac48, 0x11d2, \
|
|
{0x86, 0xd8, 0x0, 0x0, 0x64, 0x65, 0x73, 0x74} }
|
|
|
|
|
|
/**
|
|
* A transaction that joins two elements E1 (left node) and E2 (right node)
|
|
* into a single node E.
|
|
* The children of E are the children of E1 followed by the children of E2.
|
|
* After Do() and Redo(), E1 is removed from the content tree and E2 remains.
|
|
*/
|
|
class JoinElementTxn : public EditTxn
|
|
{
|
|
public:
|
|
|
|
/** initialize the transaction
|
|
* @param aEditor the provider of core editing operations
|
|
* @param aLeftNode the first of two nodes to join
|
|
* @param aRightNode the second of two nodes to join
|
|
*/
|
|
NS_IMETHOD Init(nsIEditor *aEditor,
|
|
nsIDOMNode *aLeftNode,
|
|
nsIDOMNode *aRightNode);
|
|
protected:
|
|
JoinElementTxn();
|
|
|
|
public:
|
|
|
|
virtual ~JoinElementTxn();
|
|
|
|
NS_IMETHOD Do(void);
|
|
|
|
NS_IMETHOD Undo(void);
|
|
|
|
// NS_IMETHOD Redo(void);
|
|
|
|
NS_IMETHOD GetIsTransient(PRBool *aIsTransient);
|
|
|
|
NS_IMETHOD Merge(PRBool *aDidMerge, nsITransaction *aTransaction);
|
|
|
|
NS_IMETHOD Write(nsIOutputStream *aOutputStream);
|
|
|
|
NS_IMETHOD GetUndoString(nsString **aString);
|
|
|
|
NS_IMETHOD GetRedoString(nsString **aString);
|
|
|
|
protected:
|
|
|
|
/** the elements to operate upon.
|
|
* After the merge, mRightNode remains and mLeftNode is removed from the content tree.
|
|
*/
|
|
nsCOMPtr<nsIDOMNode> mLeftNode;
|
|
nsCOMPtr<nsIDOMNode> mRightNode;
|
|
|
|
/** the offset into mNode where the children of mElement are split (for undo).<BR>
|
|
* mOffset is the index of the first child in the right node.
|
|
* -1 means the left node had no children.
|
|
*/
|
|
PRUint32 mOffset;
|
|
|
|
/** the parent node containing mLeftNode and mRightNode */
|
|
nsCOMPtr<nsIDOMNode> mParent;
|
|
nsCOMPtr<nsIEditor> mEditor;
|
|
|
|
friend class TransactionFactory;
|
|
|
|
};
|
|
|
|
#endif
|