single-scripture-rcl 3.3.1 → 3.3.2-beta
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -24,8 +24,11 @@ import * as React from 'react';
|
|
|
24
24
|
import useDeepCompareEffect from 'use-deep-compare-effect';
|
|
25
25
|
import { VerseObjects } from 'scripture-resources-rcl';
|
|
26
26
|
import { UsfmFileConversionHelpers } from 'word-aligner-rcl';
|
|
27
|
-
import {
|
|
27
|
+
import { RxLink2, RxLinkBreak2 } from 'react-icons/rx';
|
|
28
|
+
import { IconButton } from '@mui/material';
|
|
29
|
+
import { ScriptureReference } from '../../types';
|
|
28
30
|
import { getResourceMessage } from '../../utils';
|
|
31
|
+
import { ScriptureALignmentEditProps, useScriptureAlignmentEdit } from "../../hooks/useScriptureAlignmentEdit";
|
|
29
32
|
import { Container, Content } from './styled';
|
|
30
33
|
var MessageStyle = {
|
|
31
34
|
direction: 'ltr',
|
|
@@ -48,11 +51,13 @@ var TextAreaStyle = {
|
|
|
48
51
|
};
|
|
49
52
|
|
|
50
53
|
function ScripturePane(_ref) {
|
|
54
|
+
var _scriptureAlignmentEd3;
|
|
55
|
+
|
|
51
56
|
var reference = _ref.reference,
|
|
52
57
|
refStyle = _ref.refStyle,
|
|
53
58
|
direction = _ref.direction,
|
|
59
|
+
currentIndex = _ref.currentIndex,
|
|
54
60
|
contentStyle = _ref.contentStyle,
|
|
55
|
-
verseObjects = _ref.verseObjects,
|
|
56
61
|
disableWordPopover = _ref.disableWordPopover,
|
|
57
62
|
resourceStatus = _ref.resourceStatus,
|
|
58
63
|
resourceLink = _ref.resourceLink,
|
|
@@ -61,16 +66,34 @@ function ScripturePane(_ref) {
|
|
|
61
66
|
fontSize = _ref.fontSize,
|
|
62
67
|
getLexiconData = _ref.getLexiconData,
|
|
63
68
|
translate = _ref.translate,
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
+
saving = _ref.saving,
|
|
70
|
+
scriptureAlignmentEditConfig = _ref.scriptureAlignmentEditConfig,
|
|
71
|
+
setSavedChanges = _ref.setSavedChanges,
|
|
72
|
+
setWordAlignerStatus = _ref.setWordAlignerStatus;
|
|
73
|
+
|
|
74
|
+
var _React$useState = React.useState({
|
|
75
|
+
urlError: null,
|
|
76
|
+
doingAlignment: false
|
|
77
|
+
}),
|
|
69
78
|
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
70
|
-
|
|
71
|
-
|
|
79
|
+
state = _React$useState2[0],
|
|
80
|
+
setState_ = _React$useState2[1];
|
|
81
|
+
|
|
82
|
+
var urlError = state.urlError,
|
|
83
|
+
doingAlignment = state.doingAlignment;
|
|
84
|
+
|
|
85
|
+
function setState(newState) {
|
|
86
|
+
setState_(function (prevState) {
|
|
87
|
+
return _objectSpread(_objectSpread({}, prevState), newState);
|
|
88
|
+
});
|
|
89
|
+
}
|
|
72
90
|
|
|
73
|
-
var
|
|
91
|
+
var _React$useState3 = React.useState(null),
|
|
92
|
+
_React$useState4 = _slicedToArray(_React$useState3, 2),
|
|
93
|
+
initialVerseText = _React$useState4[0],
|
|
94
|
+
setInitialVerseText = _React$useState4[1];
|
|
95
|
+
|
|
96
|
+
var resourceMsg = saving ? 'Saving Changes...' : getResourceMessage(resourceStatus, server, resourceLink, isNT);
|
|
74
97
|
var chapter = reference.chapter,
|
|
75
98
|
verse = reference.verse;
|
|
76
99
|
direction = direction || 'ltr';
|
|
@@ -81,7 +104,39 @@ function ScripturePane(_ref) {
|
|
|
81
104
|
contentStyle = contentStyle || {
|
|
82
105
|
fontFamily: 'Noto Sans',
|
|
83
106
|
fontSize: '100%'
|
|
84
|
-
};
|
|
107
|
+
};
|
|
108
|
+
|
|
109
|
+
var _scriptureAlignmentEditConfig = _objectSpread(_objectSpread({}, scriptureAlignmentEditConfig), {}, {
|
|
110
|
+
initialVerseText: initialVerseText
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
var _scriptureAlignmentEdit = useScriptureAlignmentEdit(_scriptureAlignmentEditConfig);
|
|
114
|
+
|
|
115
|
+
var _scriptureAlignmentEd = _scriptureAlignmentEdit.actions,
|
|
116
|
+
handleAlignmentClick = _scriptureAlignmentEd.handleAlignmentClick,
|
|
117
|
+
setEditing = _scriptureAlignmentEd.setEditing,
|
|
118
|
+
setVerseChanged = _scriptureAlignmentEd.setVerseChanged,
|
|
119
|
+
_scriptureAlignmentEd2 = _scriptureAlignmentEdit.state,
|
|
120
|
+
aligned = _scriptureAlignmentEd2.aligned,
|
|
121
|
+
alignerData = _scriptureAlignmentEd2.alignerData,
|
|
122
|
+
currentVerseObjects = _scriptureAlignmentEd2.currentVerseObjects,
|
|
123
|
+
initialVerseObjects = _scriptureAlignmentEd2.initialVerseObjects,
|
|
124
|
+
editing = _scriptureAlignmentEd2.editing,
|
|
125
|
+
unsavedChanges = _scriptureAlignmentEd2.unsavedChanges,
|
|
126
|
+
newVerseText = _scriptureAlignmentEd2.newVerseText;
|
|
127
|
+
React.useEffect(function () {
|
|
128
|
+
if (alignerData && !doingAlignment) {
|
|
129
|
+
setWordAlignerStatus && setWordAlignerStatus(_scriptureAlignmentEdit);
|
|
130
|
+
setState({
|
|
131
|
+
doingAlignment: true
|
|
132
|
+
});
|
|
133
|
+
} else if (doingAlignment) {
|
|
134
|
+
setWordAlignerStatus && setWordAlignerStatus(_scriptureAlignmentEdit);
|
|
135
|
+
setState({
|
|
136
|
+
doingAlignment: false
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
}, [_scriptureAlignmentEdit === null || _scriptureAlignmentEdit === void 0 ? void 0 : (_scriptureAlignmentEd3 = _scriptureAlignmentEdit.state) === null || _scriptureAlignmentEd3 === void 0 ? void 0 : _scriptureAlignmentEd3.alignerData]); // dynamically adjust font size
|
|
85
140
|
|
|
86
141
|
var calculatedFontSize = React.useMemo(function () {
|
|
87
142
|
return parseFloat(TextAreaStyle.fontSize) * fontSize / 100 + 'px';
|
|
@@ -93,11 +148,12 @@ function ScripturePane(_ref) {
|
|
|
93
148
|
|
|
94
149
|
useDeepCompareEffect(function () {
|
|
95
150
|
var verseText = UsfmFileConversionHelpers.getUsfmForVerseContent({
|
|
96
|
-
verseObjects:
|
|
151
|
+
verseObjects: initialVerseObjects
|
|
97
152
|
});
|
|
98
153
|
setInitialVerseText(verseText);
|
|
99
154
|
}, [{
|
|
100
|
-
|
|
155
|
+
reference: reference,
|
|
156
|
+
initialVerseObjects: initialVerseObjects
|
|
101
157
|
}]);
|
|
102
158
|
|
|
103
159
|
function onTextChange(event) {
|
|
@@ -112,6 +168,8 @@ function ScripturePane(_ref) {
|
|
|
112
168
|
setEditing(false);
|
|
113
169
|
}
|
|
114
170
|
|
|
171
|
+
var checkingState = aligned ? 'valid' : 'invalid';
|
|
172
|
+
var titleText = checkingState === 'valid' ? 'Alignment is Valid' : 'Alignment is Invalid';
|
|
115
173
|
return /*#__PURE__*/React.createElement(Container, {
|
|
116
174
|
style: {
|
|
117
175
|
direction: direction,
|
|
@@ -135,17 +193,33 @@ function ScripturePane(_ref) {
|
|
|
135
193
|
setEditing && setEditing(true);
|
|
136
194
|
}
|
|
137
195
|
}, editing ? /*#__PURE__*/React.createElement("textarea", {
|
|
138
|
-
defaultValue: initialVerseText,
|
|
196
|
+
defaultValue: newVerseText || initialVerseText,
|
|
139
197
|
onChange: onTextChange,
|
|
140
198
|
onBlur: onBlur,
|
|
141
199
|
style: textAreaStyle,
|
|
142
200
|
autoFocus: true
|
|
143
201
|
}) : /*#__PURE__*/React.createElement(VerseObjects, {
|
|
144
202
|
verseKey: "".concat(reference.chapter, ":").concat(reference.verse),
|
|
145
|
-
verseObjects:
|
|
203
|
+
verseObjects: currentVerseObjects || [],
|
|
146
204
|
disableWordPopover: disableWordPopover,
|
|
147
205
|
getLexiconData: getLexiconData,
|
|
148
206
|
translate: translate
|
|
207
|
+
})), setWordAlignerStatus && /*#__PURE__*/React.createElement(IconButton, {
|
|
208
|
+
key: "checking-button",
|
|
209
|
+
onClick: function onClick() {
|
|
210
|
+
return handleAlignmentClick();
|
|
211
|
+
},
|
|
212
|
+
title: titleText,
|
|
213
|
+
"aria-label": titleText,
|
|
214
|
+
style: {
|
|
215
|
+
cursor: 'pointer'
|
|
216
|
+
}
|
|
217
|
+
}, checkingState === 'valid' ? /*#__PURE__*/React.createElement(RxLink2, {
|
|
218
|
+
id: "valid_icon",
|
|
219
|
+
color: "#BBB"
|
|
220
|
+
}) : /*#__PURE__*/React.createElement(RxLinkBreak2, {
|
|
221
|
+
id: "invalid_icon",
|
|
222
|
+
color: "#000"
|
|
149
223
|
}))));
|
|
150
224
|
}
|
|
151
225
|
|
|
@@ -153,4 +227,4 @@ ScripturePane.defaultProps = {
|
|
|
153
227
|
verseObjects: []
|
|
154
228
|
};
|
|
155
229
|
export default ScripturePane;
|
|
156
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/ScripturePane/ScripturePane.tsx"],"names":["React","useDeepCompareEffect","VerseObjects","UsfmFileConversionHelpers","ScriptureReference","VerseObjectsType","getResourceMessage","Container","Content","MessageStyle","direction","whiteSpace","lineHeight","display","justifyContent","alignItems","height","width","fontSize","fontFamily","fontWeight","TextAreaStyle","minWidth","ScripturePane","reference","refStyle","contentStyle","verseObjects","disableWordPopover","resourceStatus","resourceLink","server","isNT","getLexiconData","translate","editing","setEditing","setVerseChanged","useState","initialVerseText","setInitialVerseText","resourceMsg","chapter","verse","calculatedFontSize","useMemo","parseFloat","textAreaStyle","verseText","getUsfmForVerseContent","onTextChange","event","newText","target","value","changed","onBlur","paddingBottom","defaultProps"],"mappings":"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","sourcesContent":["import * as React from 'react'\nimport useDeepCompareEffect from 'use-deep-compare-effect'\nimport { VerseObjects } from 'scripture-resources-rcl'\nimport { UsfmFileConversionHelpers } from 'word-aligner-rcl'\nimport { ScriptureReference, VerseObjectsType } from '../../types'\nimport { getResourceMessage } from '../../utils'\nimport { Container, Content } from './styled'\n\ninterface Props {\n  /** current reference **/\n  reference: ScriptureReference;\n  /** optional styles to use for reference **/\n  refStyle: any;\n  /** optional styles to use for content **/\n  contentStyle: any;\n  /** language direction to use **/\n  direction: string|undefined;\n  /** verseObjects **/\n  verseObjects: VerseObjectsType|undefined;\n  /** if true then do not display lexicon popover on hover **/\n  disableWordPopover: boolean|undefined;\n  /** object that contains resource loading status or fetching errors */\n  resourceStatus: object|undefined;\n  /** resource that was loaded */\n  resourceLink: string|undefined;\n  /** server */\n  server: string|undefined;\n  /** true if browsing NT */\n  isNT: boolean;\n  /** font size for messages */\n  fontSize: number;\n  /** function to get latest lexicon data */\n  getLexiconData: Function;\n  /** optional function for localization */\n  translate: Function;\n  /** true if in edit mode */\n  editing: boolean;\n  /** callback to set edit mode */\n  setEditing: Function;\n  /** callback to set that verse has changed */\n  setVerseChanged: Function;\n}\n\nconst MessageStyle = {\n  direction: 'ltr',\n  whiteSpace: 'pre-wrap',\n  lineHeight: 'normal',\n  display: 'flex',\n  justifyContent: 'center',\n  alignItems: 'center',\n  height: '100%',\n  width: '100%',\n  fontSize: '16px',\n  fontFamily: 'Noto Sans',\n  fontWeight: 'bold',\n}\n\nconst TextAreaStyle = {\n  height: '60%',\n  width: '100%',\n  minWidth: '220px',\n  fontSize: '16px',\n}\n\nfunction ScripturePane({\n  reference,\n  refStyle,\n  direction,\n  contentStyle,\n  verseObjects,\n  disableWordPopover,\n  resourceStatus,\n  resourceLink,\n  server,\n  isNT,\n  fontSize,\n  getLexiconData,\n  translate,\n  editing,\n  setEditing,\n  setVerseChanged,\n} : Props) {\n  const [initialVerseText, setInitialVerseText] = React.useState(null)\n  const resourceMsg = getResourceMessage(resourceStatus, server, resourceLink, isNT)\n  const { chapter, verse } = reference\n  direction = direction || 'ltr'\n\n  refStyle = refStyle || {\n    fontFamily: 'Noto Sans',\n    fontSize: '90%',\n  }\n\n  contentStyle = contentStyle || {\n    fontFamily: 'Noto Sans',\n    fontSize: '100%',\n  }\n\n  // dynamically adjust font size\n  const calculatedFontSize = React.useMemo(() => (\n    parseFloat(TextAreaStyle.fontSize) * fontSize / 100 + 'px'\n  ), [fontSize])\n\n  const textAreaStyle = {\n    ...contentStyle,\n    ...TextAreaStyle,\n    fontSize: calculatedFontSize,\n  }\n\n  useDeepCompareEffect(() => {\n    const verseText = UsfmFileConversionHelpers.getUsfmForVerseContent({ verseObjects })\n    setInitialVerseText(verseText)\n  }, [{ verseObjects }])\n\n  function onTextChange(event: React.ChangeEvent<HTMLTextAreaElement>) {\n    const newText = event?.target?.value\n    const changed = newText !== initialVerseText\n    setVerseChanged(changed, newText, initialVerseText)\n  }\n\n  function onBlur(event: React.ChangeEvent<HTMLTextAreaElement>) {\n    setEditing(false)\n  }\n\n  return (\n    <Container style={{ direction, width: '100%', paddingBottom: '0.5em'}}>\n      {resourceMsg ?\n        // @ts-ignore\n        <div style={MessageStyle}>\n          <div style={{ fontSize: `${fontSize}%` }}> {resourceMsg} </div>\n        </div>\n        :\n        <Content>\n          <span style={refStyle}> {chapter}:{verse}&nbsp;</span>\n          <span style={contentStyle} onClick={() => {\n            setEditing && setEditing(true)\n          }}\n          >\n            {editing ?\n              <textarea\n                defaultValue={initialVerseText}\n                onChange={onTextChange}\n                onBlur={onBlur}\n                style={textAreaStyle}\n                autoFocus\n              />\n              :\n              <VerseObjects\n                verseKey={`${reference.chapter}:${reference.verse}`}\n                verseObjects={verseObjects || []}\n                disableWordPopover={disableWordPopover}\n                getLexiconData={getLexiconData}\n                translate={translate}\n              />\n            }\n          </span>\n        </Content>\n      }\n    </Container>\n  )\n}\n\nScripturePane.defaultProps = { verseObjects: [] }\n\nexport default ScripturePane\n"]}
|
|
230
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/ScripturePane/ScripturePane.tsx"],"names":["React","useDeepCompareEffect","VerseObjects","UsfmFileConversionHelpers","RxLink2","RxLinkBreak2","IconButton","ScriptureReference","getResourceMessage","ScriptureALignmentEditProps","useScriptureAlignmentEdit","Container","Content","MessageStyle","direction","whiteSpace","lineHeight","display","justifyContent","alignItems","height","width","fontSize","fontFamily","fontWeight","TextAreaStyle","minWidth","ScripturePane","reference","refStyle","currentIndex","contentStyle","disableWordPopover","resourceStatus","resourceLink","server","isNT","getLexiconData","translate","saving","scriptureAlignmentEditConfig","setSavedChanges","setWordAlignerStatus","useState","urlError","doingAlignment","state","setState_","setState","newState","prevState","initialVerseText","setInitialVerseText","resourceMsg","chapter","verse","_scriptureAlignmentEditConfig","_scriptureAlignmentEdit","actions","handleAlignmentClick","setEditing","setVerseChanged","aligned","alignerData","currentVerseObjects","initialVerseObjects","editing","unsavedChanges","newVerseText","useEffect","calculatedFontSize","useMemo","parseFloat","textAreaStyle","verseText","getUsfmForVerseContent","verseObjects","onTextChange","event","newText","target","value","changed","onBlur","checkingState","titleText","paddingBottom","cursor","defaultProps"],"mappings":"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","sourcesContent":["import * as React from 'react'\nimport useDeepCompareEffect from 'use-deep-compare-effect'\nimport { VerseObjects } from 'scripture-resources-rcl'\nimport { UsfmFileConversionHelpers } from 'word-aligner-rcl'\nimport { RxLink2, RxLinkBreak2 } from 'react-icons/rx'\nimport { IconButton } from '@mui/material'\nimport { ScriptureReference } from '../../types'\nimport { getResourceMessage } from '../../utils'\nimport { ScriptureALignmentEditProps, useScriptureAlignmentEdit } from \"../../hooks/useScriptureAlignmentEdit\";\nimport { Container, Content } from './styled'\n\ninterface Props {\n  /** optional styles to use for content **/\n  contentStyle: any;\n  // index number for this scripture pane\n  currentIndex: number,\n  /** language direction to use **/\n  direction: string|undefined;\n  /** if true then do not display lexicon popover on hover **/\n  disableWordPopover: boolean|undefined;\n  /** font size for messages */\n  fontSize: number;\n  /** function to get latest lexicon data */\n  getLexiconData: Function;\n  /** true if browsing NT */\n  isNT: boolean;\n  /** current reference **/\n  reference: ScriptureReference;\n  /** optional styles to use for reference **/\n  refStyle: any;\n  /** object that contains resource loading status or fetching errors */\n  resourceStatus: object|undefined;\n  /** resource that was loaded */\n  resourceLink: string|undefined;\n  /** true if currently saving updated text and alignments */\n  saving: boolean;\n  // initialization for useScriptureAlignmentEdit\n  scriptureAlignmentEditConfig: ScriptureALignmentEditProps,\n  /** server */\n  server: string|undefined;\n  /** callback to flag unsaved status */\n  setSavedChanges: Function;\n  // callback for change in word alignment status\n  setWordAlignerStatus: Function;\n  /** optional function for localization */\n  translate: Function;\n}\n\nconst MessageStyle = {\n  direction: 'ltr',\n  whiteSpace: 'pre-wrap',\n  lineHeight: 'normal',\n  display: 'flex',\n  justifyContent: 'center',\n  alignItems: 'center',\n  height: '100%',\n  width: '100%',\n  fontSize: '16px',\n  fontFamily: 'Noto Sans',\n  fontWeight: 'bold',\n}\n\nconst TextAreaStyle = {\n  height: '60%',\n  width: '100%',\n  minWidth: '220px',\n  fontSize: '16px',\n}\n\nfunction ScripturePane({\n  reference,\n  refStyle,\n  direction,\n  currentIndex,\n  contentStyle,\n  disableWordPopover,\n  resourceStatus,\n  resourceLink,\n  server,\n  isNT,\n  fontSize,\n  getLexiconData,\n  translate,\n  saving,\n  scriptureAlignmentEditConfig,\n  setSavedChanges,\n  setWordAlignerStatus,\n} : Props) {\n  const [state, setState_] = React.useState({\n    urlError: null,\n    doingAlignment: false,\n  })\n  const {\n    urlError,\n    doingAlignment,\n  } = state\n\n  function setState(newState) {\n    setState_(prevState => ({ ...prevState, ...newState }))\n  }\n\n  const [initialVerseText, setInitialVerseText] = React.useState(null)\n  const resourceMsg = saving ? 'Saving Changes...' : getResourceMessage(resourceStatus, server, resourceLink, isNT)\n  const { chapter, verse } = reference\n  direction = direction || 'ltr'\n\n  refStyle = refStyle || {\n    fontFamily: 'Noto Sans',\n    fontSize: '90%',\n  }\n\n  contentStyle = contentStyle || {\n    fontFamily: 'Noto Sans',\n    fontSize: '100%',\n  }\n\n  const _scriptureAlignmentEditConfig = {\n    ...scriptureAlignmentEditConfig,\n    initialVerseText,\n  }\n\n  const _scriptureAlignmentEdit = useScriptureAlignmentEdit(_scriptureAlignmentEditConfig)\n  const {\n    actions: {\n      handleAlignmentClick,\n      setEditing,\n      setVerseChanged,\n    },\n    state: {\n      aligned,\n      alignerData,\n      currentVerseObjects,\n      initialVerseObjects,\n      editing,\n      unsavedChanges,\n      newVerseText,\n    },\n  } = _scriptureAlignmentEdit\n\n  React.useEffect(() => {\n    if (alignerData && !doingAlignment) {\n      setWordAlignerStatus && setWordAlignerStatus(_scriptureAlignmentEdit)\n      setState({ doingAlignment: true })\n    } else if (doingAlignment) {\n      setWordAlignerStatus && setWordAlignerStatus(_scriptureAlignmentEdit)\n      setState({ doingAlignment: false })\n    }\n  }, [_scriptureAlignmentEdit?.state?.alignerData])\n\n  // dynamically adjust font size\n  const calculatedFontSize = React.useMemo(() => (\n    parseFloat(TextAreaStyle.fontSize) * fontSize / 100 + 'px'\n  ), [fontSize])\n\n  const textAreaStyle = {\n    ...contentStyle,\n    ...TextAreaStyle,\n    fontSize: calculatedFontSize,\n  }\n\n  useDeepCompareEffect(() => {\n    const verseText = UsfmFileConversionHelpers.getUsfmForVerseContent({ verseObjects: initialVerseObjects })\n    setInitialVerseText(verseText)\n  }, [{ reference, initialVerseObjects }])\n\n  function onTextChange(event: React.ChangeEvent<HTMLTextAreaElement>) {\n    const newText = event?.target?.value\n    const changed = newText !== initialVerseText\n    setVerseChanged(changed, newText, initialVerseText)\n  }\n\n  function onBlur(event: React.ChangeEvent<HTMLTextAreaElement>) {\n    setEditing(false)\n  }\n\n  const checkingState = aligned ? 'valid' : 'invalid'\n  const titleText = checkingState === 'valid' ? 'Alignment is Valid' : 'Alignment is Invalid'\n\n  return (\n    <Container style={{ direction, width: '100%', paddingBottom: '0.5em'}}>\n      {resourceMsg ?\n        // @ts-ignore\n        <div style={MessageStyle}>\n          <div style={{ fontSize: `${fontSize}%` }}> {resourceMsg} </div>\n        </div>\n        :\n        <Content>\n          <span style={refStyle}> {chapter}:{verse}&nbsp;</span>\n          <span style={contentStyle} onClick={() => {\n            setEditing && setEditing(true)\n          }}\n          >\n            {editing ?\n              <textarea\n                defaultValue={newVerseText || initialVerseText}\n                onChange={onTextChange}\n                onBlur={onBlur}\n                style={textAreaStyle}\n                autoFocus\n              />\n              :\n              <VerseObjects\n                verseKey={`${reference.chapter}:${reference.verse}`}\n                verseObjects={currentVerseObjects || []}\n                disableWordPopover={disableWordPopover}\n                getLexiconData={getLexiconData}\n                translate={translate}\n              />\n            }\n          </span>\n          {setWordAlignerStatus &&\n            <IconButton\n              key='checking-button'\n              onClick={() => handleAlignmentClick()}\n              title={titleText}\n              aria-label={titleText}\n              style={{ cursor: 'pointer' }}\n            >\n              {checkingState === 'valid' ? (\n                <RxLink2 id='valid_icon' color='#BBB' />\n              ) : (\n                <RxLinkBreak2 id='invalid_icon' color='#000' />\n              )}\n            </IconButton>\n          }\n        </Content>\n      }\n    </Container>\n  )\n}\n\nScripturePane.defaultProps = { verseObjects: [] }\n\nexport default ScripturePane\n"]}
|