Skip to content

Commit

Permalink
Merge pull request #142 from NearSocial/release-2.5.0
Browse files Browse the repository at this point in the history
## 2.5.0

- Fix `default` case for the switch statement in `VM`.
- Add a VM feature, `enableComponentSrcDataKey`, which adds the `data-component` attribute specifying the path of the comonent responsible for rendering the DOM element.
- Add support for VM.require when using redirectMap.
- Fixes an issue with VM.require not retaining context in migration to initGlobalFunctions.
- Add `onLink` and `onImage` to Markdown component. It allows to display links and images differently.
- Expose all VM functions into the state directly, it simplifies VM readability and implementation.
- Expose certain native objects directly into the state. It should improve access to the functions.
- Update the way events and errors are passed to the functions. 
  - For events, expose `preventDefault()` and `stopPropagation()` functions.
  NOTE: Previously, all React's `SyntheticEvent`s were getting `preventDefault()` called by default.
  - For errors, expose `message`, `name` and `type`.
- Fix `vm.depth` not being initialized.
- Introduce `useMemo` hook. Similar to the React hook, it calculates a value and memoizes it, only recalculating when one of its dependencies changes.

```jsx
const data = [
  //...some large array
];

const filteredData = useMemo(() => {
  console.log("Filtering data");
  return data.filter(/* some filtering criteria */);
}, [data]);

return (
  <div>
    {filteredData.map(item => (
      <div key={item.id}>{item.name}</div>
    ))}
  </div>
);
```

- Introduce `useCallback` hook. Similarly to the React hook, it memoizes a callback function and returns that memoized version unless one of its dependencies changes.
 ```jsx
 const incrementCounter = useCallback(() => {
  setCounter(counter + 1);
}, [counter]);

return (
  <div>
    Counter = {counter}
    <div>
      <button onClick={incrementCounter}>Increment</button>
    </div>
  </div>
);
```
  • Loading branch information
Evgeny Kuzyakov authored Oct 13, 2023
2 parents c8d62ac + e3178b0 commit 2794f26
Show file tree
Hide file tree
Showing 8 changed files with 775 additions and 604 deletions.
51 changes: 51 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,56 @@
# Changelog

## 2.5.0

- Fix `default` case for the switch statement in `VM`.
- Add a VM feature, `enableComponentSrcDataKey`, which adds the `data-component` attribute specifying the path of the comonent responsible for rendering the DOM element.
- Add support for VM.require when using redirectMap.
- Fixes an issue with VM.require not retaining context in migration to initGlobalFunctions.
- Add `onLink` and `onImage` to Markdown component. It allows to display links and images differently.
- Expose all VM functions into the state directly, it simplifies VM readability and implementation.
- Expose certain native objects directly into the state. It should improve access to the functions.
- Update the way events and errors are passed to the functions.
- For events, expose `preventDefault()` and `stopPropagation()` functions.
NOTE: Previously, all React's `SyntheticEvent`s were getting `preventDefault()` called by default.
- For errors, expose `message`, `name` and `type`.
- Fix `vm.depth` not being initialized.
- Introduce `useMemo` hook. Similar to the React hook, it calculates a value and memoizes it, only recalculating when one of its dependencies changes.

```jsx
const data = [
//...some large array
];

const filteredData = useMemo(() => {
console.log("Filtering data");
return data.filter(/* some filtering criteria */);
}, [data]);

return (
<div>
{filteredData.map(item => (
<div key={item.id}>{item.name}</div>
))}
</div>
);
```

- Introduce `useCallback` hook. Similarly to the React hook, it memoizes a callback function and returns that memoized version unless one of its dependencies changes.
```jsx
const incrementCounter = useCallback(() => {
setCounter(counter + 1);
}, [counter]);

return (
<div>
Counter = {counter}
<div>
<button onClick={incrementCounter}>Increment</button>
</div>
</div>
);
```

## 2.4.2

- Add missing code changes (`cacheOptions` and `lodash`) from 2.4.0.
Expand Down
2 changes: 1 addition & 1 deletion dist/index.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "near-social-vm",
"version": "2.4.2",
"version": "2.5.0",
"description": "Near Social VM",
"main": "dist/index.js",
"files": [
Expand Down
22 changes: 18 additions & 4 deletions src/lib/components/Markdown.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,15 @@ import mentions from "./remark/mentions";
import hashtags from "./remark/hashtags";

export const Markdown = (props) => {
const { onLinkClick, text, onMention, onHashtag, syntaxHighlighterProps } =
props;
const {
onLink,
onLinkClick,
text,
onMention,
onHashtag,
onImage,
syntaxHighlighterProps,
} = props;
return (
<ReactMarkdown
plugins={[]}
Expand All @@ -25,12 +32,19 @@ export const Markdown = (props) => {
return <strong {...props}>{children}</strong>;
},
a: ({ node, ...props }) =>
onLinkClick ? (
onLink ? (
onLink({ ...props, href: node.properties?.href })
) : onLinkClick ? (
<a onClick={onLinkClick} {...props} />
) : (
<a target="_blank" {...props} />
),
img: ({ node, ...props }) => <img className="img-fluid" {...props} />,
img: ({ node, ...props }) =>
onImage ? (
onImage({ ...props })
) : (
<img className="img-fluid" {...props} />
),
blockquote: ({ node, ...props }) => (
<blockquote className="blockquote" {...props} />
),
Expand Down
22 changes: 1 addition & 21 deletions src/lib/components/Widget.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import {
isFunction,
Loading,
TGas,
computeSrcOrCode,
} from "../data/utils";
import { ErrorBoundary } from "react-error-boundary";
import { useCache } from "../data/cache";
Expand All @@ -26,27 +27,6 @@ import Big from "big.js";
import uuid from "react-uuid";
import { EthersProviderContext } from "./ethers";

const computeSrcOrCode = (src, code, configs) => {
let srcOrCode = src ? { src } : code ? { code } : null;
for (const config of configs || []) {
if (srcOrCode?.src) {
const src = srcOrCode.src;
let value = isObject(config?.redirectMap) && config.redirectMap[src];
if (!value) {
try {
value = isFunction(config?.redirect) && config.redirect(src);
} catch {}
}
if (isString(value)) {
srcOrCode = { src: value };
} else if (isString(value?.code)) {
return { code: value.code };
}
}
}
return srcOrCode;
};

export const Widget = React.forwardRef((props, forwardedRef) => {
const {
loading,
Expand Down
6 changes: 6 additions & 0 deletions src/lib/data/near.js
Original file line number Diff line number Diff line change
Expand Up @@ -211,13 +211,18 @@ async function web4ViewCall(contractId, methodName, args, fallback) {
}
}

/**
* Current VM Features:
* - enableComponentSrcDataKey: Allows enabling the component source `data-component` attribute for rendered DOM elements. Disabled by default.
**/
async function _initNear({
networkId,
config,
keyStore,
selector,
walletConnectCallback = () => {},
customElements = {},
features = {},
}) {
if (!config) {
config = {};
Expand Down Expand Up @@ -250,6 +255,7 @@ async function _initNear({
selector,
keyStore,
nearConnection,
features
};

_near.nearArchivalConnection = nearAPI.Connection.fromConfig({
Expand Down
29 changes: 29 additions & 0 deletions src/lib/data/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -395,4 +395,33 @@ export const deepCopy = (o) => {
}
};

export const filterValues = (o) => {
return isObject(o)
? Object.fromEntries(
Object.entries(o).filter(([key, value]) => value !== undefined)
)
: o;
};

export const deepEqual = equal;

export const computeSrcOrCode = (src, code, configs) => {
let srcOrCode = src ? { src } : code ? { code } : null;
for (const config of configs || []) {
if (srcOrCode?.src) {
const src = srcOrCode.src;
let value = isObject(config?.redirectMap) && config.redirectMap[src];
if (!value) {
try {
value = isFunction(config?.redirect) && config.redirect(src);
} catch {}
}
if (isString(value)) {
srcOrCode = { src: value };
} else if (isString(value?.code)) {
return { code: value.code };
}
}
}
return srcOrCode;
};
Loading

0 comments on commit 2794f26

Please sign in to comment.