single-scripture-rcl 3.3.3-patch.2 → 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.
@@ -24,11 +24,9 @@ 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 { RxLink2, RxLinkBreak2 } from 'react-icons/rx';
28
- import { IconButton } from '@mui/material';
29
27
  import { ScriptureReference } from '../../types';
30
- import { getResourceMessage } from '../../utils';
31
- import { ScriptureALignmentEditProps, useScriptureAlignmentEdit } from "../../hooks/useScriptureAlignmentEdit";
28
+ import { getResourceMessage, LOADING_RESOURCE } from '../../utils';
29
+ import { ScriptureALignmentEditProps, useScriptureAlignmentEdit } from '../../hooks/useScriptureAlignmentEdit';
32
30
  import { Container, Content } from './styled';
33
31
  var MessageStyle = {
34
32
  direction: 'ltr',
@@ -53,24 +51,28 @@ var TextAreaStyle = {
53
51
  function ScripturePane(_ref) {
54
52
  var _scriptureAlignmentEd3;
55
53
 
56
- var reference = _ref.reference,
57
- refStyle = _ref.refStyle,
58
- direction = _ref.direction,
59
- currentIndex = _ref.currentIndex,
54
+ var currentIndex = _ref.currentIndex,
60
55
  contentStyle = _ref.contentStyle,
56
+ determiningBranch = _ref.determiningBranch,
57
+ direction = _ref.direction,
61
58
  disableWordPopover = _ref.disableWordPopover,
62
- resourceStatus = _ref.resourceStatus,
63
- resourceLink = _ref.resourceLink,
64
- server = _ref.server,
65
- isNT = _ref.isNT,
66
59
  fontSize = _ref.fontSize,
67
60
  getLexiconData = _ref.getLexiconData,
68
- translate = _ref.translate,
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,
69
69
  saving = _ref.saving,
70
70
  scriptureAlignmentEditConfig = _ref.scriptureAlignmentEditConfig,
71
71
  setSavedChanges = _ref.setSavedChanges,
72
72
  setWordAlignerStatus = _ref.setWordAlignerStatus,
73
- setOriginalScriptureResource = _ref.setOriginalScriptureResource;
73
+ server = _ref.server,
74
+ translate = _ref.translate,
75
+ updateVersesAlignmentStatus = _ref.updateVersesAlignmentStatus;
74
76
 
75
77
  var _React$useState = React.useState({
76
78
  doingAlignment: false,
@@ -96,9 +98,19 @@ function ScripturePane(_ref) {
96
98
  initialVerseText = _React$useState4[0],
97
99
  setInitialVerseText = _React$useState4[1];
98
100
 
99
- var resourceMsg = saving ? 'Saving Changes...' : getResourceMessage(resourceStatus, server, resourceLink, isNT);
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
+
100
111
  var chapter = reference.chapter,
101
- verse = reference.verse;
112
+ verse = reference.verse,
113
+ projectId = reference.projectId;
102
114
  direction = direction || 'ltr';
103
115
  refStyle = refStyle || {
104
116
  fontFamily: 'Noto Sans',
@@ -110,12 +122,21 @@ function ScripturePane(_ref) {
110
122
  };
111
123
 
112
124
  var _scriptureAlignmentEditConfig = _objectSpread(_objectSpread({}, scriptureAlignmentEditConfig), {}, {
113
- initialVerseText: initialVerseText
125
+ initialVerseText: initialVerseText,
126
+ originalScriptureBookObjects: originalScriptureBookObjects
114
127
  });
115
128
 
129
+ React.useEffect(function () {
130
+ console.log("ScripturePane: determiningBranch is ".concat(determiningBranch), {
131
+ reference: reference,
132
+ resourceLink: resourceLink
133
+ });
134
+ }, [determiningBranch]);
135
+
116
136
  var _scriptureAlignmentEdit = useScriptureAlignmentEdit(_scriptureAlignmentEditConfig);
117
137
 
118
138
  var _scriptureAlignmentEd = _scriptureAlignmentEdit.actions,
139
+ clearChanges = _scriptureAlignmentEd.clearChanges,
119
140
  handleAlignmentClick = _scriptureAlignmentEd.handleAlignmentClick,
120
141
  setEditing = _scriptureAlignmentEd.setEditing,
121
142
  setVerseChanged = _scriptureAlignmentEd.setVerseChanged,
@@ -126,13 +147,15 @@ function ScripturePane(_ref) {
126
147
  initialVerseObjects = _scriptureAlignmentEd2.initialVerseObjects,
127
148
  editing = _scriptureAlignmentEd2.editing,
128
149
  unsavedChanges = _scriptureAlignmentEd2.unsavedChanges,
129
- newVerseText = _scriptureAlignmentEd2.newVerseText,
130
- originalScriptureResource = _scriptureAlignmentEd2.originalScriptureResource;
150
+ newVerseText = _scriptureAlignmentEd2.newVerseText;
151
+
152
+ if (isVerseSelectedForAlignment && !alignerData && !doingAlignment) {
153
+ handleAlignmentClick();
154
+ }
155
+
131
156
  React.useEffect(function () {
132
- if (originalScriptureResource) {
133
- setOriginalScriptureResource && setOriginalScriptureResource(originalScriptureResource);
134
- }
135
- }, [originalScriptureResource]);
157
+ updateVersesAlignmentStatus && updateVersesAlignmentStatus(reference, aligned);
158
+ }, [aligned, chapter, verse, projectId]);
136
159
  React.useEffect(function () {
137
160
  if (alignerData && !doingAlignment) {
138
161
  setWordAlignerStatus && setWordAlignerStatus(_scriptureAlignmentEdit);
@@ -144,6 +167,7 @@ function ScripturePane(_ref) {
144
167
  setState({
145
168
  doingAlignment: false
146
169
  });
170
+ onAlignmentFinish && onAlignmentFinish();
147
171
  }
148
172
  }, [_scriptureAlignmentEdit === null || _scriptureAlignmentEdit === void 0 ? void 0 : (_scriptureAlignmentEd3 = _scriptureAlignmentEdit.state) === null || _scriptureAlignmentEd3 === void 0 ? void 0 : _scriptureAlignmentEd3.alignerData]); // dynamically adjust font size
149
173
 
@@ -159,6 +183,7 @@ function ScripturePane(_ref) {
159
183
  var verseText = UsfmFileConversionHelpers.getUsfmForVerseContent({
160
184
  verseObjects: initialVerseObjects
161
185
  });
186
+ clearChanges();
162
187
  setInitialVerseText(verseText);
163
188
  }, [{
164
189
  reference: reference,
@@ -181,8 +206,6 @@ function ScripturePane(_ref) {
181
206
  setEditing(false, newText);
182
207
  }
183
208
 
184
- var checkingState = aligned ? 'valid' : 'invalid';
185
- var titleText = checkingState === 'valid' ? 'Alignment is Valid' : 'Alignment is Invalid';
186
209
  return /*#__PURE__*/React.createElement(Container, {
187
210
  style: {
188
211
  direction: direction,
@@ -217,25 +240,6 @@ function ScripturePane(_ref) {
217
240
  disableWordPopover: disableWordPopover,
218
241
  getLexiconData: getLexiconData,
219
242
  translate: translate
220
- })), setWordAlignerStatus &&
221
- /*#__PURE__*/
222
- //add scriptureAlignmentEditConfig?.enableAlignment
223
- React.createElement(IconButton, {
224
- key: "checking-button",
225
- onClick: function onClick() {
226
- return handleAlignmentClick();
227
- },
228
- title: titleText,
229
- "aria-label": titleText,
230
- style: {
231
- cursor: 'pointer'
232
- }
233
- }, checkingState === 'valid' ? /*#__PURE__*/React.createElement(RxLink2, {
234
- id: "valid_icon",
235
- color: "#BBB"
236
- }) : /*#__PURE__*/React.createElement(RxLinkBreak2, {
237
- id: "invalid_icon",
238
- color: "#000"
239
243
  }))));
240
244
  }
241
245
 
@@ -243,4 +247,4 @@ ScripturePane.defaultProps = {
243
247
  verseObjects: []
244
248
  };
245
249
  export default ScripturePane;
246
- //# 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","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","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  /** 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  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  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    }\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          {setWordAlignerStatus && //add scriptureAlignmentEditConfig?.enableAlignment \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"]}
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"]}
@@ -0,0 +1,104 @@
1
+ import "core-js/modules/es.array.concat.js";
2
+ import "core-js/modules/es.array.map.js";
3
+ import * as React from 'react';
4
+ import { makeStyles } from '@material-ui/core/styles';
5
+ import { DraggableCard } from 'translation-helps-rcl';
6
+ import Box from '@mui/material/Box';
7
+ import List from '@mui/material/List';
8
+ import ListItem from '@mui/material/ListItem';
9
+ import ListItemButton from '@mui/material/ListItemButton';
10
+ import ListItemIcon from '@mui/material/ListItemIcon';
11
+ import ListItemText from '@mui/material/ListItemText';
12
+ import { RxLink2, RxLinkBreak2 } from 'react-icons/rx';
13
+ var useStyles = makeStyles(function (theme) {
14
+ return {
15
+ wrapper: {
16
+ display: 'flex',
17
+ flexDirection: 'column'
18
+ },
19
+ list: {
20
+ paddingTop: theme.spacing(1),
21
+ paddingBottom: theme.spacing(1)
22
+ },
23
+ button: {
24
+ marginTop: theme.spacing(1),
25
+ marginBottom: theme.spacing(1),
26
+ alignSelf: 'flex-end'
27
+ }
28
+ };
29
+ });
30
+
31
+ var VerseSelectorContent = function VerseSelectorContent(_ref) {
32
+ var resourceId = _ref.resourceId,
33
+ versesForRef = _ref.versesForRef,
34
+ versesAlignmentStatus = _ref.versesAlignmentStatus,
35
+ onVerseSelect = _ref.onVerseSelect;
36
+ var renderedVerseItems = versesForRef.map(function (verse) {
37
+ var isVerseAligned = versesAlignmentStatus === null || versesAlignmentStatus === void 0 ? void 0 : versesAlignmentStatus["".concat(verse.chapter, ":").concat(verse.verse)];
38
+ var alignIcon = null;
39
+
40
+ if (isVerseAligned) {
41
+ alignIcon = /*#__PURE__*/React.createElement(RxLink2, {
42
+ id: "valid_icon_".concat(resourceId),
43
+ color: "#BBB",
44
+ size: 24
45
+ });
46
+ } else {
47
+ alignIcon = /*#__PURE__*/React.createElement(RxLinkBreak2, {
48
+ id: "invalid_alignment_icon_".concat(resourceId),
49
+ color: "#000",
50
+ size: 24
51
+ });
52
+ }
53
+
54
+ return /*#__PURE__*/React.createElement(ListItem, {
55
+ disablePadding: true,
56
+ id: "verse-".concat(verse.chapter, ":").concat(verse.verse),
57
+ key: "verse-".concat(verse.chapter, ":").concat(verse.verse),
58
+ onClick: function onClick(event) {
59
+ onVerseSelect(verse);
60
+ }
61
+ }, /*#__PURE__*/React.createElement(ListItemButton, null, /*#__PURE__*/React.createElement(ListItemIcon, null, alignIcon), /*#__PURE__*/React.createElement(ListItemText, {
62
+ primary: "".concat(verse.chapter, ":").concat(verse.verse)
63
+ })));
64
+ });
65
+ return /*#__PURE__*/React.createElement(Box, {
66
+ id: "verse-list-".concat(resourceId),
67
+ sx: {
68
+ minWidth: '360px',
69
+ maxWidth: '600px',
70
+ bgcolor: 'background.paper'
71
+ }
72
+ }, /*#__PURE__*/React.createElement(List, null, renderedVerseItems));
73
+ };
74
+
75
+ var VerseSelectorPopup = function VerseSelectorPopup(_ref2) {
76
+ var resourceId = _ref2.resourceId,
77
+ versesForRef = _ref2.versesForRef,
78
+ versesAlignmentStatus = _ref2.versesAlignmentStatus,
79
+ onVerseSelect = _ref2.onVerseSelect,
80
+ open = _ref2.open,
81
+ onClose = _ref2.onClose;
82
+ return /*#__PURE__*/React.createElement(DraggableCard, {
83
+ id: "verse-selector-popup-".concat(resourceId),
84
+ title: "Select Verse to Align",
85
+ open: open,
86
+ showRawContent: true,
87
+ initialPosition: {
88
+ x: 0,
89
+ y: -10
90
+ } // workspaceRef={mainScreenRef}
91
+ ,
92
+ onClose: onClose,
93
+ dimBackground: true,
94
+ content: /*#__PURE__*/React.createElement(VerseSelectorContent, {
95
+ resourceId: resourceId,
96
+ versesForRef: versesForRef,
97
+ versesAlignmentStatus: versesAlignmentStatus,
98
+ onVerseSelect: onVerseSelect
99
+ })
100
+ });
101
+ };
102
+
103
+ export default VerseSelectorPopup;
104
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/VerseSelectorPopup/VerseSelectorPopup.tsx"],"names":["React","makeStyles","DraggableCard","Box","List","ListItem","ListItemButton","ListItemIcon","ListItemText","RxLink2","RxLinkBreak2","useStyles","theme","wrapper","display","flexDirection","list","paddingTop","spacing","paddingBottom","button","marginTop","marginBottom","alignSelf","VerseSelectorContent","resourceId","versesForRef","versesAlignmentStatus","onVerseSelect","renderedVerseItems","map","verse","isVerseAligned","chapter","alignIcon","event","minWidth","maxWidth","bgcolor","VerseSelectorPopup","open","onClose","x","y"],"mappings":"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","sourcesContent":["import * as React from 'react'\nimport { makeStyles } from '@material-ui/core/styles'\nimport { DraggableCard } from 'translation-helps-rcl'\nimport Box from '@mui/material/Box';\nimport List from '@mui/material/List';\nimport ListItem from '@mui/material/ListItem';\nimport ListItemButton from '@mui/material/ListItemButton';\nimport ListItemIcon from '@mui/material/ListItemIcon';\nimport ListItemText from '@mui/material/ListItemText';\nimport { RxLink2, RxLinkBreak2 } from 'react-icons/rx'\n\nconst useStyles = makeStyles(theme => ({\n  wrapper: {\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  list: {\n    paddingTop: theme.spacing(1),\n    paddingBottom: theme.spacing(1),\n  },\n  button: {\n    marginTop: theme.spacing(1),\n    marginBottom: theme.spacing(1),\n    alignSelf: 'flex-end',\n  },\n}))\n\nconst VerseSelectorContent = ({\n  resourceId,\n  versesForRef,\n  versesAlignmentStatus,\n  onVerseSelect,\n}) => {\n\n  const renderedVerseItems = versesForRef.map(verse => {\n    const isVerseAligned = versesAlignmentStatus?.[`${verse.chapter}:${verse.verse}`]\n    let alignIcon = null\n    if (isVerseAligned) {\n      alignIcon = <RxLink2 id={`valid_icon_${resourceId}`} color='#BBB' size={24} />\n    } else {\n      alignIcon = <RxLinkBreak2 id={`invalid_alignment_icon_${resourceId}`} color='#000' size={24} />\n    }\n\n    return (\n      <ListItem\n        disablePadding\n        id={`verse-${verse.chapter}:${verse.verse}`}\n        key={`verse-${verse.chapter}:${verse.verse}`}\n        onClick={(event) => {onVerseSelect(verse)}}\n      >\n        <ListItemButton>\n          <ListItemIcon>\n            {alignIcon}\n          </ListItemIcon>\n          <ListItemText primary={`${verse.chapter}:${verse.verse}`} />\n        </ListItemButton>\n      </ListItem>\n    )\n  })\n\n  return (\n    <Box id={`verse-list-${resourceId}`} sx={{ minWidth: '360px',maxWidth: '600px', bgcolor: 'background.paper' }}>\n      <List>\n        {renderedVerseItems}\n      </List>\n    </Box>\n  )\n}\n\nconst VerseSelectorPopup = ({ resourceId, versesForRef, versesAlignmentStatus, onVerseSelect, open, onClose }) => {\n  return (\n\n    <DraggableCard\n      id={`verse-selector-popup-${resourceId}`}\n      title=\"Select Verse to Align\"\n      open={open}\n      showRawContent\n      initialPosition={{ x: 0, y: -10 }}\n      // workspaceRef={mainScreenRef}\n      onClose={onClose}\n      dimBackground={true}\n      content={\n        <VerseSelectorContent\n          resourceId={resourceId}\n          versesForRef={versesForRef}\n          versesAlignmentStatus={versesAlignmentStatus}\n          onVerseSelect={onVerseSelect}\n        />\n      }\n    />\n  )\n}\n\nexport default VerseSelectorPopup\n"]}
@@ -0,0 +1,2 @@
1
+ export { default as VerseSelectorPopup } from './VerseSelectorPopup';
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1ZlcnNlU2VsZWN0b3JQb3B1cC9pbmRleC50cyJdLCJuYW1lcyI6WyJkZWZhdWx0IiwiVmVyc2VTZWxlY3RvclBvcHVwIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxPQUFPLElBQUlDLGtCQUFwQixRQUE4QyxzQkFBOUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBkZWZhdWx0IGFzIFZlcnNlU2VsZWN0b3JQb3B1cCB9IGZyb20gJy4vVmVyc2VTZWxlY3RvclBvcHVwJ1xuIl19
@@ -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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ob29rcy9pbmRleC50c3giXSwibmFtZXMiOlsidXNlQ29tYm9Cb3giLCJwYXJzZVJlc291cmNlTWFuaWZlc3QiLCJ1c2VTY3JpcHR1cmUiLCJ1c2VTY3JpcHR1cmVSZXNvdXJjZXMiLCJ1c2VTY3JpcHR1cmVTZWxlY3RvciIsInVzZVNjcmlwdHVyZVNldHRpbmdzIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxXQUFULFFBQTRCLGVBQTVCO0FBQ0EsU0FBU0MscUJBQVQsUUFBc0MseUJBQXRDO0FBQ0EsU0FBU0MsWUFBVCxRQUE2QixnQkFBN0I7QUFDQSxTQUFTQyxxQkFBVCxRQUFzQyx5QkFBdEM7QUFDQSxTQUFTQyxvQkFBVCxRQUFxQyx3QkFBckM7QUFDQSxTQUFTQyxvQkFBVCxRQUFxQyx3QkFBckMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyB1c2VDb21ib0JveCB9IGZyb20gJy4vdXNlQ29tYm9Cb3gnXG5leHBvcnQgeyBwYXJzZVJlc291cmNlTWFuaWZlc3QgfSBmcm9tICcuL3BhcnNlUmVzb3VyY2VNYW5pZmVzdCdcbmV4cG9ydCB7IHVzZVNjcmlwdHVyZSB9IGZyb20gJy4vdXNlU2NyaXB0dXJlJ1xuZXhwb3J0IHsgdXNlU2NyaXB0dXJlUmVzb3VyY2VzIH0gZnJvbSAnLi91c2VTY3JpcHR1cmVSZXNvdXJjZXMnXG5leHBvcnQgeyB1c2VTY3JpcHR1cmVTZWxlY3RvciB9IGZyb20gJy4vdXNlU2NyaXB0dXJlU2VsZWN0b3InXG5leHBvcnQgeyB1c2VTY3JpcHR1cmVTZXR0aW5ncyB9IGZyb20gJy4vdXNlU2NyaXB0dXJlU2V0dGluZ3MnXG4iXX0=
7
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ob29rcy9pbmRleC50c3giXSwibmFtZXMiOlsidXNlQ29tYm9Cb3giLCJwYXJzZVJlc291cmNlTWFuaWZlc3QiLCJnZXRWZXJzZXNGb3JSZWYiLCJnZXRWZXJzZXNGb3JSZWZTdHIiLCJ1c2VTY3JpcHR1cmUiLCJ1c2VTY3JpcHR1cmVSZXNvdXJjZXMiLCJ1c2VTY3JpcHR1cmVTZWxlY3RvciIsInVzZVNjcmlwdHVyZVNldHRpbmdzIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxXQUFULFFBQTRCLGVBQTVCO0FBQ0EsU0FBU0MscUJBQVQsUUFBc0MseUJBQXRDO0FBQ0EsU0FDRUMsZUFERixFQUVFQyxrQkFGRixFQUdFQyxZQUhGLFFBSU8sZ0JBSlA7QUFLQSxTQUFTQyxxQkFBVCxRQUFzQyx5QkFBdEM7QUFDQSxTQUFTQyxvQkFBVCxRQUFxQyx3QkFBckM7QUFDQSxTQUFTQyxvQkFBVCxRQUFxQyx3QkFBckMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyB1c2VDb21ib0JveCB9IGZyb20gJy4vdXNlQ29tYm9Cb3gnXG5leHBvcnQgeyBwYXJzZVJlc291cmNlTWFuaWZlc3QgfSBmcm9tICcuL3BhcnNlUmVzb3VyY2VNYW5pZmVzdCdcbmV4cG9ydCB7XG4gIGdldFZlcnNlc0ZvclJlZixcbiAgZ2V0VmVyc2VzRm9yUmVmU3RyLFxuICB1c2VTY3JpcHR1cmUsXG59IGZyb20gJy4vdXNlU2NyaXB0dXJlJ1xuZXhwb3J0IHsgdXNlU2NyaXB0dXJlUmVzb3VyY2VzIH0gZnJvbSAnLi91c2VTY3JpcHR1cmVSZXNvdXJjZXMnXG5leHBvcnQgeyB1c2VTY3JpcHR1cmVTZWxlY3RvciB9IGZyb20gJy4vdXNlU2NyaXB0dXJlU2VsZWN0b3InXG5leHBvcnQgeyB1c2VTY3JpcHR1cmVTZXR0aW5ncyB9IGZyb20gJy4vdXNlU2NyaXB0dXJlU2V0dGluZ3MnXG4iXX0=