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 { ScriptureReference, VerseObjectsType } from '../../types';
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
- editing = _ref.editing,
65
- setEditing = _ref.setEditing,
66
- setVerseChanged = _ref.setVerseChanged;
67
-
68
- var _React$useState = React.useState(null),
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
- initialVerseText = _React$useState2[0],
71
- setInitialVerseText = _React$useState2[1];
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 resourceMsg = getResourceMessage(resourceStatus, server, resourceLink, isNT);
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
- }; // dynamically adjust font size
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: verseObjects
151
+ verseObjects: initialVerseObjects
97
152
  });
98
153
  setInitialVerseText(verseText);
99
154
  }, [{
100
- verseObjects: verseObjects
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: 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"]}