single-scripture-rcl 3.3.3-patch.3 → 3.3.3-patch.4
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.
- package/dist/components/ScriptureCard/ScriptureCard.js +537 -377
- package/dist/components/ScripturePane/ScripturePane.js +43 -30
- package/dist/hooks/index.js +2 -2
- package/dist/hooks/useScripture.js +388 -112
- package/dist/hooks/useScriptureAlignmentEdit.js +58 -73
- package/dist/hooks/useScriptureResources.js +20 -18
- package/dist/hooks/useScriptureSelector.js +12 -12
- package/dist/hooks/useScriptureSettings.js +35 -39
- package/dist/utils/maps.js +1 -1
- package/package.json +4 -4
|
@@ -25,8 +25,8 @@ import useDeepCompareEffect from 'use-deep-compare-effect';
|
|
|
25
25
|
import { VerseObjects } from 'scripture-resources-rcl';
|
|
26
26
|
import { UsfmFileConversionHelpers } from 'word-aligner-rcl';
|
|
27
27
|
import { ScriptureReference } from '../../types';
|
|
28
|
-
import { getResourceMessage } from '../../utils';
|
|
29
|
-
import { ScriptureALignmentEditProps, useScriptureAlignmentEdit } from
|
|
28
|
+
import { getResourceMessage, LOADING_RESOURCE } from '../../utils';
|
|
29
|
+
import { ScriptureALignmentEditProps, useScriptureAlignmentEdit } from '../../hooks/useScriptureAlignmentEdit';
|
|
30
30
|
import { Container, Content } from './styled';
|
|
31
31
|
var MessageStyle = {
|
|
32
32
|
direction: 'ltr',
|
|
@@ -51,27 +51,28 @@ var TextAreaStyle = {
|
|
|
51
51
|
function ScripturePane(_ref) {
|
|
52
52
|
var _scriptureAlignmentEd3;
|
|
53
53
|
|
|
54
|
-
var
|
|
55
|
-
refStyle = _ref.refStyle,
|
|
56
|
-
direction = _ref.direction,
|
|
57
|
-
currentIndex = _ref.currentIndex,
|
|
54
|
+
var currentIndex = _ref.currentIndex,
|
|
58
55
|
contentStyle = _ref.contentStyle,
|
|
56
|
+
determiningBranch = _ref.determiningBranch,
|
|
57
|
+
direction = _ref.direction,
|
|
59
58
|
disableWordPopover = _ref.disableWordPopover,
|
|
60
|
-
resourceStatus = _ref.resourceStatus,
|
|
61
|
-
resourceLink = _ref.resourceLink,
|
|
62
|
-
server = _ref.server,
|
|
63
|
-
isNT = _ref.isNT,
|
|
64
59
|
fontSize = _ref.fontSize,
|
|
65
60
|
getLexiconData = _ref.getLexiconData,
|
|
66
|
-
|
|
61
|
+
isNT = _ref.isNT,
|
|
62
|
+
isVerseSelectedForAlignment = _ref.isVerseSelectedForAlignment,
|
|
63
|
+
onAlignmentFinish = _ref.onAlignmentFinish,
|
|
64
|
+
originalScriptureBookObjects = _ref.originalScriptureBookObjects,
|
|
65
|
+
reference = _ref.reference,
|
|
66
|
+
refStyle = _ref.refStyle,
|
|
67
|
+
resourceStatus = _ref.resourceStatus,
|
|
68
|
+
resourceLink = _ref.resourceLink,
|
|
67
69
|
saving = _ref.saving,
|
|
68
70
|
scriptureAlignmentEditConfig = _ref.scriptureAlignmentEditConfig,
|
|
69
71
|
setSavedChanges = _ref.setSavedChanges,
|
|
70
72
|
setWordAlignerStatus = _ref.setWordAlignerStatus,
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
updateVersesAlignmentStatus = _ref.updateVersesAlignmentStatus
|
|
74
|
-
setOriginalScriptureResource = _ref.setOriginalScriptureResource;
|
|
73
|
+
server = _ref.server,
|
|
74
|
+
translate = _ref.translate,
|
|
75
|
+
updateVersesAlignmentStatus = _ref.updateVersesAlignmentStatus;
|
|
75
76
|
|
|
76
77
|
var _React$useState = React.useState({
|
|
77
78
|
doingAlignment: false,
|
|
@@ -97,9 +98,19 @@ function ScripturePane(_ref) {
|
|
|
97
98
|
initialVerseText = _React$useState4[0],
|
|
98
99
|
setInitialVerseText = _React$useState4[1];
|
|
99
100
|
|
|
100
|
-
var resourceMsg =
|
|
101
|
+
var resourceMsg = null;
|
|
102
|
+
|
|
103
|
+
if (saving) {
|
|
104
|
+
resourceMsg = 'Saving Changes...';
|
|
105
|
+
} else if (determiningBranch) {
|
|
106
|
+
resourceMsg = 'Pre-' + LOADING_RESOURCE;
|
|
107
|
+
} else {
|
|
108
|
+
resourceMsg = getResourceMessage(resourceStatus, server, resourceLink, isNT);
|
|
109
|
+
}
|
|
110
|
+
|
|
101
111
|
var chapter = reference.chapter,
|
|
102
|
-
verse = reference.verse
|
|
112
|
+
verse = reference.verse,
|
|
113
|
+
projectId = reference.projectId;
|
|
103
114
|
direction = direction || 'ltr';
|
|
104
115
|
refStyle = refStyle || {
|
|
105
116
|
fontFamily: 'Noto Sans',
|
|
@@ -111,12 +122,21 @@ function ScripturePane(_ref) {
|
|
|
111
122
|
};
|
|
112
123
|
|
|
113
124
|
var _scriptureAlignmentEditConfig = _objectSpread(_objectSpread({}, scriptureAlignmentEditConfig), {}, {
|
|
114
|
-
initialVerseText: initialVerseText
|
|
125
|
+
initialVerseText: initialVerseText,
|
|
126
|
+
originalScriptureBookObjects: originalScriptureBookObjects
|
|
115
127
|
});
|
|
116
128
|
|
|
129
|
+
React.useEffect(function () {
|
|
130
|
+
console.log("ScripturePane: determiningBranch is ".concat(determiningBranch), {
|
|
131
|
+
reference: reference,
|
|
132
|
+
resourceLink: resourceLink
|
|
133
|
+
});
|
|
134
|
+
}, [determiningBranch]);
|
|
135
|
+
|
|
117
136
|
var _scriptureAlignmentEdit = useScriptureAlignmentEdit(_scriptureAlignmentEditConfig);
|
|
118
137
|
|
|
119
138
|
var _scriptureAlignmentEd = _scriptureAlignmentEdit.actions,
|
|
139
|
+
clearChanges = _scriptureAlignmentEd.clearChanges,
|
|
120
140
|
handleAlignmentClick = _scriptureAlignmentEd.handleAlignmentClick,
|
|
121
141
|
setEditing = _scriptureAlignmentEd.setEditing,
|
|
122
142
|
setVerseChanged = _scriptureAlignmentEd.setVerseChanged,
|
|
@@ -127,21 +147,15 @@ function ScripturePane(_ref) {
|
|
|
127
147
|
initialVerseObjects = _scriptureAlignmentEd2.initialVerseObjects,
|
|
128
148
|
editing = _scriptureAlignmentEd2.editing,
|
|
129
149
|
unsavedChanges = _scriptureAlignmentEd2.unsavedChanges,
|
|
130
|
-
newVerseText = _scriptureAlignmentEd2.newVerseText
|
|
131
|
-
originalScriptureResource = _scriptureAlignmentEd2.originalScriptureResource;
|
|
150
|
+
newVerseText = _scriptureAlignmentEd2.newVerseText;
|
|
132
151
|
|
|
133
152
|
if (isVerseSelectedForAlignment && !alignerData && !doingAlignment) {
|
|
134
153
|
handleAlignmentClick();
|
|
135
154
|
}
|
|
136
155
|
|
|
137
156
|
React.useEffect(function () {
|
|
138
|
-
updateVersesAlignmentStatus(reference, aligned);
|
|
139
|
-
}, [aligned]);
|
|
140
|
-
React.useEffect(function () {
|
|
141
|
-
if (originalScriptureResource) {
|
|
142
|
-
setOriginalScriptureResource && setOriginalScriptureResource(originalScriptureResource);
|
|
143
|
-
}
|
|
144
|
-
}, [originalScriptureResource]);
|
|
157
|
+
updateVersesAlignmentStatus && updateVersesAlignmentStatus(reference, aligned);
|
|
158
|
+
}, [aligned, chapter, verse, projectId]);
|
|
145
159
|
React.useEffect(function () {
|
|
146
160
|
if (alignerData && !doingAlignment) {
|
|
147
161
|
setWordAlignerStatus && setWordAlignerStatus(_scriptureAlignmentEdit);
|
|
@@ -169,6 +183,7 @@ function ScripturePane(_ref) {
|
|
|
169
183
|
var verseText = UsfmFileConversionHelpers.getUsfmForVerseContent({
|
|
170
184
|
verseObjects: initialVerseObjects
|
|
171
185
|
});
|
|
186
|
+
clearChanges();
|
|
172
187
|
setInitialVerseText(verseText);
|
|
173
188
|
}, [{
|
|
174
189
|
reference: reference,
|
|
@@ -191,8 +206,6 @@ function ScripturePane(_ref) {
|
|
|
191
206
|
setEditing(false, newText);
|
|
192
207
|
}
|
|
193
208
|
|
|
194
|
-
var checkingState = aligned ? 'valid' : 'invalid';
|
|
195
|
-
var titleText = checkingState === 'valid' ? 'Alignment is Valid' : 'Alignment is Invalid';
|
|
196
209
|
return /*#__PURE__*/React.createElement(Container, {
|
|
197
210
|
style: {
|
|
198
211
|
direction: direction,
|
|
@@ -234,4 +247,4 @@ ScripturePane.defaultProps = {
|
|
|
234
247
|
verseObjects: []
|
|
235
248
|
};
|
|
236
249
|
export default ScripturePane;
|
|
237
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/ScripturePane/ScripturePane.tsx"],"names":["React","useDeepCompareEffect","VerseObjects","UsfmFileConversionHelpers","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","isVerseSelectedForAlignment","onAlignmentFinish","updateVersesAlignmentStatus","setOriginalScriptureResource","useState","doingAlignment","newText","urlError","state","setState_","setState","newState","prevState","initialVerseText","setInitialVerseText","resourceMsg","chapter","verse","_scriptureAlignmentEditConfig","_scriptureAlignmentEdit","actions","handleAlignmentClick","setEditing","setVerseChanged","aligned","alignerData","currentVerseObjects","initialVerseObjects","editing","unsavedChanges","newVerseText","originalScriptureResource","useEffect","calculatedFontSize","useMemo","parseFloat","textAreaStyle","verseText","getUsfmForVerseContent","verseObjects","onTextChange","event","target","value","changed","onBlur","checkingState","titleText","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 } 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  /** whether or not this current verse has been selected for alignment */\n  isVerseSelectedForAlignment: boolean;\n  /** function to be called when verse alignment has finished */\n  onAlignmentFinish: Function;\n  /** function to be called to update verse alignment status */\n  updateVersesAlignmentStatus: Function;\n  /** This is a callback for original scripture resource */\n  setOriginalScriptureResource: 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  isVerseSelectedForAlignment,\n  onAlignmentFinish,\n  updateVersesAlignmentStatus,\n  setOriginalScriptureResource,\n} : Props) {\n  const [state, setState_] = React.useState({\n    doingAlignment: false,\n    newText: null,\n    urlError: null,\n  })\n  const {\n    doingAlignment,\n    newText,\n    urlError,\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      originalScriptureResource,\n    },\n  } = _scriptureAlignmentEdit\n\n  if (isVerseSelectedForAlignment && !alignerData && !doingAlignment) {\n    handleAlignmentClick()\n  }\n\n  React.useEffect(() => {\n    updateVersesAlignmentStatus(reference, aligned)\n  }, [aligned])\n\n  React.useEffect(() => {\n    if (originalScriptureResource) {\n      setOriginalScriptureResource && setOriginalScriptureResource(originalScriptureResource)\n    }\n  },[originalScriptureResource])\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      onAlignmentFinish && onAlignmentFinish()\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 newVerseText = event?.target?.value\n    const changed = newVerseText !== initialVerseText\n    // console.log(`SP.onTextChange`, { changed, newText: newVerseText, initialVerseText })\n    setVerseChanged(changed, newVerseText, initialVerseText)\n    setState({ newText: newVerseText })\n  }\n\n  function onBlur(event: React.ChangeEvent<HTMLTextAreaElement>) {\n    setEditing(false, newText)\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 || initialVerseObjects}\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"]}
|
|
250
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/ScripturePane/ScripturePane.tsx"],"names":["React","useDeepCompareEffect","VerseObjects","UsfmFileConversionHelpers","ScriptureReference","getResourceMessage","LOADING_RESOURCE","ScriptureALignmentEditProps","useScriptureAlignmentEdit","Container","Content","MessageStyle","direction","whiteSpace","lineHeight","display","justifyContent","alignItems","height","width","fontSize","fontFamily","fontWeight","TextAreaStyle","minWidth","ScripturePane","currentIndex","contentStyle","determiningBranch","disableWordPopover","getLexiconData","isNT","isVerseSelectedForAlignment","onAlignmentFinish","originalScriptureBookObjects","reference","refStyle","resourceStatus","resourceLink","saving","scriptureAlignmentEditConfig","setSavedChanges","setWordAlignerStatus","server","translate","updateVersesAlignmentStatus","useState","doingAlignment","newText","urlError","state","setState_","setState","newState","prevState","initialVerseText","setInitialVerseText","resourceMsg","chapter","verse","projectId","_scriptureAlignmentEditConfig","useEffect","console","log","_scriptureAlignmentEdit","actions","clearChanges","handleAlignmentClick","setEditing","setVerseChanged","aligned","alignerData","currentVerseObjects","initialVerseObjects","editing","unsavedChanges","newVerseText","calculatedFontSize","useMemo","parseFloat","textAreaStyle","verseText","getUsfmForVerseContent","verseObjects","onTextChange","event","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 } from '../../types'\nimport { getResourceMessage, LOADING_RESOURCE } 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  // waiting to determine branch\n  determiningBranch: boolean,\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  /** whether or not this current verse has been selected for alignment */\n  isVerseSelectedForAlignment: boolean;\n  /** function to be called when verse alignment has finished */\n  onAlignmentFinish: Function;\n  // original scripture bookObjects for current book\n  originalScriptureBookObjects: object,\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  /** function to be called to update verse alignment status */\n  updateVersesAlignmentStatus: 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  currentIndex,\n  contentStyle,\n  determiningBranch,\n  direction,\n  disableWordPopover,\n  fontSize,\n  getLexiconData,\n  isNT,\n  isVerseSelectedForAlignment,\n  onAlignmentFinish,\n  originalScriptureBookObjects,\n  reference,\n  refStyle,\n  resourceStatus,\n  resourceLink,\n  saving,\n  scriptureAlignmentEditConfig,\n  setSavedChanges,\n  setWordAlignerStatus,\n  server,\n  translate,\n  updateVersesAlignmentStatus,\n} : Props) {\n  const [state, setState_] = React.useState({\n    doingAlignment: false,\n    newText: null,\n    urlError: null,\n  })\n  const {\n    doingAlignment,\n    newText,\n    urlError,\n  } = state\n\n  function setState(newState) {\n    setState_(prevState => ({ ...prevState, ...newState }))\n  }\n\n  const [initialVerseText, setInitialVerseText] = React.useState(null)\n\n  let resourceMsg = null\n\n  if (saving) {\n    resourceMsg = 'Saving Changes...'\n  } else if (determiningBranch) {\n    resourceMsg = 'Pre-' + LOADING_RESOURCE\n  } else {\n    resourceMsg = getResourceMessage(resourceStatus, server, resourceLink, isNT)\n  }\n\n  const {\n    chapter,\n    verse,\n    projectId,\n  } = 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    originalScriptureBookObjects,\n  }\n\n  React.useEffect(() => {\n    console.log(`ScripturePane: determiningBranch is ${determiningBranch}`, { reference, resourceLink })\n  }, [determiningBranch])\n\n  const _scriptureAlignmentEdit = useScriptureAlignmentEdit(_scriptureAlignmentEditConfig)\n  const {\n    actions: {\n      clearChanges,\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  if (isVerseSelectedForAlignment && !alignerData && !doingAlignment) {\n    handleAlignmentClick()\n  }\n\n  React.useEffect(() => {\n    updateVersesAlignmentStatus && updateVersesAlignmentStatus(reference, aligned)\n  }, [aligned, chapter, verse, projectId])\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      onAlignmentFinish && onAlignmentFinish()\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    clearChanges()\n    setInitialVerseText(verseText)\n  }, [{ reference, initialVerseObjects }])\n\n  function onTextChange(event: React.ChangeEvent<HTMLTextAreaElement>) {\n    const newVerseText = event?.target?.value\n    const changed = newVerseText !== initialVerseText\n    // console.log(`SP.onTextChange`, { changed, newText: newVerseText, initialVerseText })\n    setVerseChanged(changed, newVerseText, initialVerseText)\n    setState({ newText: newVerseText })\n  }\n\n  function onBlur(event: React.ChangeEvent<HTMLTextAreaElement>) {\n    setEditing(false, newText)\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={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 || initialVerseObjects}\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"]}
|
package/dist/hooks/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export { useComboBox } from './useComboBox';
|
|
2
2
|
export { parseResourceManifest } from './parseResourceManifest';
|
|
3
|
-
export { useScripture } from './useScripture';
|
|
3
|
+
export { getVersesForRef, getVersesForRefStr, useScripture } from './useScripture';
|
|
4
4
|
export { useScriptureResources } from './useScriptureResources';
|
|
5
5
|
export { useScriptureSelector } from './useScriptureSelector';
|
|
6
6
|
export { useScriptureSettings } from './useScriptureSettings';
|
|
7
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
7
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ob29rcy9pbmRleC50c3giXSwibmFtZXMiOlsidXNlQ29tYm9Cb3giLCJwYXJzZVJlc291cmNlTWFuaWZlc3QiLCJnZXRWZXJzZXNGb3JSZWYiLCJnZXRWZXJzZXNGb3JSZWZTdHIiLCJ1c2VTY3JpcHR1cmUiLCJ1c2VTY3JpcHR1cmVSZXNvdXJjZXMiLCJ1c2VTY3JpcHR1cmVTZWxlY3RvciIsInVzZVNjcmlwdHVyZVNldHRpbmdzIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxXQUFULFFBQTRCLGVBQTVCO0FBQ0EsU0FBU0MscUJBQVQsUUFBc0MseUJBQXRDO0FBQ0EsU0FDRUMsZUFERixFQUVFQyxrQkFGRixFQUdFQyxZQUhGLFFBSU8sZ0JBSlA7QUFLQSxTQUFTQyxxQkFBVCxRQUFzQyx5QkFBdEM7QUFDQSxTQUFTQyxvQkFBVCxRQUFxQyx3QkFBckM7QUFDQSxTQUFTQyxvQkFBVCxRQUFxQyx3QkFBckMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyB1c2VDb21ib0JveCB9IGZyb20gJy4vdXNlQ29tYm9Cb3gnXG5leHBvcnQgeyBwYXJzZVJlc291cmNlTWFuaWZlc3QgfSBmcm9tICcuL3BhcnNlUmVzb3VyY2VNYW5pZmVzdCdcbmV4cG9ydCB7XG4gIGdldFZlcnNlc0ZvclJlZixcbiAgZ2V0VmVyc2VzRm9yUmVmU3RyLFxuICB1c2VTY3JpcHR1cmUsXG59IGZyb20gJy4vdXNlU2NyaXB0dXJlJ1xuZXhwb3J0IHsgdXNlU2NyaXB0dXJlUmVzb3VyY2VzIH0gZnJvbSAnLi91c2VTY3JpcHR1cmVSZXNvdXJjZXMnXG5leHBvcnQgeyB1c2VTY3JpcHR1cmVTZWxlY3RvciB9IGZyb20gJy4vdXNlU2NyaXB0dXJlU2VsZWN0b3InXG5leHBvcnQgeyB1c2VTY3JpcHR1cmVTZXR0aW5ncyB9IGZyb20gJy4vdXNlU2NyaXB0dXJlU2V0dGluZ3MnXG4iXX0=
|