Skip to content
Snippets Groups Projects
Commit a9a68883 authored by chris's avatar chris
Browse files

replace all

parent 8b9811ae
No related branches found
No related tags found
1 merge request!190Find and replace
...@@ -6,7 +6,7 @@ import React, { ...@@ -6,7 +6,7 @@ import React, {
useCallback, useCallback,
useEffect, useEffect,
} from 'react'; } from 'react';
import { each, debounce } from 'lodash'; import { each, eachRight, debounce } from 'lodash';
import { WaxContext } from 'wax-prosemirror-core'; import { WaxContext } from 'wax-prosemirror-core';
import styled from 'styled-components'; import styled from 'styled-components';
import { grid, th } from '@pubsweet/ui-toolkit'; import { grid, th } from '@pubsweet/ui-toolkit';
...@@ -138,6 +138,7 @@ const ExandedFindAndReplaceComponent = ({ close, nonExpandedText }) => { ...@@ -138,6 +138,7 @@ const ExandedFindAndReplaceComponent = ({ close, nonExpandedText }) => {
const searchRef = useRef(null); const searchRef = useRef(null);
const replaceRef = useRef(null); const replaceRef = useRef(null);
const [searchValue, setSearchValue] = useState(nonExpandedText); const [searchValue, setSearchValue] = useState(nonExpandedText);
const [replaceValue, setReplaceValue] = useState('');
const [counterText, setCounterText] = useState('0 of 0'); const [counterText, setCounterText] = useState('0 of 0');
const findAndReplacePlugin = app.PmPlugins.get('findAndReplacePlugin'); const findAndReplacePlugin = app.PmPlugins.get('findAndReplacePlugin');
...@@ -175,13 +176,27 @@ const ExandedFindAndReplaceComponent = ({ close, nonExpandedText }) => { ...@@ -175,13 +176,27 @@ const ExandedFindAndReplaceComponent = ({ close, nonExpandedText }) => {
} }
}; };
const onChangeReplaceInput = () => {}; const onChangeReplaceInput = () => {
setReplaceValue(replaceRef.current.value);
};
const replace = () => { const replace = () => {
// const { from, to } = results[0]; // const { from, to } = results[0];
// dispatch(state.tr.insertText(replace, from, to)); // dispatch(state.tr.insertText(replace, from, to));
}; };
const replaceAll = () => {}; const replaceAll = () => {
each(view, (singleView, viewId) => {
const results = helpers.findMatches(singleView.state.doc, searchValue);
const {
state: { tr },
} = singleView;
eachRight(results, result => {
tr.insertText(replaceValue, result.from, result.to);
});
singleView.dispatch(tr);
});
};
const closeFind = () => { const closeFind = () => {
findAndReplacePlugin.props.setSearchText(''); findAndReplacePlugin.props.setSearchText('');
......
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment