wiki:TEXT_PARAGRAPH_SPACING_R0

Version 10 (modified by vlado, 16 years ago) (diff)

--

Error: Macro BackLinksMenu(None) failed
compressed data is corrupt

Error: Macro TicketQuery(summary=TEXT_PARAGRAPH_SPACING_R0, format=table, col=summary|owner|status|type|component|priority|effort|importance, rows=description|analysis_owners|analysis_reviewers|analysis_score|design_owners|design_reviewers|design_score|implementation_owners|implementation_reviewers|implementation_score|test_owners|test_reviewers|test_score|) failed
current transaction is aborted, commands ignored until end of transaction block

Analysis

Overview

A paragraph is a self-contained unit of a discourse in writing dealing with a particular point or idea. The start of a paragraph is indicated by beginning on a new line. Sometimes the first line is indented; sometimes it is indented without beginning a new line. At various times the beginning of a paragraph has been indicated by the pilcrow: ¶. User should be able to specify spacing setting for specific paragraph via paragraph settings hud.
Identation defines where does the text begin in the frame.Following settings should present:

  • Right indent - defines the space after the text, for now in points.
  • Left indent - defines the space before the text, for now in points.
  • First line indent - defines the space before the first line in the text, for now in points.
  • Space above - defines the space above the paragraph, for now in points.
  • Space below - defines the space below the paragraph, for now in points.
  • Line spacing - defines spacing between the lines in the paragraph, in lines. The default is 1.

source:trunk/sophie2-platform/doc/spec-diagrams/Paragraph.png

Task requirements

  • Implement indent functionalities for the paragraph
  • Create a paragraph hud(OPTIONAL IF NOT FINISHED WILL BE INCLUDED IN THE NEXT REVISION)
    • Should contain controls for align, character style and indents. (add only indent controls)

Task result

  • The result should be code.

Implementation idea

TEXT_PARAGPRAPH_FORMAT_COMMONS_R0
TEXT_PARAGRAPH_ALIGN_R0
TEXT_PARAGRAPH_STYLE_TEMPLATES_R0
TEXT_PARAGRAPH_CHAR_STYLE_R0
TEXT_PARAGRAPH_NEXT_STYLE_R0

DETACHED_TEXT_FRAME_EDITOR_R0 http://en.wikipedia.org/wiki/Paragraph

How to demo

  • Run the application
  • Create a new book and place text frame inside
  • Populate some lorem ipsum text inside with a number of paragraphs(lorem ipsum generator --> http://www.lipsum.com/)
  • Open the paragraph settings hud and manipulate spacing controls.

Design

  • Layout
    • Extend Atom class functionality with paragraph related attributes:
      • Add Atom.isParaBegin to check for BEGIN_PARAGRAPH attribute.
      • Modify Atom.isParaEnd to check for END_PARAGRAPH attribute.
      • Methods for indentation, top and bottom spacing, etc.
    • Add VertexFields values for the needed paragraph attributes.
    • Modify the layout algorithm:
      • EdgeKind.OPEN_LINE to check for BEGIN_PARAGRAPH.
      • EdgeKind.CLOSE_LINE to check for END_PARAGRAPH.
      • EdgeKind.SEGMENT to check for BEGIN_PARAGRAPH and END_PARAGRAPH.
      • EdgeKind.SEGMENT to apply the paragraph visualization properties/attributes.

Implementation

(Describe and link the implementation results here (from the wiki or the repository).)

Testing

(Place the testing results here.)

Comments

(Write comments for this or later revisions here.)