mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-07 16:48:02 +08:00
e7868df1ad
Summary: toolbar popup displays restore caret protection on contenteditable BAD - can't use cursor saving and restoring with react :( _findNode works saves and restores cursor state contenteditable fixes to support cursor comments on cursor initial undo manager extract undo manager and move up in stack make undo manager a mixin adding selection snapshots in composer fixes in undo manager selection saves selection states properly move UndoManager and fix draft selection state can now select backwards selection works backwards and click not overridden change bold class to allow for bolding and unbolding styling of hover component can set links in composer bold and italic clicking works. text seleciton works show link modal on hover selection fixes Test Plan: TODO Reviewers: bengotow Reviewed By: bengotow Differential Revision: https://review.inboxapp.com/D1249
41 lines
1.5 KiB
CoffeeScript
41 lines
1.5 KiB
CoffeeScript
# OBSOLETE: Use FloatingToolbar instead.
|
|
# However, We may decide to change back to a static toolbar in the footer,
|
|
# so don't delete me yet.
|
|
|
|
|
|
# React = require 'react'
|
|
#
|
|
# module.exports =
|
|
# ContenteditableToolbar = React.createClass
|
|
# render: ->
|
|
# style =
|
|
# display: @state.show and 'initial' or 'none'
|
|
# <div className="compose-toolbar-wrap" onBlur={@onBlur}>
|
|
# <button className="btn btn-icon btn-formatting"
|
|
# onClick={=> @setState { show: !@state.show }}
|
|
# ><i className="fa fa-font"></i></button>
|
|
# <div ref="toolbar" className="compose-toolbar" style={style}>
|
|
# <button className="btn btn-bold" onClick={@onClick} data-command-name="bold"><strong>B</strong></button>
|
|
# <button className="btn btn-italic" onClick={@onClick} data-command-name="italic"><em>I</em></button>
|
|
# <button className="btn btn-underline" onClick={@onClick} data-command-name="underline"><span style={'textDecoration': 'underline'}>U</span></button>
|
|
# </div>
|
|
# </div>
|
|
#
|
|
# getInitialState: ->
|
|
# show: false
|
|
#
|
|
# componentDidUpdate: (lastProps, lastState) ->
|
|
# if !lastState.show and @state.show
|
|
# @refs.toolbar.getDOMNode().focus()
|
|
#
|
|
# onClick: (event) ->
|
|
# cmd = event.currentTarget.getAttribute 'data-command-name'
|
|
# document.execCommand(cmd, false, null)
|
|
# true
|
|
#
|
|
# onBlur: (event) ->
|
|
# target = event.nativeEvent.relatedTarget
|
|
# if target? and target.getAttribute 'data-command-name'
|
|
# return
|
|
# @setState
|
|
# show: false
|