mirror of
https://github.com/urbit/shrub.git
synced 2025-01-06 21:18:42 +03:00
Merge branch 'next/groups' into hm/remove-dm-delete
This commit is contained in:
commit
846502ef51
@ -168,6 +168,11 @@
|
|||||||
%+ turn ~(tap by charges)
|
%+ turn ~(tap by charges)
|
||||||
|= [=desk =charge]
|
|= [=desk =charge]
|
||||||
[desk (get-light-charge charge)]
|
[desk (get-light-charge charge)]
|
||||||
|
::
|
||||||
|
[%x %charges @ %version ~]
|
||||||
|
?~ charge=(~(get by charges) i.t.t.path)
|
||||||
|
[~ ~]
|
||||||
|
``noun+!>(version.docket.u.charge)
|
||||||
==
|
==
|
||||||
::
|
::
|
||||||
++ on-agent
|
++ on-agent
|
||||||
|
@ -5,3 +5,4 @@ bin/
|
|||||||
.husky/
|
.husky/
|
||||||
*.config.js
|
*.config.js
|
||||||
*.config.ts
|
*.config.ts
|
||||||
|
package.json
|
47
pkg/grid/CONTRIBUTING.md
Normal file
47
pkg/grid/CONTRIBUTING.md
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
# Contributing to Landscape
|
||||||
|
|
||||||
|
Thank you for your interest in contributing to the Urbit ecosystem.
|
||||||
|
|
||||||
|
Landscape is entirely open to contributions from the community. We mainly organize through our [project board], [issues], and [weekly call].
|
||||||
|
|
||||||
|
For now our code is stored in the main [urbit repo]. If you would like to contribute feel free to open up a PR there.
|
||||||
|
|
||||||
|
## Git Conventions
|
||||||
|
|
||||||
|
For Landscape we follow the same conventions as the main repo which can be found in it's [contributing doc]. This can be summarized as the following:
|
||||||
|
|
||||||
|
Commits should try to be atomic and focused on one feature at a time. Work-in-progress commits should be rebased and combined into one so that the commit history stays clean.
|
||||||
|
|
||||||
|
Commits should follow this format:
|
||||||
|
|
||||||
|
> component: short description
|
||||||
|
>
|
||||||
|
> long description
|
||||||
|
|
||||||
|
Where `component` is the closest most relevant area of the code base written as concisely as possible. The short description that accompanies should be a super concise summary of the changes. The total length of the commit message should strive to be 50 characters or less. The long description is optional, but should be used if further explanation is necessary.
|
||||||
|
|
||||||
|
### Pull Requests
|
||||||
|
|
||||||
|
A pull request (PR) should have a title similar in structure to our commit messages where it has a short identifier component followed by a very concise summary of the PR's intent. All PRs should have a description further laying out what it accomplishes. If the PR addresses certain Github issues, those should be referenced in the body of the description so they get linked.
|
||||||
|
|
||||||
|
PRs to this repo should currently tag (or request review) from one of the following contributors:
|
||||||
|
|
||||||
|
- [Liam - @liam-fitzgerald](https://github.com/liam-fitzgerald)
|
||||||
|
- [Hunter - @arthyn](https://github.com/arthyn)
|
||||||
|
- [James - @nerveharp](https://github.com/nerveharp)
|
||||||
|
|
||||||
|
If design or visual changes are made, please provide screenshots and also tag (or request a review) from one of the following contributors:
|
||||||
|
|
||||||
|
- [Éd - @urcades](https://github.com/urcades)
|
||||||
|
- [Gavin - @g-a-v-i-n](https://github.com/g-a-v-i-n)
|
||||||
|
|
||||||
|
## Further Information
|
||||||
|
|
||||||
|
If you haven't yet, check out the main [contributing doc] at the base of the repo for information on how to get started developing on Urbit. Also you can find a host of resources on [developers.urbit.org], including ways to earn address space by contributing.
|
||||||
|
|
||||||
|
[project board]: https://github.com/orgs/urbit/projects/17
|
||||||
|
[issues]: https://github.com/urbit/landscape/issues
|
||||||
|
[weekly call]: https://github.com/urbit/landscape/issues/792
|
||||||
|
[urbit repo]: https://github.com/urbit/urbit
|
||||||
|
[contributing doc]: ../../CONTRIBUTING.md
|
||||||
|
[developers.urbit.org]: https://developers.urbit.org/
|
43
pkg/grid/README.md
Normal file
43
pkg/grid/README.md
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
# Landscape
|
||||||
|
|
||||||
|
Landscape provides the primary launching interface for Tlon's suite of userspace applications. This directory contains the front-end web application to power said interface.
|
||||||
|
|
||||||
|
Landscape is built primarily using [React], [Typescript], and [Tailwind CSS]. [Vite] ensures that all code and assets are loaded appropriately, bundles the application for distribution and provides a functional dev environment.
|
||||||
|
|
||||||
|
## Getting Started
|
||||||
|
|
||||||
|
To get started using Landscape first you need to run, `npm i && npm run bootstrap` at the top level of the greater urbit repo. This will install your npm dependencies and correctly link the current implementation of the packages at `pkg/npm/*` to your dependencies.
|
||||||
|
|
||||||
|
If you intend to edit those packages will developing on Landscape, you should also have `npm run watch-libs` running to build and re-link them after every change.
|
||||||
|
|
||||||
|
Once that's done, you can then run `npm run mock` if you'd like to get started immediately. This will use hard-coded mock data to power the interface so you can work on the interface without being connected to a ship.
|
||||||
|
|
||||||
|
To develop against a working ship, you first need to add a `.env.local` file to the root of this directory. This file will not be committed. Adding `VITE_SHIP_URL={URL}` where **{URL}** is the URL of the ship you would like to point to, will allow you to run `npm run dev`. This will proxy all requests to the ship except for those powering the interface, allowing you to see live data.
|
||||||
|
|
||||||
|
Regardless of what you run to develop, Vite will hot-reload code changes as you work so you don't have to constantly refresh.
|
||||||
|
|
||||||
|
## Deploying
|
||||||
|
|
||||||
|
To deploy, run `npm run build` which will bundle all the code and assets into the `dist/` folder. This can then be made into a glob by doing the following:
|
||||||
|
|
||||||
|
1. Create or launch an urbit using the -F flag
|
||||||
|
2. On that urbit, if you don't already have a desk to run from, run `|merge %work our %base` to create a new desk and mount it with `|mount %work`.
|
||||||
|
3. Now the `%work` desk is accessible through the host OS's filesystem as a directory of that urbit's pier ie `~/zod/work`.
|
||||||
|
4. From the directory of grid you can run `rsync -avL --delete dist/ ~/zod/work/grid` where `~/zod` is your fake urbit's pier.
|
||||||
|
5. Once completed you can then run `|commit %work` on your urbit and you should see your files logged back out from the dojo.
|
||||||
|
6. Now run `=dir /=garden` to switch to the garden desk directory
|
||||||
|
7. You can now run `-make-glob %work /grid` which will take the grid folder where you just added files and create a glob which can be thought of as a sort of bundle. It will be output to `~/zod/.urb/put`.
|
||||||
|
8. If you navigate to `~/zod/.urb/put` you should see a file that looks like this `glob-0v5.fdf99.nph65.qecq3.ncpjn.q13mb.glob`. The characters between `glob-` and `.glob` are a hash of the glob's contents.
|
||||||
|
9. If you're working at Tlon, you can upload this to our Google storage using `gsutil cp glob-*.* gs://bootstrap.urbit.org`. Otherwise any publicly available HTTP endpoint that can serve files should be sufficient for distributing the glob.
|
||||||
|
10. Once you've uploaded the glob, you should then update the corresponding entry in the docket file that represents Landscape which currently resides at `pkg/garden/desk.docket-0`. Both the full URL and the hash should be updated to match the glob we just created, on the line that looks like this:
|
||||||
|
|
||||||
|
```hoon
|
||||||
|
glob-http+['https://bootstrap.urbit.org/glob-0v5.fdf99.nph65.qecq3.ncpjn.q13mb.glob' 0v5.fdf99.nph65.qecq3.ncpjn.q13mb]
|
||||||
|
```
|
||||||
|
|
||||||
|
11. This can now be safely committed and deployed.
|
||||||
|
|
||||||
|
[react]: https://reactjs.org/
|
||||||
|
[typescript]: https://www.typescriptlang.org/
|
||||||
|
[tailwind css]: https://tailwindcss.com/
|
||||||
|
[vite]: https://vitejs.dev/
|
29
pkg/grid/package-lock.json
generated
29
pkg/grid/package-lock.json
generated
@ -15,8 +15,8 @@
|
|||||||
"@radix-ui/react-toggle": "^0.0.10",
|
"@radix-ui/react-toggle": "^0.0.10",
|
||||||
"@tlon/sigil-js": "^1.4.4",
|
"@tlon/sigil-js": "^1.4.4",
|
||||||
"@types/lodash": "^4.14.172",
|
"@types/lodash": "^4.14.172",
|
||||||
"@urbit/api": "^1.4.0",
|
"@urbit/api": "^2.0.0",
|
||||||
"@urbit/http-api": "^1.3.1",
|
"@urbit/http-api": "^2.0.0",
|
||||||
"big-integer": "^1.6.48",
|
"big-integer": "^1.6.48",
|
||||||
"classnames": "^2.3.1",
|
"classnames": "^2.3.1",
|
||||||
"clipboard-copy": "^4.0.1",
|
"clipboard-copy": "^4.0.1",
|
||||||
@ -38,7 +38,6 @@
|
|||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@tailwindcss/aspect-ratio": "^0.2.1",
|
"@tailwindcss/aspect-ratio": "^0.2.1",
|
||||||
"@types/lodash": "^4.14.172",
|
|
||||||
"@types/mousetrap": "^1.6.8",
|
"@types/mousetrap": "^1.6.8",
|
||||||
"@types/node": "^16.7.9",
|
"@types/node": "^16.7.9",
|
||||||
"@types/react": "^16.0.0",
|
"@types/react": "^16.0.0",
|
||||||
@ -1294,9 +1293,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@urbit/api": {
|
"node_modules/@urbit/api": {
|
||||||
"version": "1.4.0",
|
"version": "2.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/@urbit/api/-/api-1.4.0.tgz",
|
"resolved": "https://registry.npmjs.org/@urbit/api/-/api-2.0.0.tgz",
|
||||||
"integrity": "sha512-mjNwu+kbYhbDcDPAk3+kEMKHoHa5VtjCcIxBMQSpvy27N9jgS7D1Pn7MDEyDwdsVk9PWWG3ODg6q+yGwLMBuwg==",
|
"integrity": "sha512-shELBuW1cjXYP2DrJyRMomIh5oMDkwLgNx8AWnVY2FhZUgsojRKiWmJ/bdO/mGnFZUch0tPBAl6bawwVPkBPDg==",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/runtime": "^7.12.5",
|
"@babel/runtime": "^7.12.5",
|
||||||
"@types/lodash": "^4.14.168",
|
"@types/lodash": "^4.14.168",
|
||||||
@ -1313,9 +1312,9 @@
|
|||||||
"integrity": "sha512-4mGd4GzzF+JMG/eAhjDQBjyVYo0xNbpcC7I16GouINLIuz5LJmNZ98SRQaOpfnsGIfTiZxwyZnfIX20orvWMxQ=="
|
"integrity": "sha512-4mGd4GzzF+JMG/eAhjDQBjyVYo0xNbpcC7I16GouINLIuz5LJmNZ98SRQaOpfnsGIfTiZxwyZnfIX20orvWMxQ=="
|
||||||
},
|
},
|
||||||
"node_modules/@urbit/http-api": {
|
"node_modules/@urbit/http-api": {
|
||||||
"version": "1.3.1",
|
"version": "2.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/@urbit/http-api/-/http-api-1.3.1.tgz",
|
"resolved": "https://registry.npmjs.org/@urbit/http-api/-/http-api-2.0.0.tgz",
|
||||||
"integrity": "sha512-z9giStO48tdIwrZ570jzw9N4cQCVS6ziacNk6UPsXbAA+KPuw+r71ehxgECgVmJdfTqUSUh6u+LIcmz+1yQgJQ==",
|
"integrity": "sha512-rwi+6sNbx+WPA1E+cwsHR4kQYtlNDbObPZ8BXCwHc9lWN1FJTbZNkjCtXBR3KMelvFlf4ftR+8EkdiWTfFOnoQ==",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/runtime": "^7.12.5",
|
"@babel/runtime": "^7.12.5",
|
||||||
"@microsoft/fetch-event-source": "^2.0.0",
|
"@microsoft/fetch-event-source": "^2.0.0",
|
||||||
@ -8863,9 +8862,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"@urbit/api": {
|
"@urbit/api": {
|
||||||
"version": "1.4.0",
|
"version": "2.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/@urbit/api/-/api-1.4.0.tgz",
|
"resolved": "https://registry.npmjs.org/@urbit/api/-/api-2.0.0.tgz",
|
||||||
"integrity": "sha512-mjNwu+kbYhbDcDPAk3+kEMKHoHa5VtjCcIxBMQSpvy27N9jgS7D1Pn7MDEyDwdsVk9PWWG3ODg6q+yGwLMBuwg==",
|
"integrity": "sha512-shELBuW1cjXYP2DrJyRMomIh5oMDkwLgNx8AWnVY2FhZUgsojRKiWmJ/bdO/mGnFZUch0tPBAl6bawwVPkBPDg==",
|
||||||
"requires": {
|
"requires": {
|
||||||
"@babel/runtime": "^7.12.5",
|
"@babel/runtime": "^7.12.5",
|
||||||
"@types/lodash": "^4.14.168",
|
"@types/lodash": "^4.14.168",
|
||||||
@ -8882,9 +8881,9 @@
|
|||||||
"integrity": "sha512-4mGd4GzzF+JMG/eAhjDQBjyVYo0xNbpcC7I16GouINLIuz5LJmNZ98SRQaOpfnsGIfTiZxwyZnfIX20orvWMxQ=="
|
"integrity": "sha512-4mGd4GzzF+JMG/eAhjDQBjyVYo0xNbpcC7I16GouINLIuz5LJmNZ98SRQaOpfnsGIfTiZxwyZnfIX20orvWMxQ=="
|
||||||
},
|
},
|
||||||
"@urbit/http-api": {
|
"@urbit/http-api": {
|
||||||
"version": "1.3.1",
|
"version": "2.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/@urbit/http-api/-/http-api-1.3.1.tgz",
|
"resolved": "https://registry.npmjs.org/@urbit/http-api/-/http-api-2.0.0.tgz",
|
||||||
"integrity": "sha512-z9giStO48tdIwrZ570jzw9N4cQCVS6ziacNk6UPsXbAA+KPuw+r71ehxgECgVmJdfTqUSUh6u+LIcmz+1yQgJQ==",
|
"integrity": "sha512-rwi+6sNbx+WPA1E+cwsHR4kQYtlNDbObPZ8BXCwHc9lWN1FJTbZNkjCtXBR3KMelvFlf4ftR+8EkdiWTfFOnoQ==",
|
||||||
"requires": {
|
"requires": {
|
||||||
"@babel/runtime": "^7.12.5",
|
"@babel/runtime": "^7.12.5",
|
||||||
"@microsoft/fetch-event-source": "^2.0.0",
|
"@microsoft/fetch-event-source": "^2.0.0",
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "landscape",
|
"name": "landscape",
|
||||||
"version": "0.0.0",
|
"version": "0.0.0",
|
||||||
|
"private": true,
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "vite",
|
"dev": "vite",
|
||||||
"mock": "vite --mode mock",
|
"mock": "vite --mode mock",
|
||||||
@ -21,8 +22,8 @@
|
|||||||
"@radix-ui/react-toggle": "^0.0.10",
|
"@radix-ui/react-toggle": "^0.0.10",
|
||||||
"@tlon/sigil-js": "^1.4.4",
|
"@tlon/sigil-js": "^1.4.4",
|
||||||
"@types/lodash": "^4.14.172",
|
"@types/lodash": "^4.14.172",
|
||||||
"@urbit/api": "^1.4.0",
|
"@urbit/api": "^2.1.0",
|
||||||
"@urbit/http-api": "^1.3.1",
|
"@urbit/http-api": "^2.1.0",
|
||||||
"big-integer": "^1.6.48",
|
"big-integer": "^1.6.48",
|
||||||
"classnames": "^2.3.1",
|
"classnames": "^2.3.1",
|
||||||
"clipboard-copy": "^4.0.1",
|
"clipboard-copy": "^4.0.1",
|
||||||
|
@ -1,8 +1,7 @@
|
|||||||
import { chadIsRunning, Treaty } from '@urbit/api';
|
import { chadIsRunning, Treaty, Vat } from '@urbit/api';
|
||||||
import clipboardCopy from 'clipboard-copy';
|
import clipboardCopy from 'clipboard-copy';
|
||||||
import React, { FC, useCallback, useState } from 'react';
|
import React, { FC, useCallback, useState } from 'react';
|
||||||
import cn from 'classnames';
|
import cn from 'classnames';
|
||||||
import { Vat } from '@urbit/api/hood';
|
|
||||||
import { Button, PillButton } from './Button';
|
import { Button, PillButton } from './Button';
|
||||||
import { Dialog, DialogClose, DialogContent, DialogTrigger } from './Dialog';
|
import { Dialog, DialogClose, DialogContent, DialogTrigger } from './Dialog';
|
||||||
import { DocketHeader } from './DocketHeader';
|
import { DocketHeader } from './DocketHeader';
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import React, { useState } from 'react';
|
import React, { useState } from 'react';
|
||||||
import { Docket } from '@urbit/api/docket';
|
import { Docket } from '@urbit/api';
|
||||||
import cn from 'classnames';
|
import cn from 'classnames';
|
||||||
import { useTileColor } from '../tiles/useTileColor';
|
import { useTileColor } from '../tiles/useTileColor';
|
||||||
|
|
||||||
|
@ -7,7 +7,13 @@ type ShipNameProps = {
|
|||||||
|
|
||||||
export const ShipName = ({ name, ...props }: ShipNameProps) => {
|
export const ShipName = ({ name, ...props }: ShipNameProps) => {
|
||||||
const separator = /([_^-])/;
|
const separator = /([_^-])/;
|
||||||
const parts = cite(name).replace('~', '').split(separator);
|
const citedName = cite(name);
|
||||||
|
|
||||||
|
if (!citedName) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
const parts = citedName.replace('~', '').split(separator);
|
||||||
const first = parts.shift();
|
const first = parts.shift();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { Vat } from '@urbit/api/hood';
|
import { Vat } from '@urbit/api';
|
||||||
|
|
||||||
import { Attribute } from './Attribute';
|
import { Attribute } from './Attribute';
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@ import classNames from 'classnames';
|
|||||||
import clipboardCopy from 'clipboard-copy';
|
import clipboardCopy from 'clipboard-copy';
|
||||||
import React, { HTMLAttributes, useCallback, useState } from 'react';
|
import React, { HTMLAttributes, useCallback, useState } from 'react';
|
||||||
import { Link, Route, useHistory } from 'react-router-dom';
|
import { Link, Route, useHistory } from 'react-router-dom';
|
||||||
import { Vat } from '@urbit/api/hood';
|
import { Vat } from '@urbit/api';
|
||||||
import { Adjust } from '../components/icons/Adjust';
|
import { Adjust } from '../components/icons/Adjust';
|
||||||
import { useVat } from '../state/kiln';
|
import { useVat } from '../state/kiln';
|
||||||
import { disableDefault, handleDropdownLink } from '../state/util';
|
import { disableDefault, handleDropdownLink } from '../state/util';
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import { pick, pickBy, partition } from 'lodash';
|
import { pick, pickBy, partition } from 'lodash';
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { kilnBump } from '@urbit/api/hood';
|
import { kilnBump } from '@urbit/api';
|
||||||
import { AppList } from '../../components/AppList';
|
import { AppList } from '../../components/AppList';
|
||||||
import { Button } from '../../components/Button';
|
import { Button } from '../../components/Button';
|
||||||
import { Dialog, DialogClose, DialogContent, DialogTrigger } from '../../components/Dialog';
|
import { Dialog, DialogClose, DialogContent, DialogTrigger } from '../../components/Dialog';
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { setMentions } from '@urbit/api/dist';
|
import { setMentions } from '@urbit/api';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { Setting } from '../../components/Setting';
|
import { Setting } from '../../components/Setting';
|
||||||
import { pokeOptimisticallyN } from '../../state/base';
|
import { pokeOptimisticallyN } from '../../state/base';
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
/* eslint-disable no-param-reassign */
|
/* eslint-disable no-param-reassign */
|
||||||
import {
|
import {
|
||||||
|
BigIntOrderedMap,
|
||||||
makePatDa,
|
makePatDa,
|
||||||
decToUd,
|
decToUd,
|
||||||
unixToDa,
|
unixToDa,
|
||||||
@ -13,7 +14,6 @@ import {
|
|||||||
NotificationGraphConfig,
|
NotificationGraphConfig,
|
||||||
archiveAll
|
archiveAll
|
||||||
} from '@urbit/api';
|
} from '@urbit/api';
|
||||||
import BigIntOrderedMap from '@urbit/api/lib/BigIntOrderedMap';
|
|
||||||
/* eslint-disable-next-line camelcase */
|
/* eslint-disable-next-line camelcase */
|
||||||
import { unstable_batchedUpdates } from 'react-dom';
|
import { unstable_batchedUpdates } from 'react-dom';
|
||||||
import produce from 'immer';
|
import produce from 'immer';
|
||||||
|
@ -1,5 +1,13 @@
|
|||||||
import { getVats, Vats, scryLag, getBlockers, Vat, kilnInstall } from '@urbit/api';
|
import {
|
||||||
import { kilnPause, kilnResume } from '@urbit/api/hood';
|
getVats,
|
||||||
|
Vats,
|
||||||
|
scryLag,
|
||||||
|
getBlockers,
|
||||||
|
Vat,
|
||||||
|
kilnInstall,
|
||||||
|
kilnPause,
|
||||||
|
kilnResume
|
||||||
|
} from '@urbit/api';
|
||||||
import create from 'zustand';
|
import create from 'zustand';
|
||||||
import produce from 'immer';
|
import produce from 'immer';
|
||||||
import { useCallback } from 'react';
|
import { useCallback } from 'react';
|
||||||
|
@ -5,7 +5,7 @@ import {
|
|||||||
putEntry as doPutEntry,
|
putEntry as doPutEntry,
|
||||||
getDeskSettings,
|
getDeskSettings,
|
||||||
DeskData
|
DeskData
|
||||||
} from '@urbit/api/settings';
|
} from '@urbit/api';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import {
|
import {
|
||||||
BaseState,
|
BaseState,
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { Docket, DocketHref, Treaty } from '@urbit/api/docket';
|
import { Docket, DocketHref, Treaty } from '@urbit/api';
|
||||||
import { hsla, parseToHsla } from 'color2k';
|
import { hsla, parseToHsla } from 'color2k';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
|
|
||||||
|
@ -71,7 +71,7 @@ module.exports = {
|
|||||||
]
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
exclude: /node_modules\/(?!(@tlon\/indigo-dark|@tlon\/indigo-light|@tlon\/indigo-react)\/).*/
|
exclude: /node_modules\/(?!(@tlon\/indigo-dark|@tlon\/indigo-light|@tlon\/indigo-react|@urbit\/api)\/).*/
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
test: /\.css$/i,
|
test: /\.css$/i,
|
||||||
|
@ -30,7 +30,7 @@ module.exports = {
|
|||||||
]
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
exclude: /node_modules\/(?!(@tlon\/indigo-dark|@tlon\/indigo-light|@tlon\/indigo-react)\/).*/
|
exclude: /node_modules\/(?!(@tlon\/indigo-dark|@tlon\/indigo-light|@tlon\/indigo-react|@urbit\/api)\/).*/
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
test: /\.css$/i,
|
test: /\.css$/i,
|
||||||
|
221
pkg/interface/package-lock.json
generated
221
pkg/interface/package-lock.json
generated
@ -19,6 +19,8 @@
|
|||||||
"@tlon/indigo-light": "^1.0.7",
|
"@tlon/indigo-light": "^1.0.7",
|
||||||
"@tlon/indigo-react": "^1.2.27",
|
"@tlon/indigo-react": "^1.2.27",
|
||||||
"@tlon/sigil-js": "^1.4.3",
|
"@tlon/sigil-js": "^1.4.3",
|
||||||
|
"@urbit/api": "^2.1.0",
|
||||||
|
"@urbit/http-api": "^2.1.0",
|
||||||
"any-ascii": "^0.1.7",
|
"any-ascii": "^0.1.7",
|
||||||
"aws-sdk": "^2.830.0",
|
"aws-sdk": "^2.830.0",
|
||||||
"big-integer": "^1.6.48",
|
"big-integer": "^1.6.48",
|
||||||
@ -86,6 +88,7 @@
|
|||||||
"@types/yup": "^0.29.11",
|
"@types/yup": "^0.29.11",
|
||||||
"@typescript-eslint/eslint-plugin": "^4.15.0",
|
"@typescript-eslint/eslint-plugin": "^4.15.0",
|
||||||
"@typescript-eslint/parser": "^4.24.0",
|
"@typescript-eslint/parser": "^4.24.0",
|
||||||
|
"@urbit/eslint-config": "^1.0.0",
|
||||||
"@welldone-software/why-did-you-render": "^6.1.0",
|
"@welldone-software/why-did-you-render": "^6.1.0",
|
||||||
"babel-eslint": "^10.1.0",
|
"babel-eslint": "^10.1.0",
|
||||||
"babel-jest": "^26.6.3",
|
"babel-jest": "^26.6.3",
|
||||||
@ -1951,9 +1954,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@babel/runtime": {
|
"node_modules/@babel/runtime": {
|
||||||
"version": "7.14.6",
|
"version": "7.16.7",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.14.6.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.16.7.tgz",
|
||||||
"integrity": "sha512-/PCB2uJ7oM44tz8YhC4Z/6PeOKXp4K588f+5M3clr1M4zbqztlo0XEfJ2LEzj/FgwfgGcIdl8n7YYjTCI0BYwg==",
|
"integrity": "sha512-9E9FJowqAsytyOY6LG+1KuueckRL+aQW+mKvXRXnuFGyRAyepJPmEo9vgMfXUA6O9u3IeEdv9MAkppFcaQwogQ==",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"regenerator-runtime": "^0.13.4"
|
"regenerator-runtime": "^0.13.4"
|
||||||
},
|
},
|
||||||
@ -3711,6 +3714,11 @@
|
|||||||
"url": "https://opencollective.com/unified"
|
"url": "https://opencollective.com/unified"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/@microsoft/fetch-event-source": {
|
||||||
|
"version": "2.0.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/@microsoft/fetch-event-source/-/fetch-event-source-2.0.1.tgz",
|
||||||
|
"integrity": "sha512-W6CLUJ2eBMw3Rec70qrsEW0jOm/3twwJv21mrmj2yORiaVmVYGS4sSS5yUwvQc1ZlDLYGPnClVWmUUMagKNsfA=="
|
||||||
|
},
|
||||||
"node_modules/@mrmlnc/readdir-enhanced": {
|
"node_modules/@mrmlnc/readdir-enhanced": {
|
||||||
"version": "2.2.1",
|
"version": "2.2.1",
|
||||||
"resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz",
|
"resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz",
|
||||||
@ -7627,6 +7635,35 @@
|
|||||||
"url": "https://opencollective.com/typescript-eslint"
|
"url": "https://opencollective.com/typescript-eslint"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/@urbit/api": {
|
||||||
|
"version": "2.1.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/@urbit/api/-/api-2.1.0.tgz",
|
||||||
|
"integrity": "sha512-2njwpvZ2s23gp5C4v9uDynU1wxrN33+vloqpvlErUhMR/4R6mXE4cMvsZzj/fCGOa0J3LRV/If7XmgG+kY69Tg==",
|
||||||
|
"dependencies": {
|
||||||
|
"@babel/runtime": "^7.16.0",
|
||||||
|
"big-integer": "^1.6.48",
|
||||||
|
"core-js": "^3.19.1",
|
||||||
|
"immer": "^9.0.1",
|
||||||
|
"urbit-ob": "^5.0.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/@urbit/eslint-config": {
|
||||||
|
"version": "1.0.3",
|
||||||
|
"resolved": "https://registry.npmjs.org/@urbit/eslint-config/-/eslint-config-1.0.3.tgz",
|
||||||
|
"integrity": "sha512-4mGd4GzzF+JMG/eAhjDQBjyVYo0xNbpcC7I16GouINLIuz5LJmNZ98SRQaOpfnsGIfTiZxwyZnfIX20orvWMxQ==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
|
"node_modules/@urbit/http-api": {
|
||||||
|
"version": "2.1.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/@urbit/http-api/-/http-api-2.1.0.tgz",
|
||||||
|
"integrity": "sha512-eXYar3ofw1HlhHy2NSkJPCo//oZzfnrGXIJAKQ/gWSzd8x3o7eiiIQjoFbuWojaACy8T9fXsGzpxEqoXZlWDhw==",
|
||||||
|
"dependencies": {
|
||||||
|
"@babel/runtime": "^7.12.5",
|
||||||
|
"@microsoft/fetch-event-source": "^2.0.0",
|
||||||
|
"browser-or-node": "^1.3.0",
|
||||||
|
"core-js": "^3.19.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/@webassemblyjs/ast": {
|
"node_modules/@webassemblyjs/ast": {
|
||||||
"version": "1.9.0",
|
"version": "1.9.0",
|
||||||
"resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.9.0.tgz",
|
"resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.9.0.tgz",
|
||||||
@ -8094,7 +8131,7 @@
|
|||||||
"version": "3.1.2",
|
"version": "3.1.2",
|
||||||
"resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz",
|
"resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz",
|
||||||
"integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==",
|
"integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"normalize-path": "^3.0.0",
|
"normalize-path": "^3.0.0",
|
||||||
"picomatch": "^2.0.4"
|
"picomatch": "^2.0.4"
|
||||||
@ -8389,7 +8426,7 @@
|
|||||||
"version": "1.0.3",
|
"version": "1.0.3",
|
||||||
"resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz",
|
"resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz",
|
||||||
"integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==",
|
"integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"node_modules/async-limiter": {
|
"node_modules/async-limiter": {
|
||||||
"version": "1.0.1",
|
"version": "1.0.1",
|
||||||
@ -9132,7 +9169,7 @@
|
|||||||
"version": "2.2.0",
|
"version": "2.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
|
||||||
"integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
|
"integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=8"
|
"node": ">=8"
|
||||||
}
|
}
|
||||||
@ -9141,7 +9178,6 @@
|
|||||||
"version": "1.5.0",
|
"version": "1.5.0",
|
||||||
"resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz",
|
"resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz",
|
||||||
"integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==",
|
"integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"file-uri-to-path": "1.0.0"
|
"file-uri-to-path": "1.0.0"
|
||||||
@ -9380,7 +9416,7 @@
|
|||||||
"version": "3.0.2",
|
"version": "3.0.2",
|
||||||
"resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
|
"resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
|
||||||
"integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
|
"integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"fill-range": "^7.0.1"
|
"fill-range": "^7.0.1"
|
||||||
},
|
},
|
||||||
@ -9393,6 +9429,11 @@
|
|||||||
"resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz",
|
||||||
"integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8="
|
"integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8="
|
||||||
},
|
},
|
||||||
|
"node_modules/browser-or-node": {
|
||||||
|
"version": "1.3.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/browser-or-node/-/browser-or-node-1.3.0.tgz",
|
||||||
|
"integrity": "sha512-0F2z/VSnLbmEeBcUrSuDH5l0HxTXdQQzLjkmBR4cYfvg1zJrKSlmIZFqyFR8oX0NrwPhy3c3HQ6i3OxMbew4Tg=="
|
||||||
|
},
|
||||||
"node_modules/browser-process-hrtime": {
|
"node_modules/browser-process-hrtime": {
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz",
|
||||||
@ -10067,7 +10108,7 @@
|
|||||||
"version": "3.5.2",
|
"version": "3.5.2",
|
||||||
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz",
|
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz",
|
||||||
"integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==",
|
"integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"anymatch": "~3.1.2",
|
"anymatch": "~3.1.2",
|
||||||
"braces": "~3.0.2",
|
"braces": "~3.0.2",
|
||||||
@ -11101,10 +11142,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/core-js": {
|
"node_modules/core-js": {
|
||||||
"version": "3.15.2",
|
"version": "3.20.2",
|
||||||
"resolved": "https://registry.npmjs.org/core-js/-/core-js-3.15.2.tgz",
|
"resolved": "https://registry.npmjs.org/core-js/-/core-js-3.20.2.tgz",
|
||||||
"integrity": "sha512-tKs41J7NJVuaya8DxIOCnl8QuPHx5/ZVbFo1oKgVl1qHFBBrDctzQGtuLjPpRdNTWmKPH6oEvgN/MUID+l485Q==",
|
"integrity": "sha512-nuqhq11DcOAbFBV4zCbKeGbKQsUDRqTX0oqx7AttUBuqe3h20ixsE039QHelbL6P4h+9kytVqyEtyZ6gsiwEYw==",
|
||||||
"dev": true,
|
|
||||||
"hasInstallScript": true,
|
"hasInstallScript": true,
|
||||||
"funding": {
|
"funding": {
|
||||||
"type": "opencollective",
|
"type": "opencollective",
|
||||||
@ -14176,7 +14216,6 @@
|
|||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz",
|
||||||
"integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==",
|
"integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==",
|
||||||
"dev": true,
|
|
||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"node_modules/filesize": {
|
"node_modules/filesize": {
|
||||||
@ -14192,7 +14231,7 @@
|
|||||||
"version": "7.0.1",
|
"version": "7.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
|
||||||
"integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
|
"integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"to-regex-range": "^5.0.1"
|
"to-regex-range": "^5.0.1"
|
||||||
},
|
},
|
||||||
@ -14935,7 +14974,6 @@
|
|||||||
"version": "2.3.2",
|
"version": "2.3.2",
|
||||||
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
|
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
|
||||||
"integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
|
"integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
|
||||||
"dev": true,
|
|
||||||
"hasInstallScript": true,
|
"hasInstallScript": true,
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"os": [
|
"os": [
|
||||||
@ -15194,7 +15232,7 @@
|
|||||||
"version": "5.1.2",
|
"version": "5.1.2",
|
||||||
"resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
|
"resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
|
||||||
"integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
|
"integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"is-glob": "^4.0.1"
|
"is-glob": "^4.0.1"
|
||||||
},
|
},
|
||||||
@ -17040,7 +17078,7 @@
|
|||||||
"version": "2.1.0",
|
"version": "2.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
|
||||||
"integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
|
"integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"binary-extensions": "^2.0.0"
|
"binary-extensions": "^2.0.0"
|
||||||
},
|
},
|
||||||
@ -17194,7 +17232,7 @@
|
|||||||
"version": "2.1.1",
|
"version": "2.1.1",
|
||||||
"resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
|
"resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
|
||||||
"integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
|
"integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=0.10.0"
|
"node": ">=0.10.0"
|
||||||
}
|
}
|
||||||
@ -17230,7 +17268,7 @@
|
|||||||
"version": "4.0.1",
|
"version": "4.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
|
||||||
"integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
|
"integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"is-extglob": "^2.1.1"
|
"is-extglob": "^2.1.1"
|
||||||
},
|
},
|
||||||
@ -17272,7 +17310,7 @@
|
|||||||
"version": "7.0.0",
|
"version": "7.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
|
||||||
"integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
|
"integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=0.12.0"
|
"node": ">=0.12.0"
|
||||||
}
|
}
|
||||||
@ -22011,7 +22049,6 @@
|
|||||||
"version": "2.14.2",
|
"version": "2.14.2",
|
||||||
"resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz",
|
"resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz",
|
||||||
"integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==",
|
"integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==",
|
||||||
"dev": true,
|
|
||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"node_modules/nanomatch": {
|
"node_modules/nanomatch": {
|
||||||
@ -23118,7 +23155,7 @@
|
|||||||
"version": "1.0.2",
|
"version": "1.0.2",
|
||||||
"resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz",
|
"resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz",
|
||||||
"integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=",
|
"integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"node_modules/path-exists": {
|
"node_modules/path-exists": {
|
||||||
"version": "4.0.0",
|
"version": "4.0.0",
|
||||||
@ -23205,7 +23242,7 @@
|
|||||||
"version": "2.3.0",
|
"version": "2.3.0",
|
||||||
"resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz",
|
"resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz",
|
||||||
"integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==",
|
"integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=8.6"
|
"node": ">=8.6"
|
||||||
},
|
},
|
||||||
@ -24907,7 +24944,7 @@
|
|||||||
"version": "3.6.0",
|
"version": "3.6.0",
|
||||||
"resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
|
"resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
|
||||||
"integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
|
"integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"picomatch": "^2.2.1"
|
"picomatch": "^2.2.1"
|
||||||
},
|
},
|
||||||
@ -25886,7 +25923,7 @@
|
|||||||
"version": "1.1.0",
|
"version": "1.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
|
||||||
"integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=",
|
"integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"node_modules/rename-keys": {
|
"node_modules/rename-keys": {
|
||||||
"version": "1.2.0",
|
"version": "1.2.0",
|
||||||
@ -28716,7 +28753,7 @@
|
|||||||
"version": "5.0.1",
|
"version": "5.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
|
||||||
"integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
|
"integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"is-number": "^7.0.0"
|
"is-number": "^7.0.0"
|
||||||
},
|
},
|
||||||
@ -29326,7 +29363,7 @@
|
|||||||
"version": "1.2.0",
|
"version": "1.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/upath/-/upath-1.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/upath/-/upath-1.2.0.tgz",
|
||||||
"integrity": "sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==",
|
"integrity": "sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=4",
|
"node": ">=4",
|
||||||
"yarn": "*"
|
"yarn": "*"
|
||||||
@ -29769,7 +29806,6 @@
|
|||||||
"version": "2.0.1",
|
"version": "2.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/watchpack-chokidar2/-/watchpack-chokidar2-2.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/watchpack-chokidar2/-/watchpack-chokidar2-2.0.1.tgz",
|
||||||
"integrity": "sha512-nCFfBIPKr5Sh61s4LPpy1Wtfi0HE8isJ3d2Yb5/Ppw2P2B/3eVSEBjKfN0fmHJSK14+31KwMKmcrzs2GM4P0Ww==",
|
"integrity": "sha512-nCFfBIPKr5Sh61s4LPpy1Wtfi0HE8isJ3d2Yb5/Ppw2P2B/3eVSEBjKfN0fmHJSK14+31KwMKmcrzs2GM4P0Ww==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"chokidar": "^2.1.8"
|
"chokidar": "^2.1.8"
|
||||||
@ -29779,7 +29815,6 @@
|
|||||||
"version": "2.0.0",
|
"version": "2.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz",
|
||||||
"integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==",
|
"integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"micromatch": "^3.1.4",
|
"micromatch": "^3.1.4",
|
||||||
@ -29790,7 +29825,6 @@
|
|||||||
"version": "2.1.1",
|
"version": "2.1.1",
|
||||||
"resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz",
|
"resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz",
|
||||||
"integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=",
|
"integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"remove-trailing-separator": "^1.0.1"
|
"remove-trailing-separator": "^1.0.1"
|
||||||
@ -29803,7 +29837,6 @@
|
|||||||
"version": "1.13.1",
|
"version": "1.13.1",
|
||||||
"resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz",
|
"resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz",
|
||||||
"integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==",
|
"integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=0.10.0"
|
"node": ">=0.10.0"
|
||||||
@ -29813,7 +29846,6 @@
|
|||||||
"version": "2.3.2",
|
"version": "2.3.2",
|
||||||
"resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz",
|
"resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz",
|
||||||
"integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==",
|
"integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"arr-flatten": "^1.1.0",
|
"arr-flatten": "^1.1.0",
|
||||||
@ -29835,7 +29867,6 @@
|
|||||||
"version": "2.0.1",
|
"version": "2.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
|
||||||
"integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
|
"integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"is-extendable": "^0.1.0"
|
"is-extendable": "^0.1.0"
|
||||||
@ -29849,7 +29880,6 @@
|
|||||||
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz",
|
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz",
|
||||||
"integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==",
|
"integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==",
|
||||||
"deprecated": "Chokidar 2 will break on node v14+. Upgrade to chokidar 3 with 15x less dependencies.",
|
"deprecated": "Chokidar 2 will break on node v14+. Upgrade to chokidar 3 with 15x less dependencies.",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"anymatch": "^2.0.0",
|
"anymatch": "^2.0.0",
|
||||||
@ -29872,7 +29902,6 @@
|
|||||||
"version": "4.0.0",
|
"version": "4.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz",
|
||||||
"integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=",
|
"integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"extend-shallow": "^2.0.1",
|
"extend-shallow": "^2.0.1",
|
||||||
@ -29888,7 +29917,6 @@
|
|||||||
"version": "2.0.1",
|
"version": "2.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
|
||||||
"integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
|
"integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"is-extendable": "^0.1.0"
|
"is-extendable": "^0.1.0"
|
||||||
@ -29902,7 +29930,6 @@
|
|||||||
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.13.tgz",
|
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.13.tgz",
|
||||||
"integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==",
|
"integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==",
|
||||||
"deprecated": "fsevents 1 will break on node v14+ and could be using insecure binaries. Upgrade to fsevents 2.",
|
"deprecated": "fsevents 1 will break on node v14+ and could be using insecure binaries. Upgrade to fsevents 2.",
|
||||||
"dev": true,
|
|
||||||
"hasInstallScript": true,
|
"hasInstallScript": true,
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"os": [
|
"os": [
|
||||||
@ -29920,7 +29947,6 @@
|
|||||||
"version": "3.1.0",
|
"version": "3.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz",
|
||||||
"integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=",
|
"integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"is-glob": "^3.1.0",
|
"is-glob": "^3.1.0",
|
||||||
@ -29931,7 +29957,6 @@
|
|||||||
"version": "3.1.0",
|
"version": "3.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz",
|
||||||
"integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=",
|
"integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"is-extglob": "^2.1.0"
|
"is-extglob": "^2.1.0"
|
||||||
@ -29944,7 +29969,6 @@
|
|||||||
"version": "1.0.1",
|
"version": "1.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz",
|
||||||
"integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=",
|
"integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"binary-extensions": "^1.0.0"
|
"binary-extensions": "^1.0.0"
|
||||||
@ -29957,7 +29981,6 @@
|
|||||||
"version": "3.0.0",
|
"version": "3.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz",
|
||||||
"integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=",
|
"integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"kind-of": "^3.0.2"
|
"kind-of": "^3.0.2"
|
||||||
@ -29970,7 +29993,6 @@
|
|||||||
"version": "3.2.2",
|
"version": "3.2.2",
|
||||||
"resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
|
"resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
|
||||||
"integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
|
"integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"is-buffer": "^1.1.5"
|
"is-buffer": "^1.1.5"
|
||||||
@ -29983,7 +30005,6 @@
|
|||||||
"version": "6.0.3",
|
"version": "6.0.3",
|
||||||
"resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz",
|
"resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz",
|
||||||
"integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==",
|
"integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=0.10.0"
|
"node": ">=0.10.0"
|
||||||
@ -29993,7 +30014,6 @@
|
|||||||
"version": "3.1.10",
|
"version": "3.1.10",
|
||||||
"resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz",
|
"resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz",
|
||||||
"integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==",
|
"integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"arr-diff": "^4.0.0",
|
"arr-diff": "^4.0.0",
|
||||||
@ -30018,7 +30038,6 @@
|
|||||||
"version": "2.2.1",
|
"version": "2.2.1",
|
||||||
"resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz",
|
"resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz",
|
||||||
"integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==",
|
"integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"graceful-fs": "^4.1.11",
|
"graceful-fs": "^4.1.11",
|
||||||
@ -30033,7 +30052,6 @@
|
|||||||
"version": "2.1.1",
|
"version": "2.1.1",
|
||||||
"resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz",
|
"resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz",
|
||||||
"integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=",
|
"integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"is-number": "^3.0.0",
|
"is-number": "^3.0.0",
|
||||||
@ -33076,9 +33094,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"@babel/runtime": {
|
"@babel/runtime": {
|
||||||
"version": "7.14.6",
|
"version": "7.16.7",
|
||||||
"resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.14.6.tgz",
|
"resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.16.7.tgz",
|
||||||
"integrity": "sha512-/PCB2uJ7oM44tz8YhC4Z/6PeOKXp4K588f+5M3clr1M4zbqztlo0XEfJ2LEzj/FgwfgGcIdl8n7YYjTCI0BYwg==",
|
"integrity": "sha512-9E9FJowqAsytyOY6LG+1KuueckRL+aQW+mKvXRXnuFGyRAyepJPmEo9vgMfXUA6O9u3IeEdv9MAkppFcaQwogQ==",
|
||||||
"requires": {
|
"requires": {
|
||||||
"regenerator-runtime": "^0.13.4"
|
"regenerator-runtime": "^0.13.4"
|
||||||
}
|
}
|
||||||
@ -34436,6 +34454,11 @@
|
|||||||
"integrity": "sha512-H1rQc1ZOHANWBvPcW+JpGwr+juXSxM8Q8YCkm3GhZd8REu1fHR3z99CErO1p9pkcfcxZnMdIZdIsXkOHY0NilA==",
|
"integrity": "sha512-H1rQc1ZOHANWBvPcW+JpGwr+juXSxM8Q8YCkm3GhZd8REu1fHR3z99CErO1p9pkcfcxZnMdIZdIsXkOHY0NilA==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"@microsoft/fetch-event-source": {
|
||||||
|
"version": "2.0.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/@microsoft/fetch-event-source/-/fetch-event-source-2.0.1.tgz",
|
||||||
|
"integrity": "sha512-W6CLUJ2eBMw3Rec70qrsEW0jOm/3twwJv21mrmj2yORiaVmVYGS4sSS5yUwvQc1ZlDLYGPnClVWmUUMagKNsfA=="
|
||||||
|
},
|
||||||
"@mrmlnc/readdir-enhanced": {
|
"@mrmlnc/readdir-enhanced": {
|
||||||
"version": "2.2.1",
|
"version": "2.2.1",
|
||||||
"resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz",
|
"resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz",
|
||||||
@ -37325,6 +37348,35 @@
|
|||||||
"eslint-visitor-keys": "^2.0.0"
|
"eslint-visitor-keys": "^2.0.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"@urbit/api": {
|
||||||
|
"version": "2.1.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/@urbit/api/-/api-2.1.0.tgz",
|
||||||
|
"integrity": "sha512-2njwpvZ2s23gp5C4v9uDynU1wxrN33+vloqpvlErUhMR/4R6mXE4cMvsZzj/fCGOa0J3LRV/If7XmgG+kY69Tg==",
|
||||||
|
"requires": {
|
||||||
|
"@babel/runtime": "^7.16.0",
|
||||||
|
"big-integer": "^1.6.48",
|
||||||
|
"core-js": "^3.19.1",
|
||||||
|
"immer": "^9.0.1",
|
||||||
|
"urbit-ob": "^5.0.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"@urbit/eslint-config": {
|
||||||
|
"version": "1.0.3",
|
||||||
|
"resolved": "https://registry.npmjs.org/@urbit/eslint-config/-/eslint-config-1.0.3.tgz",
|
||||||
|
"integrity": "sha512-4mGd4GzzF+JMG/eAhjDQBjyVYo0xNbpcC7I16GouINLIuz5LJmNZ98SRQaOpfnsGIfTiZxwyZnfIX20orvWMxQ==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
|
"@urbit/http-api": {
|
||||||
|
"version": "2.1.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/@urbit/http-api/-/http-api-2.1.0.tgz",
|
||||||
|
"integrity": "sha512-eXYar3ofw1HlhHy2NSkJPCo//oZzfnrGXIJAKQ/gWSzd8x3o7eiiIQjoFbuWojaACy8T9fXsGzpxEqoXZlWDhw==",
|
||||||
|
"requires": {
|
||||||
|
"@babel/runtime": "^7.12.5",
|
||||||
|
"@microsoft/fetch-event-source": "^2.0.0",
|
||||||
|
"browser-or-node": "^1.3.0",
|
||||||
|
"core-js": "^3.19.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
"@webassemblyjs/ast": {
|
"@webassemblyjs/ast": {
|
||||||
"version": "1.9.0",
|
"version": "1.9.0",
|
||||||
"resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.9.0.tgz",
|
"resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.9.0.tgz",
|
||||||
@ -37718,7 +37770,7 @@
|
|||||||
"version": "3.1.2",
|
"version": "3.1.2",
|
||||||
"resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz",
|
"resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz",
|
||||||
"integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==",
|
"integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"normalize-path": "^3.0.0",
|
"normalize-path": "^3.0.0",
|
||||||
"picomatch": "^2.0.4"
|
"picomatch": "^2.0.4"
|
||||||
@ -37954,7 +38006,7 @@
|
|||||||
"version": "1.0.3",
|
"version": "1.0.3",
|
||||||
"resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz",
|
"resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz",
|
||||||
"integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==",
|
"integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"async-limiter": {
|
"async-limiter": {
|
||||||
"version": "1.0.1",
|
"version": "1.0.1",
|
||||||
@ -38533,13 +38585,12 @@
|
|||||||
"version": "2.2.0",
|
"version": "2.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
|
||||||
"integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
|
"integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"bindings": {
|
"bindings": {
|
||||||
"version": "1.5.0",
|
"version": "1.5.0",
|
||||||
"resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz",
|
"resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz",
|
||||||
"integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==",
|
"integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"file-uri-to-path": "1.0.0"
|
"file-uri-to-path": "1.0.0"
|
||||||
@ -38742,7 +38793,7 @@
|
|||||||
"version": "3.0.2",
|
"version": "3.0.2",
|
||||||
"resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
|
"resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
|
||||||
"integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
|
"integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"fill-range": "^7.0.1"
|
"fill-range": "^7.0.1"
|
||||||
}
|
}
|
||||||
@ -38752,6 +38803,11 @@
|
|||||||
"resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz",
|
||||||
"integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8="
|
"integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8="
|
||||||
},
|
},
|
||||||
|
"browser-or-node": {
|
||||||
|
"version": "1.3.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/browser-or-node/-/browser-or-node-1.3.0.tgz",
|
||||||
|
"integrity": "sha512-0F2z/VSnLbmEeBcUrSuDH5l0HxTXdQQzLjkmBR4cYfvg1zJrKSlmIZFqyFR8oX0NrwPhy3c3HQ6i3OxMbew4Tg=="
|
||||||
|
},
|
||||||
"browser-process-hrtime": {
|
"browser-process-hrtime": {
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz",
|
||||||
@ -39284,7 +39340,7 @@
|
|||||||
"version": "3.5.2",
|
"version": "3.5.2",
|
||||||
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz",
|
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz",
|
||||||
"integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==",
|
"integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"anymatch": "~3.1.2",
|
"anymatch": "~3.1.2",
|
||||||
"braces": "~3.0.2",
|
"braces": "~3.0.2",
|
||||||
@ -40092,10 +40148,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"core-js": {
|
"core-js": {
|
||||||
"version": "3.15.2",
|
"version": "3.20.2",
|
||||||
"resolved": "https://registry.npmjs.org/core-js/-/core-js-3.15.2.tgz",
|
"resolved": "https://registry.npmjs.org/core-js/-/core-js-3.20.2.tgz",
|
||||||
"integrity": "sha512-tKs41J7NJVuaya8DxIOCnl8QuPHx5/ZVbFo1oKgVl1qHFBBrDctzQGtuLjPpRdNTWmKPH6oEvgN/MUID+l485Q==",
|
"integrity": "sha512-nuqhq11DcOAbFBV4zCbKeGbKQsUDRqTX0oqx7AttUBuqe3h20ixsE039QHelbL6P4h+9kytVqyEtyZ6gsiwEYw=="
|
||||||
"dev": true
|
|
||||||
},
|
},
|
||||||
"core-js-compat": {
|
"core-js-compat": {
|
||||||
"version": "3.15.2",
|
"version": "3.15.2",
|
||||||
@ -42513,7 +42568,6 @@
|
|||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz",
|
||||||
"integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==",
|
"integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==",
|
||||||
"dev": true,
|
|
||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"filesize": {
|
"filesize": {
|
||||||
@ -42526,7 +42580,7 @@
|
|||||||
"version": "7.0.1",
|
"version": "7.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
|
||||||
"integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
|
"integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"to-regex-range": "^5.0.1"
|
"to-regex-range": "^5.0.1"
|
||||||
}
|
}
|
||||||
@ -43121,7 +43175,6 @@
|
|||||||
"version": "2.3.2",
|
"version": "2.3.2",
|
||||||
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
|
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
|
||||||
"integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
|
"integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
|
||||||
"dev": true,
|
|
||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"function-bind": {
|
"function-bind": {
|
||||||
@ -43320,7 +43373,7 @@
|
|||||||
"version": "5.1.2",
|
"version": "5.1.2",
|
||||||
"resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
|
"resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
|
||||||
"integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
|
"integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-glob": "^4.0.1"
|
"is-glob": "^4.0.1"
|
||||||
}
|
}
|
||||||
@ -44723,7 +44776,7 @@
|
|||||||
"version": "2.1.0",
|
"version": "2.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
|
||||||
"integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
|
"integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"binary-extensions": "^2.0.0"
|
"binary-extensions": "^2.0.0"
|
||||||
}
|
}
|
||||||
@ -44827,7 +44880,7 @@
|
|||||||
"version": "2.1.1",
|
"version": "2.1.1",
|
||||||
"resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
|
"resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
|
||||||
"integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
|
"integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"is-fullwidth-code-point": {
|
"is-fullwidth-code-point": {
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
@ -44854,7 +44907,7 @@
|
|||||||
"version": "4.0.1",
|
"version": "4.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
|
||||||
"integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
|
"integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-extglob": "^2.1.1"
|
"is-extglob": "^2.1.1"
|
||||||
}
|
}
|
||||||
@ -44880,7 +44933,7 @@
|
|||||||
"version": "7.0.0",
|
"version": "7.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
|
||||||
"integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
|
"integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"is-number-object": {
|
"is-number-object": {
|
||||||
"version": "1.0.5",
|
"version": "1.0.5",
|
||||||
@ -48465,7 +48518,6 @@
|
|||||||
"version": "2.14.2",
|
"version": "2.14.2",
|
||||||
"resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz",
|
"resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz",
|
||||||
"integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==",
|
"integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==",
|
||||||
"dev": true,
|
|
||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"nanomatch": {
|
"nanomatch": {
|
||||||
@ -49351,7 +49403,7 @@
|
|||||||
"version": "1.0.2",
|
"version": "1.0.2",
|
||||||
"resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz",
|
"resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz",
|
||||||
"integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=",
|
"integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"path-exists": {
|
"path-exists": {
|
||||||
"version": "4.0.0",
|
"version": "4.0.0",
|
||||||
@ -49425,7 +49477,7 @@
|
|||||||
"version": "2.3.0",
|
"version": "2.3.0",
|
||||||
"resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz",
|
"resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz",
|
||||||
"integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==",
|
"integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"pify": {
|
"pify": {
|
||||||
"version": "4.0.1",
|
"version": "4.0.1",
|
||||||
@ -50734,7 +50786,7 @@
|
|||||||
"version": "3.6.0",
|
"version": "3.6.0",
|
||||||
"resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
|
"resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
|
||||||
"integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
|
"integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"picomatch": "^2.2.1"
|
"picomatch": "^2.2.1"
|
||||||
}
|
}
|
||||||
@ -51454,7 +51506,7 @@
|
|||||||
"version": "1.1.0",
|
"version": "1.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
|
||||||
"integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=",
|
"integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"rename-keys": {
|
"rename-keys": {
|
||||||
"version": "1.2.0",
|
"version": "1.2.0",
|
||||||
@ -53696,7 +53748,7 @@
|
|||||||
"version": "5.0.1",
|
"version": "5.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
|
||||||
"integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
|
"integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
|
||||||
"dev": true,
|
"devOptional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-number": "^7.0.0"
|
"is-number": "^7.0.0"
|
||||||
}
|
}
|
||||||
@ -54164,7 +54216,7 @@
|
|||||||
"version": "1.2.0",
|
"version": "1.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/upath/-/upath-1.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/upath/-/upath-1.2.0.tgz",
|
||||||
"integrity": "sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==",
|
"integrity": "sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==",
|
||||||
"dev": true
|
"devOptional": true
|
||||||
},
|
},
|
||||||
"urbit-ob": {
|
"urbit-ob": {
|
||||||
"version": "5.0.1",
|
"version": "5.0.1",
|
||||||
@ -54514,7 +54566,6 @@
|
|||||||
"version": "2.0.1",
|
"version": "2.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/watchpack-chokidar2/-/watchpack-chokidar2-2.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/watchpack-chokidar2/-/watchpack-chokidar2-2.0.1.tgz",
|
||||||
"integrity": "sha512-nCFfBIPKr5Sh61s4LPpy1Wtfi0HE8isJ3d2Yb5/Ppw2P2B/3eVSEBjKfN0fmHJSK14+31KwMKmcrzs2GM4P0Ww==",
|
"integrity": "sha512-nCFfBIPKr5Sh61s4LPpy1Wtfi0HE8isJ3d2Yb5/Ppw2P2B/3eVSEBjKfN0fmHJSK14+31KwMKmcrzs2GM4P0Ww==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"chokidar": "^2.1.8"
|
"chokidar": "^2.1.8"
|
||||||
@ -54524,7 +54575,6 @@
|
|||||||
"version": "2.0.0",
|
"version": "2.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz",
|
||||||
"integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==",
|
"integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"micromatch": "^3.1.4",
|
"micromatch": "^3.1.4",
|
||||||
@ -54535,7 +54585,6 @@
|
|||||||
"version": "2.1.1",
|
"version": "2.1.1",
|
||||||
"resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz",
|
"resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz",
|
||||||
"integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=",
|
"integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"remove-trailing-separator": "^1.0.1"
|
"remove-trailing-separator": "^1.0.1"
|
||||||
@ -54547,14 +54596,12 @@
|
|||||||
"version": "1.13.1",
|
"version": "1.13.1",
|
||||||
"resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz",
|
"resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz",
|
||||||
"integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==",
|
"integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==",
|
||||||
"dev": true,
|
|
||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"braces": {
|
"braces": {
|
||||||
"version": "2.3.2",
|
"version": "2.3.2",
|
||||||
"resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz",
|
"resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz",
|
||||||
"integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==",
|
"integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"arr-flatten": "^1.1.0",
|
"arr-flatten": "^1.1.0",
|
||||||
@ -54573,7 +54620,6 @@
|
|||||||
"version": "2.0.1",
|
"version": "2.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
|
||||||
"integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
|
"integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-extendable": "^0.1.0"
|
"is-extendable": "^0.1.0"
|
||||||
@ -54585,7 +54631,6 @@
|
|||||||
"version": "2.1.8",
|
"version": "2.1.8",
|
||||||
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz",
|
"resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz",
|
||||||
"integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==",
|
"integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"anymatch": "^2.0.0",
|
"anymatch": "^2.0.0",
|
||||||
@ -54606,7 +54651,6 @@
|
|||||||
"version": "4.0.0",
|
"version": "4.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz",
|
||||||
"integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=",
|
"integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"extend-shallow": "^2.0.1",
|
"extend-shallow": "^2.0.1",
|
||||||
@ -54619,7 +54663,6 @@
|
|||||||
"version": "2.0.1",
|
"version": "2.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
|
||||||
"integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
|
"integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-extendable": "^0.1.0"
|
"is-extendable": "^0.1.0"
|
||||||
@ -54631,7 +54674,6 @@
|
|||||||
"version": "1.2.13",
|
"version": "1.2.13",
|
||||||
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.13.tgz",
|
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.13.tgz",
|
||||||
"integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==",
|
"integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"bindings": "^1.5.0",
|
"bindings": "^1.5.0",
|
||||||
@ -54642,7 +54684,6 @@
|
|||||||
"version": "3.1.0",
|
"version": "3.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz",
|
||||||
"integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=",
|
"integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-glob": "^3.1.0",
|
"is-glob": "^3.1.0",
|
||||||
@ -54653,7 +54694,6 @@
|
|||||||
"version": "3.1.0",
|
"version": "3.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz",
|
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz",
|
||||||
"integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=",
|
"integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-extglob": "^2.1.0"
|
"is-extglob": "^2.1.0"
|
||||||
@ -54665,7 +54705,6 @@
|
|||||||
"version": "1.0.1",
|
"version": "1.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz",
|
||||||
"integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=",
|
"integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"binary-extensions": "^1.0.0"
|
"binary-extensions": "^1.0.0"
|
||||||
@ -54675,7 +54714,6 @@
|
|||||||
"version": "3.0.0",
|
"version": "3.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz",
|
||||||
"integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=",
|
"integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"kind-of": "^3.0.2"
|
"kind-of": "^3.0.2"
|
||||||
@ -54685,7 +54723,6 @@
|
|||||||
"version": "3.2.2",
|
"version": "3.2.2",
|
||||||
"resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
|
"resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
|
||||||
"integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
|
"integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-buffer": "^1.1.5"
|
"is-buffer": "^1.1.5"
|
||||||
@ -54697,14 +54734,12 @@
|
|||||||
"version": "6.0.3",
|
"version": "6.0.3",
|
||||||
"resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz",
|
"resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz",
|
||||||
"integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==",
|
"integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==",
|
||||||
"dev": true,
|
|
||||||
"optional": true
|
"optional": true
|
||||||
},
|
},
|
||||||
"micromatch": {
|
"micromatch": {
|
||||||
"version": "3.1.10",
|
"version": "3.1.10",
|
||||||
"resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz",
|
"resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz",
|
||||||
"integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==",
|
"integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"arr-diff": "^4.0.0",
|
"arr-diff": "^4.0.0",
|
||||||
@ -54726,7 +54761,6 @@
|
|||||||
"version": "2.2.1",
|
"version": "2.2.1",
|
||||||
"resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz",
|
"resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz",
|
||||||
"integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==",
|
"integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"graceful-fs": "^4.1.11",
|
"graceful-fs": "^4.1.11",
|
||||||
@ -54738,7 +54772,6 @@
|
|||||||
"version": "2.1.1",
|
"version": "2.1.1",
|
||||||
"resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz",
|
"resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz",
|
||||||
"integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=",
|
"integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=",
|
||||||
"dev": true,
|
|
||||||
"optional": true,
|
"optional": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-number": "^3.0.0",
|
"is-number": "^3.0.0",
|
||||||
|
@ -15,8 +15,8 @@
|
|||||||
"@tlon/indigo-light": "^1.0.7",
|
"@tlon/indigo-light": "^1.0.7",
|
||||||
"@tlon/indigo-react": "^1.2.27",
|
"@tlon/indigo-react": "^1.2.27",
|
||||||
"@tlon/sigil-js": "^1.4.3",
|
"@tlon/sigil-js": "^1.4.3",
|
||||||
"@urbit/api": "^1.4.0",
|
"@urbit/api": "^2.1.0",
|
||||||
"@urbit/http-api": "^1.2.1",
|
"@urbit/http-api": "^2.1.0",
|
||||||
"any-ascii": "^0.1.7",
|
"any-ascii": "^0.1.7",
|
||||||
"aws-sdk": "^2.830.0",
|
"aws-sdk": "^2.830.0",
|
||||||
"big-integer": "^1.6.48",
|
"big-integer": "^1.6.48",
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { Content, GraphNode, unixToDa } from '@urbit/api';
|
import { BigIntOrderedMap, Content, GraphNode, unixToDa } from '@urbit/api';
|
||||||
import BigIntOrderedMap from '@urbit/api/lib/BigIntOrderedMap';
|
|
||||||
import bigInt, { BigInteger } from 'big-integer';
|
import bigInt, { BigInteger } from 'big-integer';
|
||||||
|
|
||||||
export const makeComment = (
|
export const makeComment = (
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { deSig, Path, PatpNoSig } from '@urbit/api';
|
import { deSig, Path, PatpNoSig, Group, Resource, roleTags, RoleTags } from '@urbit/api';
|
||||||
import { Group, Resource, roleTags, RoleTags } from '@urbit/api/groups';
|
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
|
|
||||||
export function roleForShip(
|
export function roleForShip(
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { Content, GraphNode, Post, TextContent } from '@urbit/api';
|
import { BigIntOrderedMap, Content, GraphNode, Post, TextContent } from '@urbit/api';
|
||||||
import BigIntOrderedMap from '@urbit/api/lib/BigIntOrderedMap';
|
|
||||||
import bigInt, { BigInteger } from 'big-integer';
|
import bigInt, { BigInteger } from 'big-integer';
|
||||||
import { buntPost } from '~/logic/lib/post';
|
import { buntPost } from '~/logic/lib/post';
|
||||||
import { unixToDa } from '~/logic/lib/util';
|
import { unixToDa } from '~/logic/lib/util';
|
||||||
|
@ -1,9 +1,4 @@
|
|||||||
import { GraphNode } from '@urbit/api';
|
import { arrToString, stringToArr, BigIntOrderedMap, BigIntArrayOrderedMap, GraphNode } from '@urbit/api';
|
||||||
import BigIntOrderedMap from '@urbit/api/lib/BigIntOrderedMap';
|
|
||||||
import BigIntArrayOrderedMap, {
|
|
||||||
arrToString,
|
|
||||||
stringToArr
|
|
||||||
} from '@urbit/api/lib/BigIntArrayOrderedMap';
|
|
||||||
import bigInt, { BigInteger } from 'big-integer';
|
import bigInt, { BigInteger } from 'big-integer';
|
||||||
import produce from 'immer';
|
import produce from 'immer';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
|
@ -1,11 +1,9 @@
|
|||||||
import { Enc } from '@urbit/api';
|
|
||||||
import {
|
import {
|
||||||
|
Enc,
|
||||||
Group,
|
Group,
|
||||||
|
|
||||||
GroupPolicy, GroupUpdate,
|
GroupPolicy, GroupUpdate,
|
||||||
|
|
||||||
InvitePolicy, InvitePolicyDiff, OpenPolicy, OpenPolicyDiff, Tags
|
InvitePolicy, InvitePolicyDiff, OpenPolicy, OpenPolicyDiff, Tags
|
||||||
} from '@urbit/api/groups';
|
} from '@urbit/api';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { Cage } from '~/types/cage';
|
import { Cage } from '~/types/cage';
|
||||||
import { resourceAsPath } from '../lib/util';
|
import { resourceAsPath } from '../lib/util';
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
import {
|
import {
|
||||||
|
BigIntOrderedMap,
|
||||||
HarkPlace,
|
HarkPlace,
|
||||||
Timebox,
|
Timebox,
|
||||||
HarkStats,
|
HarkStats,
|
||||||
harkBinToId,
|
harkBinToId,
|
||||||
makePatDa
|
makePatDa
|
||||||
} from '@urbit/api';
|
} from '@urbit/api';
|
||||||
import BigIntOrderedMap from '@urbit/api/lib/BigIntOrderedMap';
|
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { compose } from 'lodash/fp';
|
import { compose } from 'lodash/fp';
|
||||||
import { BaseState } from '../state/base';
|
import { BaseState } from '../state/base';
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { InviteUpdate } from '@urbit/api/invite';
|
import { InviteUpdate } from '@urbit/api';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { BaseState } from '../state/base';
|
import { BaseState } from '../state/base';
|
||||||
import { InviteState as State } from '../state/invite';
|
import { InviteState as State } from '../state/invite';
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { MetadataUpdate, Associations, ResourceAssociations } from '@urbit/api/metadata';
|
import { MetadataUpdate, Associations, ResourceAssociations } from '@urbit/api';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { Cage } from '~/types/cage';
|
import { Cage } from '~/types/cage';
|
||||||
import { BaseState } from '../state/base';
|
import { BaseState } from '../state/base';
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { SettingsUpdate } from '@urbit/api/settings';
|
import { SettingsUpdate } from '@urbit/api';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { SettingsState as State } from '~/logic/state/settings';
|
import { SettingsState as State } from '~/logic/state/settings';
|
||||||
import { BaseState } from '../state/base';
|
import { BaseState } from '../state/base';
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
import BigIntOrderedMap from '@urbit/api/lib/BigIntOrderedMap';
|
|
||||||
import { patp2dec } from 'urbit-ob';
|
import { patp2dec } from 'urbit-ob';
|
||||||
import shallow from 'zustand/shallow';
|
import shallow from 'zustand/shallow';
|
||||||
|
import {
|
||||||
import { Association, deSig, GraphNode, Graphs, FlatGraphs, resourceFromPath, ThreadGraphs, getGraph, getShallowChildren, setScreen } from '@urbit/api';
|
Association, BigIntOrderedMap, deSig, GraphNode, Graphs, FlatGraphs, resourceFromPath, ThreadGraphs, getGraph, getShallowChildren, setScreen,
|
||||||
|
addDmMessage, addPost, Content, getDeepOlderThan, getFirstborn, getNewest, getNode, getOlderSiblings, getYoungerSiblings, markPending, Post, addNode, GraphNodePoke
|
||||||
|
} from '@urbit/api';
|
||||||
import { useCallback } from 'react';
|
import { useCallback } from 'react';
|
||||||
import { createState, createSubscription, reduceStateN, pokeOptimisticallyN } from './base';
|
import { createState, createSubscription, reduceStateN, pokeOptimisticallyN } from './base';
|
||||||
import airlock from '~/logic/api';
|
import airlock from '~/logic/api';
|
||||||
import { addDmMessage, addPost, Content, getDeepOlderThan, getFirstborn, getNewest, getNode, getOlderSiblings, getYoungerSiblings, markPending, Post, addNode, GraphNodePoke } from '@urbit/api/graph';
|
|
||||||
import { GraphReducer, reduceDm } from '../reducers/graph-update';
|
import { GraphReducer, reduceDm } from '../reducers/graph-update';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { clone } from '../lib/util';
|
import { clone } from '../lib/util';
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import {
|
import {
|
||||||
archive,
|
archive,
|
||||||
|
BigIntOrderedMap,
|
||||||
HarkBin,
|
HarkBin,
|
||||||
markCountAsRead,
|
markCountAsRead,
|
||||||
NotificationGraphConfig,
|
NotificationGraphConfig,
|
||||||
@ -15,7 +16,6 @@ import {
|
|||||||
import { Poke } from '@urbit/http-api';
|
import { Poke } from '@urbit/http-api';
|
||||||
import { patp2dec } from 'urbit-ob';
|
import { patp2dec } from 'urbit-ob';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import BigIntOrderedMap from '@urbit/api/lib/BigIntOrderedMap';
|
|
||||||
import api from '~/logic/api';
|
import api from '~/logic/api';
|
||||||
import { useCallback, useMemo } from 'react';
|
import { useCallback, useMemo } from 'react';
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { Association, Associations, MetadataUpdatePreview } from '@urbit/api/metadata';
|
import { Association, Associations, MetadataUpdatePreview } from '@urbit/api';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { useCallback, useEffect, useState } from 'react';
|
import { useCallback, useEffect, useState } from 'react';
|
||||||
import {
|
import {
|
||||||
|
@ -16,8 +16,7 @@ import {
|
|||||||
import { useCallback } from 'react';
|
import { useCallback } from 'react';
|
||||||
import { reduceUpdate } from '../reducers/settings-update';
|
import { reduceUpdate } from '../reducers/settings-update';
|
||||||
import airlock from '~/logic/api';
|
import airlock from '~/logic/api';
|
||||||
import { Contact, getDeskSettings, Value } from '@urbit/api';
|
import { Contact, getDeskSettings, putEntry, Value } from '@urbit/api';
|
||||||
import { putEntry } from '@urbit/api/settings';
|
|
||||||
|
|
||||||
export interface ShortcutMapping {
|
export interface ShortcutMapping {
|
||||||
cycleForward: string;
|
cycleForward: string;
|
||||||
|
@ -3,7 +3,7 @@ import { Meta, Story } from '@storybook/react';
|
|||||||
|
|
||||||
import { Box } from '@tlon/indigo-react';
|
import { Box } from '@tlon/indigo-react';
|
||||||
import { InviteItem, InviteItemProps } from '~/views/components/Invite';
|
import { InviteItem, InviteItemProps } from '~/views/components/Invite';
|
||||||
import { JoinProgress } from '@urbit/api/groups';
|
import { JoinProgress } from '@urbit/api';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
title: 'Notifications/Invite',
|
title: 'Notifications/Invite',
|
||||||
|
@ -4,8 +4,7 @@ import { withDesign } from 'storybook-addon-designs';
|
|||||||
|
|
||||||
import { Col, Row } from '@tlon/indigo-react';
|
import { Col, Row } from '@tlon/indigo-react';
|
||||||
import { LinkBlockItem } from '~/views/apps/links/components/LinkBlockItem';
|
import { LinkBlockItem } from '~/views/apps/links/components/LinkBlockItem';
|
||||||
import { createPost, GraphNode } from '@urbit/api';
|
import { BigIntOrderedMap, createPost, GraphNode } from '@urbit/api';
|
||||||
import BigIntOrderedMap from '@urbit/api/lib/BigIntOrderedMap';
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
title: 'Collections/BlockItem',
|
title: 'Collections/BlockItem',
|
||||||
|
@ -4,8 +4,7 @@ import { withDesign } from 'storybook-addon-designs';
|
|||||||
|
|
||||||
import { Box } from '@tlon/indigo-react';
|
import { Box } from '@tlon/indigo-react';
|
||||||
import { LinkDetail } from '~/views/apps/links/components/LinkDetail';
|
import { LinkDetail } from '~/views/apps/links/components/LinkDetail';
|
||||||
import BigIntOrderedMap from '@urbit/api/lib/BigIntOrderedMap';
|
import { BigIntOrderedMap, GraphNode } from '@urbit/api';
|
||||||
import { GraphNode } from '@urbit/api';
|
|
||||||
import useMetadataState from '~/logic/state/metadata';
|
import useMetadataState from '~/logic/state/metadata';
|
||||||
import { makeComment } from '~/logic/lib/fixtures';
|
import { makeComment } from '~/logic/lib/fixtures';
|
||||||
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { ContactUpdate, GroupUpdate, InviteUpdate, MetadataUpdate } from '@urbit/api';
|
import { ContactUpdate, GroupUpdate, InviteUpdate, MetadataUpdate, SettingsUpdate } from '@urbit/api';
|
||||||
import { SettingsUpdate } from '@urbit/api/settings';
|
|
||||||
import { ConnectionStatus } from './connection';
|
import { ConnectionStatus } from './connection';
|
||||||
import { LaunchUpdate, WeatherState } from './launch-update';
|
import { LaunchUpdate, WeatherState } from './launch-update';
|
||||||
import { LocalUpdate } from './local-update';
|
import { LocalUpdate } from './local-update';
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { Content, createPost, fetchIsAllowed, Post, removePosts, deSig } from '@urbit/api';
|
import { Association, Content, createPost, fetchIsAllowed, Post, removePosts, deSig } from '@urbit/api';
|
||||||
import { Association } from '@urbit/api/metadata';
|
|
||||||
import { BigInteger } from 'big-integer';
|
import { BigInteger } from 'big-integer';
|
||||||
import React, {
|
import React, {
|
||||||
ReactElement, useCallback,
|
ReactElement, useCallback,
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
import { Box, Center, Col, LoadingSpinner, Text } from '@tlon/indigo-react';
|
import { Box, Center, Col, LoadingSpinner, Text } from '@tlon/indigo-react';
|
||||||
import { deSig, Group } from '@urbit/api';
|
import { Association, deSig, Group } from '@urbit/api';
|
||||||
import { Association } from '@urbit/api/metadata';
|
|
||||||
import bigInt from 'big-integer';
|
import bigInt from 'big-integer';
|
||||||
import React, { useEffect } from 'react';
|
import React, { useEffect } from 'react';
|
||||||
import { Link, Route, Switch, useLocation } from 'react-router-dom';
|
import { Link, Route, Switch, useLocation } from 'react-router-dom';
|
||||||
|
@ -1,12 +1,11 @@
|
|||||||
import { Col, Row, Text } from '@tlon/indigo-react';
|
import { Col, Row, Text } from '@tlon/indigo-react';
|
||||||
import { Association, Graph, GraphNode, markEachAsRead } from '@urbit/api';
|
import { Association, BigIntOrderedMap, Graph, GraphNode, markEachAsRead } from '@urbit/api';
|
||||||
import React, { useCallback, useState, useMemo, useEffect } from 'react';
|
import React, { useCallback, useState, useMemo, useEffect } from 'react';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { useResize } from '~/logic/lib/useResize';
|
import { useResize } from '~/logic/lib/useResize';
|
||||||
import { LinkBlockItem } from './LinkBlockItem';
|
import { LinkBlockItem } from './LinkBlockItem';
|
||||||
import { LinkBlockInput } from './LinkBlockInput';
|
import { LinkBlockInput } from './LinkBlockInput';
|
||||||
import useLocalState from '~/logic/state/local';
|
import useLocalState from '~/logic/state/local';
|
||||||
import BigIntOrderedMap from '@urbit/api/lib/BigIntOrderedMap';
|
|
||||||
import bigInt from 'big-integer';
|
import bigInt from 'big-integer';
|
||||||
import airlock from '~/logic/api';
|
import airlock from '~/logic/api';
|
||||||
import useHarkState, { selHarkGraph } from '~/logic/state/hark';
|
import useHarkState, { selHarkGraph } from '~/logic/state/hark';
|
||||||
|
@ -3,7 +3,7 @@ import { Box, Row, Text } from '@tlon/indigo-react';
|
|||||||
import { StatelessAsyncAction } from '~/views/components/StatelessAsyncAction';
|
import { StatelessAsyncAction } from '~/views/components/StatelessAsyncAction';
|
||||||
import Author from '~/views/components/Author';
|
import Author from '~/views/components/Author';
|
||||||
import { useHistory } from 'react-router';
|
import { useHistory } from 'react-router';
|
||||||
import { acceptDm, declineDm } from '@urbit/api/graph';
|
import { acceptDm, declineDm } from '@urbit/api';
|
||||||
import airlock from '~/logic/api';
|
import airlock from '~/logic/api';
|
||||||
|
|
||||||
export function PendingDm(props: { ship: string; }) {
|
export function PendingDm(props: { ship: string; }) {
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
import { Box, Col, Icon, Image, Row, Text } from '@tlon/indigo-react';
|
import { Box, Col, Icon, Image, Row, Text } from '@tlon/indigo-react';
|
||||||
import { Group } from '@urbit/api';
|
import { Group, GraphNode } from '@urbit/api';
|
||||||
import { GraphNode } from '@urbit/api/graph';
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import ReactMarkdown from 'react-markdown';
|
import ReactMarkdown from 'react-markdown';
|
||||||
import { Link } from 'react-router-dom';
|
import { Link } from 'react-router-dom';
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { addNodes, Association } from '@urbit/api';
|
import { addNodes, Association, Graph } from '@urbit/api';
|
||||||
import { Graph } from '@urbit/api/graph';
|
|
||||||
import { FormikHelpers } from 'formik';
|
import { FormikHelpers } from 'formik';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { RouteComponentProps } from 'react-router-dom';
|
import { RouteComponentProps } from 'react-router-dom';
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
import { Action, Box, Col, Icon, Row, Text } from '@tlon/indigo-react';
|
import { Action, Box, Col, Icon, Row, Text } from '@tlon/indigo-react';
|
||||||
import { Group, removePosts } from '@urbit/api';
|
import { GraphNode, Group, removePosts } from '@urbit/api';
|
||||||
import { GraphNode } from '@urbit/api/graph';
|
|
||||||
import bigInt from 'big-integer';
|
import bigInt from 'big-integer';
|
||||||
import React, { useCallback, useEffect, useRef } from 'react';
|
import React, { useCallback, useEffect, useRef } from 'react';
|
||||||
import { roleForShip } from '~/logic/lib/group';
|
import { roleForShip } from '~/logic/lib/group';
|
||||||
|
@ -6,8 +6,7 @@ import {
|
|||||||
ErrorLabel, Icon, Label,
|
ErrorLabel, Icon, Label,
|
||||||
Row, Text
|
Row, Text
|
||||||
} from '@tlon/indigo-react';
|
} from '@tlon/indigo-react';
|
||||||
import { OpenPolicy } from '@urbit/api';
|
import { Association, OpenPolicy } from '@urbit/api';
|
||||||
import { Association } from '@urbit/api/metadata';
|
|
||||||
import { FieldArray, useFormikContext } from 'formik';
|
import { FieldArray, useFormikContext } from 'formik';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import React, { ReactElement, useMemo, useState } from 'react';
|
import React, { ReactElement, useMemo, useState } from 'react';
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { JoinRequest } from '@urbit/api';
|
import { Invite, JoinRequest } from '@urbit/api';
|
||||||
import { Invite } from '@urbit/api/invite';
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { usePreview } from '~/logic/state/metadata';
|
import { usePreview } from '~/logic/state/metadata';
|
||||||
import { GroupInvite } from './Group';
|
import { GroupInvite } from './Group';
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
import { BigInteger } from 'big-integer';
|
import { BigInteger } from 'big-integer';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import VirtualScroller, { VirtualScrollerProps } from './VirtualScroller';
|
import VirtualScroller, { VirtualScrollerProps } from './VirtualScroller';
|
||||||
|
import { arrToString, FlatGraphNode } from '@urbit/api';
|
||||||
import { arrToString } from '@urbit/api/lib/BigIntArrayOrderedMap';
|
|
||||||
import { FlatGraphNode } from '@urbit/api';
|
|
||||||
|
|
||||||
type ThreadScrollerProps = Omit<
|
type ThreadScrollerProps = Omit<
|
||||||
VirtualScrollerProps<BigInteger[], FlatGraphNode>,
|
VirtualScrollerProps<BigInteger[], FlatGraphNode>,
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
import { Box, Center, Col, Text } from '@tlon/indigo-react';
|
import { Box, Center, Col, Text } from '@tlon/indigo-react';
|
||||||
import { joinGraph } from '@urbit/api/graph';
|
import { Association, GraphConfig, joinGraph } from '@urbit/api';
|
||||||
import { Association, GraphConfig } from '@urbit/api/metadata';
|
|
||||||
import React, { useEffect, useMemo, useState } from 'react';
|
import React, { useEffect, useMemo, useState } from 'react';
|
||||||
import { useHistory } from 'react-router-dom';
|
import { useHistory } from 'react-router-dom';
|
||||||
import { useQuery } from '~/logic/lib/useQuery';
|
import { useQuery } from '~/logic/lib/useQuery';
|
||||||
|
@ -5,9 +5,7 @@ import {
|
|||||||
Text
|
Text
|
||||||
} from '@tlon/indigo-react';
|
} from '@tlon/indigo-react';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { changePolicy, deSig, Enc } from '@urbit/api';
|
import { Association, changePolicy, deSig, Enc, Group, GroupPolicy, metadataEdit, MetadataEditField } from '@urbit/api';
|
||||||
import { Group, GroupPolicy } from '@urbit/api/groups';
|
|
||||||
import { Association, metadataEdit, MetadataEditField } from '@urbit/api/metadata';
|
|
||||||
import { Form, Formik, FormikHelpers } from 'formik';
|
import { Form, Formik, FormikHelpers } from 'formik';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import * as Yup from 'yup';
|
import * as Yup from 'yup';
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
import { Box, Button, Col, Text } from '@tlon/indigo-react';
|
import { Box, Button, Col, Text } from '@tlon/indigo-react';
|
||||||
import { deSig } from '@urbit/api';
|
import { Association, deSig, Group } from '@urbit/api';
|
||||||
import { Group } from '@urbit/api/groups';
|
|
||||||
import { Association } from '@urbit/api/metadata';
|
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { useHistory } from 'react-router-dom';
|
import { useHistory } from 'react-router-dom';
|
||||||
import { resourceFromPath, roleForShip } from '~/logic/lib/group';
|
import { resourceFromPath, roleForShip } from '~/logic/lib/group';
|
||||||
|
@ -4,8 +4,7 @@ import {
|
|||||||
|
|
||||||
Text
|
Text
|
||||||
} from '@tlon/indigo-react';
|
} from '@tlon/indigo-react';
|
||||||
import { ignoreGroup, listenGroup } from '@urbit/api';
|
import { Association, ignoreGroup, listenGroup } from '@urbit/api';
|
||||||
import { Association } from '@urbit/api/metadata';
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import useHarkState from '~/logic/state/hark';
|
import useHarkState from '~/logic/state/hark';
|
||||||
import { StatelessAsyncToggle } from '~/views/components/StatelessAsyncToggle';
|
import { StatelessAsyncToggle } from '~/views/components/StatelessAsyncToggle';
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import { Button, Icon, Row, Text } from '@tlon/indigo-react';
|
import { Button, Icon, Row, Text } from '@tlon/indigo-react';
|
||||||
import { disableGroupFeed } from '@urbit/api/graph';
|
import { disableGroupFeed } from '@urbit/api';
|
||||||
import React, { useState } from 'react';
|
import React, { useState } from 'react';
|
||||||
import { Link, useHistory } from 'react-router-dom';
|
import { Link, useHistory } from 'react-router-dom';
|
||||||
import { resourceFromPath } from '~/logic/lib/group';
|
import { resourceFromPath } from '~/logic/lib/group';
|
||||||
|
@ -1,12 +1,9 @@
|
|||||||
import { Box, Col } from '@tlon/indigo-react';
|
import { Box, Col } from '@tlon/indigo-react';
|
||||||
import { Association, FlatGraph, FlatGraphNode, Group } from '@urbit/api';
|
import { arrToString, Association, FlatGraph, FlatGraphNode, Group } from '@urbit/api';
|
||||||
import bigInt from 'big-integer';
|
import bigInt from 'big-integer';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { RouteComponentProps, useHistory } from 'react-router';
|
import { RouteComponentProps, useHistory } from 'react-router';
|
||||||
import { resourceFromPath } from '~/logic/lib/group';
|
import { resourceFromPath } from '~/logic/lib/group';
|
||||||
import {
|
|
||||||
arrToString
|
|
||||||
} from '@urbit/api/lib/BigIntArrayOrderedMap';
|
|
||||||
import { keyEq, ThreadScroller } from '~/views/components/ThreadScroller';
|
import { keyEq, ThreadScroller } from '~/views/components/ThreadScroller';
|
||||||
import PostItem from './PostItem/PostItem';
|
import PostItem from './PostItem/PostItem';
|
||||||
import PostInput from './PostInput';
|
import PostInput from './PostInput';
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import { Action, Col, Icon, Row } from '@tlon/indigo-react';
|
import { Action, Col, Icon, Row } from '@tlon/indigo-react';
|
||||||
import { Association, Post } from '@urbit/api';
|
import { Association, Post, removePosts } from '@urbit/api';
|
||||||
import React, { ReactElement } from 'react';
|
import React, { ReactElement } from 'react';
|
||||||
import { getPermalinkForGraph } from '~/logic/lib/permalinks';
|
import { getPermalinkForGraph } from '~/logic/lib/permalinks';
|
||||||
import { useCopy } from '~/logic/lib/useCopy';
|
import { useCopy } from '~/logic/lib/useCopy';
|
||||||
@ -8,7 +8,6 @@ import { resourceFromPath } from '~/logic/lib/group';
|
|||||||
import Author from '~/views/components/Author';
|
import Author from '~/views/components/Author';
|
||||||
import { Dropdown } from '~/views/components/Dropdown';
|
import { Dropdown } from '~/views/components/Dropdown';
|
||||||
import airlock from '~/logic/api';
|
import airlock from '~/logic/api';
|
||||||
import { removePosts } from '@urbit/api/graph';
|
|
||||||
interface PostHeaderProps {
|
interface PostHeaderProps {
|
||||||
post: Post;
|
post: Post;
|
||||||
association: Association;
|
association: Association;
|
||||||
|
@ -6,11 +6,10 @@ import React, {
|
|||||||
} from 'react';
|
} from 'react';
|
||||||
import { resourceFromPath } from '~/logic/lib/group';
|
import { resourceFromPath } from '~/logic/lib/group';
|
||||||
import { Loading } from '~/views/components/Loading';
|
import { Loading } from '~/views/components/Loading';
|
||||||
import { arrToString } from '@urbit/api/lib/BigIntArrayOrderedMap';
|
|
||||||
import useGraphState from '~/logic/state/graph';
|
import useGraphState from '~/logic/state/graph';
|
||||||
import PostFlatFeed from './PostFlatFeed';
|
import PostFlatFeed from './PostFlatFeed';
|
||||||
import PostInput from './PostInput';
|
import PostInput from './PostInput';
|
||||||
import { Association, deSig, PermVariation } from '@urbit/api';
|
import { arrToString, Association, deSig, PermVariation } from '@urbit/api';
|
||||||
import { useParams, Switch, Route } from 'react-router';
|
import { useParams, Switch, Route } from 'react-router';
|
||||||
import { useGroupForAssoc } from '~/logic/state/group';
|
import { useGroupForAssoc } from '~/logic/state/group';
|
||||||
|
|
||||||
|
@ -5,8 +5,7 @@ import {
|
|||||||
|
|
||||||
Row, Text
|
Row, Text
|
||||||
} from '@tlon/indigo-react';
|
} from '@tlon/indigo-react';
|
||||||
import { invite } from '@urbit/api/groups';
|
import { Association, invite } from '@urbit/api';
|
||||||
import { Association } from '@urbit/api/metadata';
|
|
||||||
import { Form, Formik } from 'formik';
|
import { Form, Formik } from 'formik';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import React, { useCallback, useRef } from 'react';
|
import React, { useCallback, useRef } from 'react';
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import { Box, Col, Text } from '@tlon/indigo-react';
|
import { Box, Col, Text } from '@tlon/indigo-react';
|
||||||
import { invite } from '@urbit/api/groups';
|
import { invite } from '@urbit/api';
|
||||||
import { Form, Formik } from 'formik';
|
import { Form, Formik } from 'formik';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
@ -6,10 +6,7 @@ import {
|
|||||||
|
|
||||||
StatelessTextInput as Input, Text
|
StatelessTextInput as Input, Text
|
||||||
} from '@tlon/indigo-react';
|
} from '@tlon/indigo-react';
|
||||||
import { Contact, Contacts } from '@urbit/api/contacts';
|
import { addTag, Association, Contact, Contacts, changePolicy, deSig, Group, removeMembers, removeTag, RoleTags } from '@urbit/api';
|
||||||
import { addTag, removeMembers, changePolicy, Group, removeTag, RoleTags } from '@urbit/api/groups';
|
|
||||||
import { Association } from '@urbit/api/metadata';
|
|
||||||
import { deSig } from '@urbit/api';
|
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import f from 'lodash/fp';
|
import f from 'lodash/fp';
|
||||||
import React, {
|
import React, {
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
import { Box, Col, Text } from '@tlon/indigo-react';
|
import { Box, Col, Text } from '@tlon/indigo-react';
|
||||||
import { Group } from '@urbit/api/groups';
|
import { Association, deSig, Group } from '@urbit/api';
|
||||||
import { deSig } from '@urbit/api';
|
|
||||||
import { Association } from '@urbit/api/metadata';
|
|
||||||
import React, { ReactElement, useCallback, useRef } from 'react';
|
import React, { ReactElement, useCallback, useRef } from 'react';
|
||||||
import { Link, Route, RouteComponentProps, Switch } from 'react-router-dom';
|
import { Link, Route, RouteComponentProps, Switch } from 'react-router-dom';
|
||||||
import { resourceFromPath } from '~/logic/lib/group';
|
import { resourceFromPath } from '~/logic/lib/group';
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { Association } from '@urbit/api/metadata';
|
import { AppName, Association } from '@urbit/api';
|
||||||
import { AppName } from '@urbit/api';
|
|
||||||
import React, { ReactElement } from 'react';
|
import React, { ReactElement } from 'react';
|
||||||
import Helmet from 'react-helmet';
|
import Helmet from 'react-helmet';
|
||||||
import { Route, Switch } from 'react-router-dom';
|
import { Route, Switch } from 'react-router-dom';
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { Box, Col, Icon, Text } from '@tlon/indigo-react';
|
import { Box, Col, Icon, Text } from '@tlon/indigo-react';
|
||||||
import { Association } from '@urbit/api/metadata';
|
import { AppName, Association } from '@urbit/api';
|
||||||
import { AppName } from '@urbit/api';
|
|
||||||
import React, { ReactElement, ReactNode, useCallback, useState } from 'react';
|
import React, { ReactElement, ReactNode, useCallback, useState } from 'react';
|
||||||
import { Link } from 'react-router-dom';
|
import { Link } from 'react-router-dom';
|
||||||
import styled from 'styled-components';
|
import styled from 'styled-components';
|
||||||
|
12
pkg/npm/api/.babelrc
Normal file
12
pkg/npm/api/.babelrc
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
{
|
||||||
|
"presets": [
|
||||||
|
[
|
||||||
|
"@babel/preset-env",
|
||||||
|
{
|
||||||
|
"targets": "> 1%",
|
||||||
|
"useBuiltIns": "usage",
|
||||||
|
"corejs": "3.19.1"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
1
pkg/npm/api/.gitignore
vendored
Normal file
1
pkg/npm/api/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
tmp
|
2
pkg/npm/api/deps.d.ts
vendored
2
pkg/npm/api/deps.d.ts
vendored
@ -1,5 +1,5 @@
|
|||||||
|
|
||||||
declare module "urbit-ob" {
|
declare module 'urbit-ob' {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a @p-encoded string to a decimal-encoded string.
|
* Convert a @p-encoded string to a decimal-encoded string.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import { Patp } from '../lib';
|
import { Patp } from '../lib';
|
||||||
import BigIntOrderedMap from '../lib/BigIntOrderedMap';
|
import { BigIntOrderedMap } from '../lib/BigIntOrderedMap';
|
||||||
import BigIntArrayOrderedMap from '../lib/BigIntArrayOrderedMap';
|
import { BigIntArrayOrderedMap } from '../lib/BigIntArrayOrderedMap';
|
||||||
|
|
||||||
export interface TextContent {
|
export interface TextContent {
|
||||||
text: string;
|
text: string;
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
import _ from 'lodash';
|
|
||||||
|
|
||||||
import { Enc, Path, Patp, PatpNoSig, Poke, Thread } from '../lib/types';
|
import { Enc, Path, Patp, PatpNoSig, Poke, Thread } from '../lib/types';
|
||||||
import { Group, GroupPolicy, GroupPolicyDiff, GroupUpdateAddMembers, GroupUpdateAddTag, GroupUpdateChangePolicy, GroupUpdateRemoveGroup, GroupUpdateRemoveMembers, GroupUpdateRemoveTag, Resource, RoleTags, Tag } from './types';
|
import { Group, GroupPolicy, GroupPolicyDiff, GroupUpdateAddMembers, GroupUpdateAddTag, GroupUpdateChangePolicy, GroupUpdateRemoveGroup, GroupUpdateRemoveMembers, GroupUpdateRemoveTag, Resource, RoleTags, Tag } from './types';
|
||||||
import { GroupUpdate } from './update';
|
import { GroupUpdate } from './update';
|
||||||
@ -97,6 +95,10 @@ export const changePolicy = (
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
export const makeResource = (ship: string, name: string) => {
|
||||||
|
return { ship, name };
|
||||||
|
};
|
||||||
|
|
||||||
export const join = (
|
export const join = (
|
||||||
ship: string,
|
ship: string,
|
||||||
name: string,
|
name: string,
|
||||||
@ -181,30 +183,32 @@ export const roleForShip = (
|
|||||||
const roleShips = group?.tags?.role?.[role];
|
const roleShips = group?.tags?.role?.[role];
|
||||||
return roleShips && roleShips.has(ship) ? role : currRole;
|
return roleShips && roleShips.has(ship) ? role : currRole;
|
||||||
}, undefined as RoleTags | undefined);
|
}, undefined as RoleTags | undefined);
|
||||||
}
|
};
|
||||||
|
|
||||||
export const resourceFromPath = (path: Path): Resource => {
|
export const resourceFromPath = (path: Path): Resource => {
|
||||||
const [, , ship, name] = path.split('/');
|
const [, , ship, name] = path.split('/');
|
||||||
return { ship, name };
|
return { ship, name };
|
||||||
}
|
};
|
||||||
|
|
||||||
export const makeResource = (ship: string, name: string) => {
|
|
||||||
return { ship, name };
|
|
||||||
}
|
|
||||||
|
|
||||||
export const isWriter = (group: Group, resource: string, ship: string) => {
|
export const isWriter = (group: Group, resource: string, ship: string) => {
|
||||||
const writers: Set<string> | undefined = _.get(
|
const graph = group.tags?.graph;
|
||||||
group,
|
const writers: Set<string> | undefined = graph && (graph[resource] as any)?.writers;
|
||||||
['tags', 'graph', resource, 'writers'],
|
|
||||||
undefined
|
|
||||||
);
|
|
||||||
const admins = group?.tags?.role?.admin ?? new Set();
|
const admins = group?.tags?.role?.admin ?? new Set();
|
||||||
if (_.isUndefined(writers)) {
|
if (typeof writers === 'undefined') {
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
return writers.has(ship) || admins.has(ship);
|
return writers.has(ship) || admins.has(ship);
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
|
export const isHost = (
|
||||||
|
resource: string,
|
||||||
|
ship: string
|
||||||
|
): boolean => {
|
||||||
|
const [, , host] = resource.split('/');
|
||||||
|
|
||||||
|
return ship === host;
|
||||||
|
};
|
||||||
|
|
||||||
export const isChannelAdmin = (
|
export const isChannelAdmin = (
|
||||||
group: Group,
|
group: Group,
|
||||||
@ -218,13 +222,4 @@ export const isChannelAdmin = (
|
|||||||
role === 'admin' ||
|
role === 'admin' ||
|
||||||
role === 'moderator'
|
role === 'moderator'
|
||||||
);
|
);
|
||||||
}
|
};
|
||||||
|
|
||||||
export const isHost = (
|
|
||||||
resource: string,
|
|
||||||
ship: string
|
|
||||||
): boolean => {
|
|
||||||
const [, , host] = resource.split('/');
|
|
||||||
|
|
||||||
return ship === host;
|
|
||||||
}
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { PatpNoSig, Path, Jug, ShipRank, Enc } from '../lib';
|
import { PatpNoSig, Path, ShipRank, Enc } from '../lib';
|
||||||
import { roleTags } from './index';
|
import { roleTags } from './index';
|
||||||
|
|
||||||
export type RoleTags = typeof roleTags[number];
|
export type RoleTags = typeof roleTags[number];
|
||||||
@ -173,5 +173,3 @@ export type GroupUpdate =
|
|||||||
| GroupUpdateInitialGroup;
|
| GroupUpdateInitialGroup;
|
||||||
|
|
||||||
export type GroupAction = Omit<GroupUpdate, 'initialGroup' | 'initial'>;
|
export type GroupAction = Omit<GroupUpdate, 'initialGroup' | 'initial'>;
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
import { Poke, Scry } from '../lib';
|
import { Poke, Scry } from '../lib';
|
||||||
import { Vats, Vat } from './types';
|
import { Vats, Vat } from './types';
|
||||||
import _ from 'lodash';
|
|
||||||
|
|
||||||
export const getVats: Scry = {
|
export const getVats: Scry = {
|
||||||
app: 'hood',
|
app: 'hood',
|
||||||
@ -98,9 +97,13 @@ export function getBlockers(vats: Vats): string[] {
|
|||||||
if(!blockedOn) {
|
if(!blockedOn) {
|
||||||
return blockers;
|
return blockers;
|
||||||
}
|
}
|
||||||
_.forEach(_.omit(vats, 'base'), (vat, desk) => {
|
|
||||||
|
Object.entries(vats)
|
||||||
|
.filter(([desk]) => desk !== 'base')
|
||||||
|
.forEach(([desk, vat]) => {
|
||||||
// assuming only %zuse
|
// assuming only %zuse
|
||||||
const kelvins = _.map((vat.arak.rail?.next || []), n => n.weft.kelvin);
|
const woofs = vat.arak.rail?.next || [];
|
||||||
|
const kelvins = woofs.map(n => n.weft.kelvin);
|
||||||
if(!(kelvins.includes(blockedOn))) {
|
if(!(kelvins.includes(blockedOn))) {
|
||||||
blockers.push(desk);
|
blockers.push(desk);
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,8 @@ export * as groups from './groups';
|
|||||||
export * from './hark';
|
export * from './hark';
|
||||||
export * as hark from './hark';
|
export * as hark from './hark';
|
||||||
export * from './invite';
|
export * from './invite';
|
||||||
export * as invite from './invite';
|
// this conflicts with /groups/lib invite
|
||||||
|
// export * as invite from './invite';
|
||||||
export * from './metadata';
|
export * from './metadata';
|
||||||
export * as metadata from './metadata';
|
export * as metadata from './metadata';
|
||||||
export * from './settings';
|
export * from './settings';
|
||||||
@ -16,6 +17,7 @@ export * from './s3';
|
|||||||
export * as s3 from './s3';
|
export * as s3 from './s3';
|
||||||
export * from './lib';
|
export * from './lib';
|
||||||
export * from './lib/BigIntOrderedMap';
|
export * from './lib/BigIntOrderedMap';
|
||||||
|
export * from './lib/BigIntArrayOrderedMap';
|
||||||
export * as hood from './hood';
|
export * as hood from './hood';
|
||||||
export * from './hood';
|
export * from './hood';
|
||||||
export * as docket from './docket';
|
export * as docket from './docket';
|
||||||
|
@ -51,7 +51,7 @@ export function sortBigIntArr(a: BigInteger[], b: BigInteger[]) {
|
|||||||
return bLen - aLen;
|
return bLen - aLen;
|
||||||
}
|
}
|
||||||
|
|
||||||
export default class BigIntArrayOrderedMap<V> implements Iterable<[BigInteger[], V]> {
|
export class BigIntArrayOrderedMap<V> implements Iterable<[BigInteger[], V]> {
|
||||||
root: Record<string, V> = {}
|
root: Record<string, V> = {}
|
||||||
cachedIter: [BigInteger[], V][] | null = null;
|
cachedIter: [BigInteger[], V][] | null = null;
|
||||||
[immerable] = true;
|
[immerable] = true;
|
||||||
|
@ -14,7 +14,7 @@ function sortBigInt(a: BigInteger, b: BigInteger) {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
export default class BigIntOrderedMap<V> implements Iterable<[BigInteger, V]> {
|
export class BigIntOrderedMap<V> implements Iterable<[BigInteger, V]> {
|
||||||
root: Record<string, V> = {}
|
root: Record<string, V> = {}
|
||||||
cachedIter: [BigInteger, V][] | null = null;
|
cachedIter: [BigInteger, V][] | null = null;
|
||||||
[immerable] = true;
|
[immerable] = true;
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
import _ from "lodash";
|
|
||||||
import f from "lodash/fp";
|
|
||||||
import bigInt, { BigInteger } from "big-integer";
|
import bigInt, { BigInteger } from "big-integer";
|
||||||
|
|
||||||
import { Resource } from "../groups/types";
|
import { Resource } from "../groups/types";
|
||||||
@ -9,6 +7,36 @@ const DA_UNIX_EPOCH = bigInt("170141184475152167957503069145530368000"); // `@ud
|
|||||||
|
|
||||||
const DA_SECOND = bigInt("18446744073709551616"); // `@ud` ~s1
|
const DA_SECOND = bigInt("18446744073709551616"); // `@ud` ~s1
|
||||||
|
|
||||||
|
function chunk<T>(arr: T[], size: number): T[][] {
|
||||||
|
let chunk: T[] = [];
|
||||||
|
let newArray = [chunk];
|
||||||
|
|
||||||
|
for (let i = 0;i < arr.length;i++) {
|
||||||
|
if (chunk.length < size) {
|
||||||
|
chunk.push(arr[i])
|
||||||
|
} else {
|
||||||
|
chunk = [arr[i]]
|
||||||
|
newArray.push(chunk)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return newArray;
|
||||||
|
}
|
||||||
|
|
||||||
|
function dropWhile<T>(arr: T[], pred: (x: T) => boolean): T[] {
|
||||||
|
const newArray = arr.slice();
|
||||||
|
|
||||||
|
for (const item of arr) {
|
||||||
|
if (pred(item)) {
|
||||||
|
newArray.shift();
|
||||||
|
} else {
|
||||||
|
return newArray;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return newArray;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Given a bigint representing an urbit date, returns a unix timestamp.
|
* Given a bigint representing an urbit date, returns a unix timestamp.
|
||||||
*
|
*
|
||||||
@ -48,17 +76,11 @@ export function udToDec(ud: string): string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function decToUd(str: string): string {
|
export function decToUd(str: string): string {
|
||||||
return _.trimStart(
|
const transform = chunk(str.split('').reverse(), 3)
|
||||||
f.flow(
|
.map(group => group.reverse().join(''))
|
||||||
f.split(""),
|
.reverse()
|
||||||
f.reverse,
|
.join('.')
|
||||||
f.chunk(3),
|
return transform.replace(/^[0\.]+/g, '');
|
||||||
f.map(f.flow(f.reverse, f.join(""))),
|
|
||||||
f.reverse,
|
|
||||||
f.join(".")
|
|
||||||
)(str),
|
|
||||||
"0."
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function resourceAsPath(resource: Resource): string {
|
export function resourceAsPath(resource: Resource): string {
|
||||||
@ -161,14 +183,11 @@ export function uxToHex(ux: string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export const hexToUx = (hex: string): string => {
|
export const hexToUx = (hex: string): string => {
|
||||||
const ux = f.flow(
|
const nonZeroChars = dropWhile(hex.split(''), y => y === '0');
|
||||||
f.dropWhile(y => y === '0'),
|
const ux = chunk(nonZeroChars.reverse(), 4).map(x => {
|
||||||
f.reverse,
|
return x.reverse().join('');
|
||||||
f.chunk(4),
|
}).reverse().join('.') || '0';
|
||||||
f.map(x => x.reverse().join('')),
|
|
||||||
f.reverse,
|
|
||||||
f.join('.')
|
|
||||||
)(hex.split('')) || '0';
|
|
||||||
return `0x${ux}`;
|
return `0x${ux}`;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -210,21 +229,6 @@ export function stringToTa(str: string): string {
|
|||||||
return "~." + out;
|
return "~." + out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Formats a numbers as a `@ud` inserting dot where needed
|
|
||||||
*/
|
|
||||||
export function numToUd(num: number): string {
|
|
||||||
return f.flow(
|
|
||||||
f.split(''),
|
|
||||||
f.reverse,
|
|
||||||
f.chunk(3),
|
|
||||||
f.reverse,
|
|
||||||
f.map(s => s.join('')),
|
|
||||||
f.join('.')
|
|
||||||
)(num.toString())
|
|
||||||
}
|
|
||||||
|
|
||||||
export const buntPost = (): Post => ({
|
export const buntPost = (): Post => ({
|
||||||
author: '',
|
author: '',
|
||||||
contents: [],
|
contents: [],
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* Martian embassy
|
* Martian embassy
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import BigIntOrderedMap from "./BigIntOrderedMap";
|
import { BigIntOrderedMap } from "./BigIntOrderedMap";
|
||||||
|
|
||||||
// an urbit style path rendered as string
|
// an urbit style path rendered as string
|
||||||
export type Path = string;
|
export type Path = string;
|
||||||
|
3600
pkg/npm/api/package-lock.json
generated
3600
pkg/npm/api/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -1,39 +1,52 @@
|
|||||||
{
|
{
|
||||||
"name": "@urbit/api",
|
"name": "@urbit/api",
|
||||||
"version": "1.4.1",
|
"version": "2.1.0",
|
||||||
"description": "",
|
"description": "A library that provides bindings and types for Urbit's various userspace desks",
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "ssh://git@github.com/urbit/urbit.git",
|
"url": "ssh://git@github.com/urbit/urbit.git",
|
||||||
"directory": "pkg/npm/api"
|
"directory": "pkg/npm/api"
|
||||||
},
|
},
|
||||||
"main": "dist/index.js",
|
"type": "module",
|
||||||
"types": "dist/index.d",
|
"main": "dist/cjs/index.js",
|
||||||
|
"module": "dist/esm/index.js",
|
||||||
|
"jsdelivr": "dist/urbit-api.min.js",
|
||||||
|
"unpkg": "dist/urbit-api.min.js",
|
||||||
|
"types": "dist/index.d.ts",
|
||||||
|
"files": [
|
||||||
|
"dist/**"
|
||||||
|
],
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "echo \"No test specified\" && exit 0",
|
"test": "echo \"No test specified\" && exit 0",
|
||||||
"watch": "tsc -p tsconfig.json --watch",
|
"build": "npm run clean && rollup -c && npx tsc -p tsconfig.json",
|
||||||
"build": "tsc -p tsconfig.json",
|
"prepare": "npm run build",
|
||||||
"clean": "rm -rf dist/*",
|
"watch": "rollup -c -w",
|
||||||
"prepare": "npm run build"
|
"clean": "rm -rf dist/* types/*"
|
||||||
},
|
},
|
||||||
"author": "",
|
"author": "",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/runtime": "^7.12.5",
|
"@babel/runtime": "^7.16.0",
|
||||||
"@types/lodash": "^4.14.168",
|
|
||||||
"@urbit/eslint-config": "^1.0.3",
|
|
||||||
"big-integer": "^1.6.48",
|
"big-integer": "^1.6.48",
|
||||||
|
"core-js": "^3.19.1",
|
||||||
"immer": "^9.0.1",
|
"immer": "^9.0.1",
|
||||||
"lodash": "^4.17.20",
|
|
||||||
"urbit-ob": "^5.0.1"
|
"urbit-ob": "^5.0.1"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
"@babel/core": "^7.16.0",
|
||||||
|
"@rollup/plugin-babel": "^5.3.0",
|
||||||
|
"@rollup/plugin-commonjs": "^21.0.1",
|
||||||
|
"@rollup/plugin-node-resolve": "^13.0.6",
|
||||||
"@types/node": "^15.12.5",
|
"@types/node": "^15.12.5",
|
||||||
"@typescript-eslint/eslint-plugin": "^4.28.2",
|
"@typescript-eslint/eslint-plugin": "^4.28.2",
|
||||||
"@typescript-eslint/parser": "^4.28.2",
|
"@typescript-eslint/parser": "^4.28.2",
|
||||||
|
"@urbit/eslint-config": "^1.0.3",
|
||||||
"babel-eslint": "^10.1.0",
|
"babel-eslint": "^10.1.0",
|
||||||
"eslint-plugin-react": "^7.24.0",
|
"eslint-plugin-react": "^7.24.0",
|
||||||
"onchange": "^7.1.0",
|
"rollup": "^2.59.0",
|
||||||
|
"rollup-plugin-analyzer": "^4.0.0",
|
||||||
|
"rollup-plugin-terser": "^7.0.2",
|
||||||
|
"rollup-plugin-typescript2": "^0.30.0",
|
||||||
"typescript": "^4.3.2"
|
"typescript": "^4.3.2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
76
pkg/npm/api/rollup.config.ts
Normal file
76
pkg/npm/api/rollup.config.ts
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
import { nodeResolve } from '@rollup/plugin-node-resolve';
|
||||||
|
import commonJS from '@rollup/plugin-commonjs';
|
||||||
|
import { terser } from 'rollup-plugin-terser';
|
||||||
|
import babel from '@rollup/plugin-babel';
|
||||||
|
import typescript from 'rollup-plugin-typescript2';
|
||||||
|
import analyze from 'rollup-plugin-analyzer'
|
||||||
|
|
||||||
|
const input = ['./index.ts'];
|
||||||
|
|
||||||
|
// Skip certain warnings
|
||||||
|
function onwarn(warning) {
|
||||||
|
if (warning.code === 'THIS_IS_UNDEFINED') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
console.warn(warning.message);
|
||||||
|
}
|
||||||
|
|
||||||
|
export default [
|
||||||
|
{
|
||||||
|
input,
|
||||||
|
onwarn,
|
||||||
|
plugins: [
|
||||||
|
nodeResolve({
|
||||||
|
extensions: ['.js', '.jsx', '.ts', '.tsx']
|
||||||
|
}),
|
||||||
|
commonJS(),
|
||||||
|
typescript(),
|
||||||
|
babel({
|
||||||
|
babelHelpers: 'bundled',
|
||||||
|
exclude: ['node_modules/**']
|
||||||
|
}),
|
||||||
|
terser({
|
||||||
|
ecma: 2017,
|
||||||
|
compress: true,
|
||||||
|
mangle: true
|
||||||
|
})
|
||||||
|
],
|
||||||
|
output: {
|
||||||
|
file: 'dist/urbit-api.min.js',
|
||||||
|
format: 'umd',
|
||||||
|
name: 'UrbitAPI', // this is the name of the global object
|
||||||
|
esModule: false,
|
||||||
|
exports: 'named',
|
||||||
|
sourcemap: true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
input,
|
||||||
|
onwarn,
|
||||||
|
plugins: [
|
||||||
|
nodeResolve({
|
||||||
|
extensions: ['.js', '.jsx', '.ts', '.tsx']
|
||||||
|
}),
|
||||||
|
commonJS(),
|
||||||
|
typescript(),
|
||||||
|
analyze({
|
||||||
|
limit: 10
|
||||||
|
})
|
||||||
|
],
|
||||||
|
output: [
|
||||||
|
{
|
||||||
|
dir: 'dist/esm',
|
||||||
|
format: 'esm',
|
||||||
|
exports: 'named',
|
||||||
|
sourcemap: true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
dir: 'dist/cjs',
|
||||||
|
format: 'cjs',
|
||||||
|
exports: 'named',
|
||||||
|
sourcemap: true
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
];
|
@ -1,10 +1,10 @@
|
|||||||
{
|
{
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
"baseUrl": ".",
|
"baseUrl": ".",
|
||||||
"outDir": "./dist",
|
"outDir": "./tmp",
|
||||||
"module": "ES2020",
|
"module": "ESNext",
|
||||||
"noImplicitAny": true,
|
"noImplicitAny": true,
|
||||||
"target": "ES2017",
|
"target": "ESNext",
|
||||||
"pretty": true,
|
"pretty": true,
|
||||||
"moduleResolution": "node",
|
"moduleResolution": "node",
|
||||||
"esModuleInterop": true,
|
"esModuleInterop": true,
|
||||||
@ -14,6 +14,11 @@
|
|||||||
"strict": false,
|
"strict": false,
|
||||||
"noErrorTruncation": true
|
"noErrorTruncation": true
|
||||||
},
|
},
|
||||||
"exclude": ["node_modules", "./dist/**/*", "@types"],
|
"exclude": [
|
||||||
|
"node_modules",
|
||||||
|
"./dist/**/*",
|
||||||
|
"./tmp/**/*",
|
||||||
|
"rollup.config.ts"
|
||||||
|
],
|
||||||
"include": ["./*.ts"]
|
"include": ["./*.ts"]
|
||||||
}
|
}
|
||||||
|
13
pkg/npm/http-api/.babelrc
Normal file
13
pkg/npm/http-api/.babelrc
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"presets": [
|
||||||
|
"@babel/preset-typescript", //needed for .ts jest tests
|
||||||
|
[
|
||||||
|
"@babel/preset-env",
|
||||||
|
{
|
||||||
|
"targets": "> 1%",
|
||||||
|
"useBuiltIns": "usage",
|
||||||
|
"corejs": "3.19.1"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
4
pkg/npm/http-api/.gitignore
vendored
4
pkg/npm/http-api/.gitignore
vendored
@ -0,0 +1,4 @@
|
|||||||
|
dist
|
||||||
|
node_modules
|
||||||
|
coverage
|
||||||
|
tmp
|
@ -1,6 +0,0 @@
|
|||||||
module.exports = {
|
|
||||||
presets: [
|
|
||||||
['@babel/preset-env', {targets: {node: 'current'}}],
|
|
||||||
'@babel/preset-typescript',
|
|
||||||
],
|
|
||||||
};
|
|
@ -1,15 +1,15 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8" />
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||||
<title>Demo</title>
|
<title>Demo</title>
|
||||||
<script src="browser.js"></script>
|
<script src="../dist/urbit-http-api.min.js"></script>
|
||||||
<style>
|
<style>
|
||||||
@import url("https://rsms.me/inter/inter.css");
|
@import url('https://rsms.me/inter/inter.css');
|
||||||
@font-face {
|
@font-face {
|
||||||
font-family: "Source Code Pro";
|
font-family: 'Source Code Pro';
|
||||||
src: url("https://storage.googleapis.com/media.urbit.org/fonts/scp-regular.woff");
|
src: url('https://storage.googleapis.com/media.urbit.org/fonts/scp-regular.woff');
|
||||||
font-weight: 400;
|
font-weight: 400;
|
||||||
}
|
}
|
||||||
body {
|
body {
|
||||||
@ -32,67 +32,91 @@
|
|||||||
border-bottom: 1px dashed currentColor;
|
border-bottom: 1px dashed currentColor;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<details>
|
<details>
|
||||||
<summary>Show instructions</summary>
|
<summary>Show instructions</summary>
|
||||||
<p>Assuming you are running a fakezod on port 8080, run</p>
|
<p>Assuming you are running a fakezod on port 8080, run</p>
|
||||||
<code id="instructions">|cors-approve '{window.location.origin}'</code>
|
<code id="instructions">|cors-approve '{window.location.origin}'</code>
|
||||||
<p>in its dojo.</p>
|
<p>in its dojo.</p>
|
||||||
<p>Press the button to run the code below. Output will be logged. You should see <code>< ~zod: opening airlock</code> in your dojo.</code> Create a chat and send a message to see the events logged.</p>
|
<p>
|
||||||
<pre>window.airlock = await Urbit.authenticate({
|
Press the button to run the code below. Output will be logged. You
|
||||||
|
should see <code>< ~zod: opening airlock</code> in your dojo. Create
|
||||||
|
a chat and send a message to see the events logged.
|
||||||
|
</p>
|
||||||
|
<pre>
|
||||||
|
window.airlock = await UrbitHttpApi.Urbit.authenticate({
|
||||||
ship: 'zod',
|
ship: 'zod',
|
||||||
url: 'localhost:8080',
|
url: 'localhost:8080',
|
||||||
code: 'lidlut-tabwed-pillex-ridrup',
|
code: 'lidlut-tabwed-pillex-ridrup',
|
||||||
verbose: true
|
verbose: true
|
||||||
});
|
});
|
||||||
window.airlock.subscribe('chat-view', '/primary', { event: console.log });</pre>
|
window.airlock.subscribe({
|
||||||
|
app: 'graph-store',
|
||||||
|
path: '/updates',
|
||||||
|
event: console.log
|
||||||
|
});</pre
|
||||||
|
>
|
||||||
</details>
|
</details>
|
||||||
|
|
||||||
<button id="blastoff" onclick="blastOff()">Blast Off</button>
|
<button id="blastoff" onclick="blastOff()">Blast Off</button>
|
||||||
<pre id="mylog">
|
<pre id="mylog"></pre>
|
||||||
|
</body>
|
||||||
</pre>
|
<script>
|
||||||
</body>
|
|
||||||
<script>
|
|
||||||
var baseLogFunction = console.log;
|
var baseLogFunction = console.log;
|
||||||
console.log = function(){
|
console.log = function () {
|
||||||
baseLogFunction.apply(console, arguments);
|
baseLogFunction.apply(console, arguments);
|
||||||
var chunk = document.createElement('div');
|
var chunk = document.createElement('div');
|
||||||
chunk.className = 'chunk';
|
chunk.className = 'chunk';
|
||||||
|
|
||||||
var args = Array.prototype.slice.call(arguments);
|
var args = Array.prototype.slice.call(arguments);
|
||||||
for(var i=0;i<args.length;i++){
|
for (var i = 0; i < args.length; i++) {
|
||||||
const val = typeof args[i] === 'string' ? args[i] : JSON.stringify(args[i]);
|
const val =
|
||||||
|
typeof args[i] === 'string' ? args[i] : JSON.stringify(args[i]);
|
||||||
var node = createLogNode(val);
|
var node = createLogNode(val);
|
||||||
chunk.appendChild(node);
|
chunk.appendChild(node);
|
||||||
}
|
}
|
||||||
document.querySelector("#mylog").insertBefore(chunk, document.querySelector("#mylog").firstChild);
|
document
|
||||||
}
|
.querySelector('#mylog')
|
||||||
|
.insertBefore(chunk, document.querySelector('#mylog').firstChild);
|
||||||
|
};
|
||||||
|
|
||||||
function createLogNode(message){
|
function createLogNode(message) {
|
||||||
var node = document.createElement("div");
|
var node = document.createElement('div');
|
||||||
node.className = 'message';
|
node.className = 'message';
|
||||||
var textNode = document.createTextNode(message);
|
var textNode = document.createTextNode(message);
|
||||||
node.appendChild(textNode);
|
node.appendChild(textNode);
|
||||||
return node;
|
return node;
|
||||||
}
|
}
|
||||||
|
|
||||||
window.onerror = function(message, url, linenumber) {
|
window.onerror = function (message, url, linenumber) {
|
||||||
console.log("JavaScript error: " + message + " on line " +
|
console.log(
|
||||||
linenumber + " for " + url);
|
'JavaScript error: ' +
|
||||||
}
|
message +
|
||||||
|
' on line ' +
|
||||||
|
linenumber +
|
||||||
|
' for ' +
|
||||||
|
url
|
||||||
|
);
|
||||||
|
};
|
||||||
const instructions = document.getElementById('instructions');
|
const instructions = document.getElementById('instructions');
|
||||||
instructions.innerText = instructions.innerText.replace('{window.location.origin}', window.location.origin);
|
instructions.innerText = instructions.innerText.replace(
|
||||||
|
'{window.location.origin}',
|
||||||
|
window.location.origin
|
||||||
|
);
|
||||||
async function blastOff() {
|
async function blastOff() {
|
||||||
window.airlock = await Urbit.authenticate({
|
window.airlock = await UrbitHttpApi.Urbit.authenticate({
|
||||||
ship: 'zod',
|
ship: 'zod',
|
||||||
url: 'localhost:8080',
|
url: 'localhost',
|
||||||
code: 'lidlut-tabwed-pillex-ridrup',
|
code: 'lidlut-tabwed-pillex-ridrup',
|
||||||
verbose: true
|
verbose: true,
|
||||||
});
|
});
|
||||||
window.airlock.subscribe('chat-view', '/primary', { event: console.log });
|
window.airlock.subscribe({
|
||||||
document.body.removeChild(document.getElementById('blastoff'))
|
app: 'graph-store',
|
||||||
|
path: '/updates',
|
||||||
|
event: console.log,
|
||||||
|
});
|
||||||
|
document.body.removeChild(document.getElementById('blastoff'));
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
</html>
|
</html>
|
@ -23,7 +23,7 @@ module.exports = {
|
|||||||
// collectCoverageFrom: undefined,
|
// collectCoverageFrom: undefined,
|
||||||
|
|
||||||
// The directory where Jest should output its coverage files
|
// The directory where Jest should output its coverage files
|
||||||
coverageDirectory: "coverage",
|
coverageDirectory: 'coverage',
|
||||||
|
|
||||||
// An array of regexp pattern strings used to skip coverage collection
|
// An array of regexp pattern strings used to skip coverage collection
|
||||||
// coveragePathIgnorePatterns: [
|
// coveragePathIgnorePatterns: [
|
||||||
@ -137,7 +137,7 @@ module.exports = {
|
|||||||
// snapshotSerializers: [],
|
// snapshotSerializers: [],
|
||||||
|
|
||||||
// The test environment that will be used for testing
|
// The test environment that will be used for testing
|
||||||
testEnvironment: "jsdom",
|
testEnvironment: 'jsdom',
|
||||||
|
|
||||||
// Options that will be passed to the testEnvironment
|
// Options that will be passed to the testEnvironment
|
||||||
// testEnvironmentOptions: {},
|
// testEnvironmentOptions: {},
|
||||||
@ -166,7 +166,7 @@ module.exports = {
|
|||||||
// testRunner: "jest-circus/runner",
|
// testRunner: "jest-circus/runner",
|
||||||
|
|
||||||
// This option sets the URL for the jsdom environment. It is reflected in properties such as location.href
|
// This option sets the URL for the jsdom environment. It is reflected in properties such as location.href
|
||||||
testURL: "http://localhost",
|
testURL: 'http://localhost',
|
||||||
|
|
||||||
// Setting this value to "fake" allows the use of fake timers for functions such as "setTimeout"
|
// Setting this value to "fake" allows the use of fake timers for functions such as "setTimeout"
|
||||||
// timers: "real",
|
// timers: "real",
|
15968
pkg/npm/http-api/package-lock.json
generated
15968
pkg/npm/http-api/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@urbit/http-api",
|
"name": "@urbit/http-api",
|
||||||
"version": "1.3.1",
|
"version": "2.1.0",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"description": "Library to interact with an Urbit ship over HTTP",
|
"description": "Library to interact with an Urbit ship over HTTP",
|
||||||
"repository": {
|
"repository": {
|
||||||
@ -8,18 +8,21 @@
|
|||||||
"url": "ssh://git@github.com/urbit/urbit.git",
|
"url": "ssh://git@github.com/urbit/urbit.git",
|
||||||
"directory": "pkg/npm/http-api"
|
"directory": "pkg/npm/http-api"
|
||||||
},
|
},
|
||||||
"main": "dist/index.js",
|
"type": "module",
|
||||||
|
"main": "dist/cjs/index.js",
|
||||||
|
"module": "dist/esm/index.js",
|
||||||
|
"jsdelivr": "dist/urbit-http-api.min.js",
|
||||||
|
"unpkg": "dist/urbit-http-api.min.js",
|
||||||
"types": "dist/index.d.ts",
|
"types": "dist/index.d.ts",
|
||||||
"files": [
|
"files": [
|
||||||
"dist",
|
"dist/**"
|
||||||
"src"
|
|
||||||
],
|
],
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "jest",
|
"test": "jest",
|
||||||
"build": "tsc -p tsconfig.json",
|
"build": "npm run clean && rollup -c && npx tsc -p tsconfig.json",
|
||||||
"prepare": "npm run build",
|
"prepare": "npm run build",
|
||||||
"watch": "tsc -p tsconfig.json --watch",
|
"watch": "rollup -c -w",
|
||||||
"clean": "rm -rf dist/*"
|
"clean": "rm -rf dist/* types/*"
|
||||||
},
|
},
|
||||||
"prettier": {
|
"prettier": {
|
||||||
"printWidth": 80,
|
"printWidth": 80,
|
||||||
@ -29,12 +32,12 @@
|
|||||||
},
|
},
|
||||||
"author": "",
|
"author": "",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@babel/core": "^7.14.6",
|
"@babel/core": "^7.15.8",
|
||||||
"@babel/plugin-proposal-class-properties": "^7.12.1",
|
"@babel/preset-env": "^7.15.8",
|
||||||
"@babel/plugin-proposal-object-rest-spread": "^7.12.1",
|
"@babel/preset-typescript": "^7.16.0",
|
||||||
"@babel/plugin-proposal-optional-chaining": "^7.12.1",
|
"@rollup/plugin-babel": "^5.3.0",
|
||||||
"@babel/preset-env": "^7.14.7",
|
"@rollup/plugin-commonjs": "^21.0.1",
|
||||||
"@babel/preset-typescript": "^7.12.1",
|
"@rollup/plugin-node-resolve": "^13.0.6",
|
||||||
"@types/browser-or-node": "^1.2.0",
|
"@types/browser-or-node": "^1.2.0",
|
||||||
"@types/eventsource": "^1.1.5",
|
"@types/eventsource": "^1.1.5",
|
||||||
"@types/jest": "^26.0.24",
|
"@types/jest": "^26.0.24",
|
||||||
@ -42,29 +45,22 @@
|
|||||||
"@typescript-eslint/eslint-plugin": "^4.7.0",
|
"@typescript-eslint/eslint-plugin": "^4.7.0",
|
||||||
"@typescript-eslint/parser": "^4.7.0",
|
"@typescript-eslint/parser": "^4.7.0",
|
||||||
"babel-jest": "^27.0.6",
|
"babel-jest": "^27.0.6",
|
||||||
"babel-loader": "^8.2.1",
|
|
||||||
"clean-webpack-plugin": "^3.0.0",
|
|
||||||
"cross-fetch": "^3.1.4",
|
"cross-fetch": "^3.1.4",
|
||||||
"event-target-polyfill": "0.0.3",
|
"event-target-polyfill": "0.0.3",
|
||||||
"fast-text-encoding": "^1.0.3",
|
"fast-text-encoding": "^1.0.3",
|
||||||
"jest": "^27.0.6",
|
"jest": "^27.0.6",
|
||||||
"onchange": "^7.1.0",
|
"rollup": "^2.59.0",
|
||||||
"tslib": "^2.0.3",
|
"rollup-plugin-terser": "^7.0.2",
|
||||||
|
"rollup-plugin-typescript2": "^0.30.0",
|
||||||
"typescript": "^3.9.7",
|
"typescript": "^3.9.7",
|
||||||
"util": "^0.12.3",
|
"util": "^0.12.3",
|
||||||
"web-streams-polyfill": "^3.0.3",
|
"web-streams-polyfill": "^3.0.3",
|
||||||
"webpack": "^5.4.0",
|
|
||||||
"webpack-cli": "^3.3.12",
|
|
||||||
"webpack-dev-server": "^3.11.0",
|
|
||||||
"yet-another-abortcontroller-polyfill": "0.0.4"
|
"yet-another-abortcontroller-polyfill": "0.0.4"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@babel/runtime": "^7.12.5",
|
"@babel/runtime": "^7.12.5",
|
||||||
"@microsoft/fetch-event-source": "^2.0.0",
|
"@microsoft/fetch-event-source": "^2.0.0",
|
||||||
"browser-or-node": "^1.3.0",
|
"browser-or-node": "^1.3.0",
|
||||||
"browserify-zlib": "^0.2.0",
|
"core-js": "^3.19.1"
|
||||||
"buffer": "^6.0.3",
|
|
||||||
"stream-browserify": "^3.0.0",
|
|
||||||
"stream-http": "^3.1.1"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
72
pkg/npm/http-api/rollup.config.ts
Normal file
72
pkg/npm/http-api/rollup.config.ts
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
import { nodeResolve } from '@rollup/plugin-node-resolve';
|
||||||
|
import commonJS from '@rollup/plugin-commonjs';
|
||||||
|
import { terser } from 'rollup-plugin-terser';
|
||||||
|
import babel from '@rollup/plugin-babel';
|
||||||
|
import typescript from 'rollup-plugin-typescript2';
|
||||||
|
|
||||||
|
const input = ['src/index.ts'];
|
||||||
|
|
||||||
|
// Skip certain warnings
|
||||||
|
function onwarn(warning) {
|
||||||
|
if (warning.code === 'THIS_IS_UNDEFINED') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
console.warn(warning.message);
|
||||||
|
}
|
||||||
|
|
||||||
|
export default [
|
||||||
|
{
|
||||||
|
input,
|
||||||
|
onwarn,
|
||||||
|
plugins: [
|
||||||
|
nodeResolve({
|
||||||
|
extensions: ['.js', '.jsx', '.ts', '.tsx'],
|
||||||
|
}),
|
||||||
|
commonJS(),
|
||||||
|
typescript(),
|
||||||
|
babel({
|
||||||
|
babelHelpers: 'bundled',
|
||||||
|
exclude: ['node_modules/**'],
|
||||||
|
}),
|
||||||
|
terser({
|
||||||
|
ecma: 2017,
|
||||||
|
compress: true,
|
||||||
|
mangle: true,
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
output: {
|
||||||
|
file: `dist/urbit-http-api.min.js`,
|
||||||
|
format: 'umd',
|
||||||
|
name: 'UrbitHttpApi', // this is the name of the global object
|
||||||
|
esModule: false,
|
||||||
|
exports: 'named',
|
||||||
|
sourcemap: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
input,
|
||||||
|
onwarn,
|
||||||
|
plugins: [
|
||||||
|
nodeResolve({
|
||||||
|
extensions: ['.js', '.jsx', '.ts', '.tsx'],
|
||||||
|
}),
|
||||||
|
commonJS(),
|
||||||
|
typescript(),
|
||||||
|
],
|
||||||
|
output: [
|
||||||
|
{
|
||||||
|
dir: 'dist/esm',
|
||||||
|
format: 'esm',
|
||||||
|
exports: 'named',
|
||||||
|
sourcemap: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
dir: 'dist/cjs',
|
||||||
|
format: 'cjs',
|
||||||
|
exports: 'named',
|
||||||
|
sourcemap: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
];
|
@ -1,8 +1,21 @@
|
|||||||
import { isBrowser, isNode } from 'browser-or-node';
|
import { isBrowser, isNode } from 'browser-or-node';
|
||||||
import { fetchEventSource, EventSourceMessage, EventStreamContentType } from '@microsoft/fetch-event-source';
|
import {
|
||||||
|
fetchEventSource,
|
||||||
|
EventSourceMessage,
|
||||||
|
} from '@microsoft/fetch-event-source';
|
||||||
|
|
||||||
import { Action, Scry, Thread, AuthenticationInterface, SubscriptionInterface, CustomEventHandler, PokeInterface, SubscriptionRequestInterface, headers, SSEOptions, PokeHandlers, Message, FatalError } from './types';
|
import {
|
||||||
import { uncamelize, hexString } from './utils';
|
Scry,
|
||||||
|
Thread,
|
||||||
|
AuthenticationInterface,
|
||||||
|
PokeInterface,
|
||||||
|
SubscriptionRequestInterface,
|
||||||
|
headers,
|
||||||
|
SSEOptions,
|
||||||
|
PokeHandlers,
|
||||||
|
Message,
|
||||||
|
} from './types';
|
||||||
|
import { hexString } from './utils';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A class for interacting with an urbit ship, given its URL and code
|
* A class for interacting with an urbit ship, given its URL and code
|
||||||
@ -50,7 +63,8 @@ export class Urbit {
|
|||||||
* subscription is available, which may be 0, 1, or many times. The
|
* subscription is available, which may be 0, 1, or many times. The
|
||||||
* disconnect function may be called exactly once.
|
* disconnect function may be called exactly once.
|
||||||
*/
|
*/
|
||||||
private outstandingSubscriptions: Map<number, SubscriptionRequestInterface> = new Map();
|
private outstandingSubscriptions: Map<number, SubscriptionRequestInterface> =
|
||||||
|
new Map();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Our abort controller, used to close the connection
|
* Our abort controller, used to close the connection
|
||||||
@ -94,7 +108,7 @@ export class Urbit {
|
|||||||
credentials: 'include',
|
credentials: 'include',
|
||||||
accept: '*',
|
accept: '*',
|
||||||
headers,
|
headers,
|
||||||
signal: this.abort.signal
|
signal: this.abort.signal,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -106,11 +120,7 @@ export class Urbit {
|
|||||||
* be the empty string.
|
* be the empty string.
|
||||||
* @param code The access code for the ship at that address
|
* @param code The access code for the ship at that address
|
||||||
*/
|
*/
|
||||||
constructor(
|
constructor(public url: string, public code?: string, public desk?: string) {
|
||||||
public url: string,
|
|
||||||
public code?: string,
|
|
||||||
public desk?: string
|
|
||||||
) {
|
|
||||||
if (isBrowser) {
|
if (isBrowser) {
|
||||||
window.addEventListener('beforeunload', this.delete);
|
window.addEventListener('beforeunload', this.delete);
|
||||||
}
|
}
|
||||||
@ -125,12 +135,21 @@ export class Urbit {
|
|||||||
* then opens the channel via EventSource.
|
* then opens the channel via EventSource.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
static async authenticate({ ship, url, code, verbose = false }: AuthenticationInterface) {
|
static async authenticate({
|
||||||
|
ship,
|
||||||
|
url,
|
||||||
|
code,
|
||||||
|
verbose = false,
|
||||||
|
}: AuthenticationInterface) {
|
||||||
const airlock = new Urbit(`http://${url}`, code);
|
const airlock = new Urbit(`http://${url}`, code);
|
||||||
airlock.verbose = verbose;
|
airlock.verbose = verbose;
|
||||||
airlock.ship = ship;
|
airlock.ship = ship;
|
||||||
await airlock.connect();
|
await airlock.connect();
|
||||||
await airlock.poke({ app: 'hood', mark: 'helm-hi', json: 'opening airlock' });
|
await airlock.poke({
|
||||||
|
app: 'hood',
|
||||||
|
mark: 'helm-hi',
|
||||||
|
json: 'opening airlock',
|
||||||
|
});
|
||||||
await airlock.eventSource();
|
await airlock.eventSource();
|
||||||
return airlock;
|
return airlock;
|
||||||
}
|
}
|
||||||
@ -141,13 +160,18 @@ export class Urbit {
|
|||||||
*/
|
*/
|
||||||
async connect(): Promise<void> {
|
async connect(): Promise<void> {
|
||||||
if (this.verbose) {
|
if (this.verbose) {
|
||||||
console.log(`password=${this.code} `, isBrowser ? "Connecting in browser context at " + `${this.url}/~/login` : "Connecting from node context");
|
console.log(
|
||||||
|
`password=${this.code} `,
|
||||||
|
isBrowser
|
||||||
|
? 'Connecting in browser context at ' + `${this.url}/~/login`
|
||||||
|
: 'Connecting from node context'
|
||||||
|
);
|
||||||
}
|
}
|
||||||
return fetch(`${this.url}/~/login`, {
|
return fetch(`${this.url}/~/login`, {
|
||||||
method: 'post',
|
method: 'post',
|
||||||
body: `password=${this.code}`,
|
body: `password=${this.code}`,
|
||||||
credentials: 'include',
|
credentials: 'include',
|
||||||
}).then(response => {
|
}).then((response) => {
|
||||||
if (this.verbose) {
|
if (this.verbose) {
|
||||||
console.log('Received authentication response', response);
|
console.log('Received authentication response', response);
|
||||||
}
|
}
|
||||||
@ -161,24 +185,27 @@ export class Urbit {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initializes the SSE pipe for the appropriate channel.
|
* Initializes the SSE pipe for the appropriate channel.
|
||||||
*/
|
*/
|
||||||
async eventSource(): Promise<void> {
|
async eventSource(): Promise<void> {
|
||||||
if(this.sseClientInitialized) {
|
if (this.sseClientInitialized) {
|
||||||
return Promise.resolve();
|
return Promise.resolve();
|
||||||
}
|
}
|
||||||
if(this.lastEventId === 0) {
|
if (this.lastEventId === 0) {
|
||||||
// Can't receive events until the channel is open,
|
// Can't receive events until the channel is open,
|
||||||
// so poke and open then
|
// so poke and open then
|
||||||
await this.poke({ app: 'hood', mark: 'helm-hi', json: 'Opening API channel' });
|
await this.poke({
|
||||||
|
app: 'hood',
|
||||||
|
mark: 'helm-hi',
|
||||||
|
json: 'Opening API channel',
|
||||||
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this.sseClientInitialized = true;
|
this.sseClientInitialized = true;
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
const sseOptions: SSEOptions = {
|
const sseOptions: SSEOptions = {
|
||||||
headers: {}
|
headers: {},
|
||||||
};
|
};
|
||||||
if (isBrowser) {
|
if (isBrowser) {
|
||||||
sseOptions.withCredentials = true;
|
sseOptions.withCredentials = true;
|
||||||
@ -208,14 +235,17 @@ export class Urbit {
|
|||||||
}
|
}
|
||||||
if (!event.id) return;
|
if (!event.id) return;
|
||||||
this.lastEventId = parseInt(event.id, 10);
|
this.lastEventId = parseInt(event.id, 10);
|
||||||
if((this.lastEventId - this.lastAcknowledgedEventId) > 20) {
|
if (this.lastEventId - this.lastAcknowledgedEventId > 20) {
|
||||||
this.ack(this.lastEventId);
|
this.ack(this.lastEventId);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (event.data && JSON.parse(event.data)) {
|
if (event.data && JSON.parse(event.data)) {
|
||||||
const data: any = JSON.parse(event.data);
|
const data: any = JSON.parse(event.data);
|
||||||
|
|
||||||
if (data.response === 'poke' && this.outstandingPokes.has(data.id)) {
|
if (
|
||||||
|
data.response === 'poke' &&
|
||||||
|
this.outstandingPokes.has(data.id)
|
||||||
|
) {
|
||||||
const funcs = this.outstandingPokes.get(data.id);
|
const funcs = this.outstandingPokes.get(data.id);
|
||||||
if (data.hasOwnProperty('ok')) {
|
if (data.hasOwnProperty('ok')) {
|
||||||
funcs.onSuccess();
|
funcs.onSuccess();
|
||||||
@ -226,22 +256,30 @@ export class Urbit {
|
|||||||
console.error('Invalid poke response', data);
|
console.error('Invalid poke response', data);
|
||||||
}
|
}
|
||||||
this.outstandingPokes.delete(data.id);
|
this.outstandingPokes.delete(data.id);
|
||||||
} else if (data.response === 'subscribe'
|
} else if (
|
||||||
&& this.outstandingSubscriptions.has(data.id)) {
|
data.response === 'subscribe' &&
|
||||||
|
this.outstandingSubscriptions.has(data.id)
|
||||||
|
) {
|
||||||
const funcs = this.outstandingSubscriptions.get(data.id);
|
const funcs = this.outstandingSubscriptions.get(data.id);
|
||||||
if (data.hasOwnProperty('err')) {
|
if (data.hasOwnProperty('err')) {
|
||||||
console.error(data.err);
|
console.error(data.err);
|
||||||
funcs.err(data.err, data.id);
|
funcs.err(data.err, data.id);
|
||||||
this.outstandingSubscriptions.delete(data.id);
|
this.outstandingSubscriptions.delete(data.id);
|
||||||
}
|
}
|
||||||
} else if (data.response === 'diff' && this.outstandingSubscriptions.has(data.id)) {
|
} else if (
|
||||||
|
data.response === 'diff' &&
|
||||||
|
this.outstandingSubscriptions.has(data.id)
|
||||||
|
) {
|
||||||
const funcs = this.outstandingSubscriptions.get(data.id);
|
const funcs = this.outstandingSubscriptions.get(data.id);
|
||||||
try {
|
try {
|
||||||
funcs.event(data.json);
|
funcs.event(data.json);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.error('Failed to call subscription event callback', e);
|
console.error('Failed to call subscription event callback', e);
|
||||||
}
|
}
|
||||||
} else if (data.response === 'quit' && this.outstandingSubscriptions.has(data.id)) {
|
} else if (
|
||||||
|
data.response === 'quit' &&
|
||||||
|
this.outstandingSubscriptions.has(data.id)
|
||||||
|
) {
|
||||||
const funcs = this.outstandingSubscriptions.get(data.id);
|
const funcs = this.outstandingSubscriptions.get(data.id);
|
||||||
funcs.quit(data);
|
funcs.quit(data);
|
||||||
this.outstandingSubscriptions.delete(data.id);
|
this.outstandingSubscriptions.delete(data.id);
|
||||||
@ -253,7 +291,7 @@ export class Urbit {
|
|||||||
},
|
},
|
||||||
onerror: (error) => {
|
onerror: (error) => {
|
||||||
console.warn(error);
|
console.warn(error);
|
||||||
if(!(error instanceof FatalError) && this.errorCount++ < 4) {
|
if (this.errorCount++ < 4) {
|
||||||
this.onRetry && this.onRetry();
|
this.onRetry && this.onRetry();
|
||||||
return Math.pow(2, this.errorCount - 1) * 750;
|
return Math.pow(2, this.errorCount - 1) * 750;
|
||||||
}
|
}
|
||||||
@ -265,7 +303,7 @@ export class Urbit {
|
|||||||
throw new Error('Ship unexpectedly closed the connection');
|
throw new Error('Ship unexpectedly closed the connection');
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
})
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -301,7 +339,7 @@ export class Urbit {
|
|||||||
this.lastAcknowledgedEventId = eventId;
|
this.lastAcknowledgedEventId = eventId;
|
||||||
const message: Message = {
|
const message: Message = {
|
||||||
action: 'ack',
|
action: 'ack',
|
||||||
'event-id': eventId
|
'event-id': eventId,
|
||||||
};
|
};
|
||||||
await this.sendJSONtoChannel(message);
|
await this.sendJSONtoChannel(message);
|
||||||
return eventId;
|
return eventId;
|
||||||
@ -311,12 +349,12 @@ export class Urbit {
|
|||||||
const response = await fetch(this.channelUrl, {
|
const response = await fetch(this.channelUrl, {
|
||||||
...this.fetchOptions,
|
...this.fetchOptions,
|
||||||
method: 'PUT',
|
method: 'PUT',
|
||||||
body: JSON.stringify(json)
|
body: JSON.stringify(json),
|
||||||
});
|
});
|
||||||
if(!response.ok) {
|
if (!response.ok) {
|
||||||
throw new Error('Failed to PUT channel');
|
throw new Error('Failed to PUT channel');
|
||||||
}
|
}
|
||||||
if(!this.sseClientInitialized) {
|
if (!this.sseClientInitialized) {
|
||||||
await this.eventSource();
|
await this.eventSource();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -335,23 +373,23 @@ export class Urbit {
|
|||||||
let done = false;
|
let done = false;
|
||||||
let id: number | null = null;
|
let id: number | null = null;
|
||||||
const quit = () => {
|
const quit = () => {
|
||||||
if(!done) {
|
if (!done) {
|
||||||
reject('quit');
|
reject('quit');
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
const event = (e: T) => {
|
const event = (e: T) => {
|
||||||
if(!done) {
|
if (!done) {
|
||||||
resolve(e);
|
resolve(e);
|
||||||
this.unsubscribe(id);
|
this.unsubscribe(id);
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
const request = { app, path, event, err: reject, quit };
|
const request = { app, path, event, err: reject, quit };
|
||||||
|
|
||||||
id = await this.subscribe(request);
|
id = await this.subscribe(request);
|
||||||
|
|
||||||
if(timeout) {
|
if (timeout) {
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
if(!done) {
|
if (!done) {
|
||||||
done = true;
|
done = true;
|
||||||
reject('timeout');
|
reject('timeout');
|
||||||
this.unsubscribe(id);
|
this.unsubscribe(id);
|
||||||
@ -369,18 +407,11 @@ export class Urbit {
|
|||||||
* @param json The data to send
|
* @param json The data to send
|
||||||
*/
|
*/
|
||||||
async poke<T>(params: PokeInterface<T>): Promise<number> {
|
async poke<T>(params: PokeInterface<T>): Promise<number> {
|
||||||
const {
|
const { app, mark, json, ship, onSuccess, onError } = {
|
||||||
app,
|
onSuccess: () => {},
|
||||||
mark,
|
onError: () => {},
|
||||||
json,
|
|
||||||
ship,
|
|
||||||
onSuccess,
|
|
||||||
onError
|
|
||||||
} = {
|
|
||||||
onSuccess: () => { },
|
|
||||||
onError: () => { },
|
|
||||||
ship: this.ship,
|
ship: this.ship,
|
||||||
...params
|
...params,
|
||||||
};
|
};
|
||||||
const message: Message = {
|
const message: Message = {
|
||||||
id: this.getEventId(),
|
id: this.getEventId(),
|
||||||
@ -388,7 +419,7 @@ export class Urbit {
|
|||||||
ship,
|
ship,
|
||||||
app,
|
app,
|
||||||
mark,
|
mark,
|
||||||
json
|
json,
|
||||||
};
|
};
|
||||||
const [send, result] = await Promise.all([
|
const [send, result] = await Promise.all([
|
||||||
this.sendJSONtoChannel(message),
|
this.sendJSONtoChannel(message),
|
||||||
@ -401,9 +432,9 @@ export class Urbit {
|
|||||||
onError: (event) => {
|
onError: (event) => {
|
||||||
onError(event);
|
onError(event);
|
||||||
reject(event.err);
|
reject(event.err);
|
||||||
}
|
},
|
||||||
});
|
});
|
||||||
})
|
}),
|
||||||
]);
|
]);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -417,19 +448,12 @@ export class Urbit {
|
|||||||
* @param handlers Handlers to deal with various events of the subscription
|
* @param handlers Handlers to deal with various events of the subscription
|
||||||
*/
|
*/
|
||||||
async subscribe(params: SubscriptionRequestInterface): Promise<number> {
|
async subscribe(params: SubscriptionRequestInterface): Promise<number> {
|
||||||
const {
|
const { app, path, ship, err, event, quit } = {
|
||||||
app,
|
err: () => {},
|
||||||
path,
|
event: () => {},
|
||||||
ship,
|
quit: () => {},
|
||||||
err,
|
|
||||||
event,
|
|
||||||
quit
|
|
||||||
} = {
|
|
||||||
err: () => { },
|
|
||||||
event: () => { },
|
|
||||||
quit: () => { },
|
|
||||||
ship: this.ship,
|
ship: this.ship,
|
||||||
...params
|
...params,
|
||||||
};
|
};
|
||||||
|
|
||||||
const message: Message = {
|
const message: Message = {
|
||||||
@ -437,11 +461,15 @@ export class Urbit {
|
|||||||
action: 'subscribe',
|
action: 'subscribe',
|
||||||
ship,
|
ship,
|
||||||
app,
|
app,
|
||||||
path
|
path,
|
||||||
};
|
};
|
||||||
|
|
||||||
this.outstandingSubscriptions.set(message.id, {
|
this.outstandingSubscriptions.set(message.id, {
|
||||||
app, path, err, event, quit
|
app,
|
||||||
|
path,
|
||||||
|
err,
|
||||||
|
event,
|
||||||
|
quit,
|
||||||
});
|
});
|
||||||
|
|
||||||
await this.sendJSONtoChannel(message);
|
await this.sendJSONtoChannel(message);
|
||||||
@ -458,7 +486,7 @@ export class Urbit {
|
|||||||
return this.sendJSONtoChannel({
|
return this.sendJSONtoChannel({
|
||||||
id: this.getEventId(),
|
id: this.getEventId(),
|
||||||
action: 'unsubscribe',
|
action: 'unsubscribe',
|
||||||
subscription
|
subscription,
|
||||||
}).then(() => {
|
}).then(() => {
|
||||||
this.outstandingSubscriptions.delete(subscription);
|
this.outstandingSubscriptions.delete(subscription);
|
||||||
});
|
});
|
||||||
@ -469,9 +497,14 @@ export class Urbit {
|
|||||||
*/
|
*/
|
||||||
delete() {
|
delete() {
|
||||||
if (isBrowser) {
|
if (isBrowser) {
|
||||||
navigator.sendBeacon(this.channelUrl, JSON.stringify([{
|
navigator.sendBeacon(
|
||||||
action: 'delete'
|
this.channelUrl,
|
||||||
}]));
|
JSON.stringify([
|
||||||
|
{
|
||||||
|
action: 'delete',
|
||||||
|
},
|
||||||
|
])
|
||||||
|
);
|
||||||
} else {
|
} else {
|
||||||
// TODO
|
// TODO
|
||||||
// this.sendMessage('delete');
|
// this.sendMessage('delete');
|
||||||
@ -496,7 +529,10 @@ export class Urbit {
|
|||||||
*/
|
*/
|
||||||
async scry<T = any>(params: Scry): Promise<T> {
|
async scry<T = any>(params: Scry): Promise<T> {
|
||||||
const { app, path } = params;
|
const { app, path } = params;
|
||||||
const response = await fetch(`${this.url}/~/scry/${app}${path}.json`, this.fetchOptions);
|
const response = await fetch(
|
||||||
|
`${this.url}/~/scry/${app}${path}.json`,
|
||||||
|
this.fetchOptions
|
||||||
|
);
|
||||||
return await response.json();
|
return await response.json();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -511,15 +547,24 @@ export class Urbit {
|
|||||||
* @returns The return value of the thread
|
* @returns The return value of the thread
|
||||||
*/
|
*/
|
||||||
async thread<R, T = any>(params: Thread<T>): Promise<R> {
|
async thread<R, T = any>(params: Thread<T>): Promise<R> {
|
||||||
const { inputMark, outputMark, threadName, body, desk = this.desk } = params;
|
const {
|
||||||
if(!desk) {
|
inputMark,
|
||||||
throw new Error("Must supply desk to run thread from");
|
outputMark,
|
||||||
|
threadName,
|
||||||
|
body,
|
||||||
|
desk = this.desk,
|
||||||
|
} = params;
|
||||||
|
if (!desk) {
|
||||||
|
throw new Error('Must supply desk to run thread from');
|
||||||
}
|
}
|
||||||
const res = await fetch(`${this.url}/spider/${desk}/${inputMark}/${threadName}/${outputMark}.json`, {
|
const res = await fetch(
|
||||||
|
`${this.url}/spider/${desk}/${inputMark}/${threadName}/${outputMark}.json`,
|
||||||
|
{
|
||||||
...this.fetchOptions,
|
...this.fetchOptions,
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
body: JSON.stringify(body)
|
body: JSON.stringify(body),
|
||||||
});
|
}
|
||||||
|
);
|
||||||
|
|
||||||
return res.json();
|
return res.json();
|
||||||
}
|
}
|
||||||
@ -536,6 +581,4 @@ export class Urbit {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
export default Urbit;
|
export default Urbit;
|
||||||
|
@ -1,3 +0,0 @@
|
|||||||
// import Urbit from '../../dist/browser';
|
|
||||||
|
|
||||||
// window.Urbit = Urbit;
|
|
@ -1,14 +0,0 @@
|
|||||||
// import Urbit from '../../dist/index';
|
|
||||||
|
|
||||||
// async function blastOff() {
|
|
||||||
// const airlock = await Urbit.authenticate({
|
|
||||||
// ship: 'zod',
|
|
||||||
// url: 'localhost:8080',
|
|
||||||
// code: 'lidlut-tabwed-pillex-ridrup',
|
|
||||||
// verbose: true
|
|
||||||
// });
|
|
||||||
|
|
||||||
// airlock.subscribe('chat-view', '/primary');
|
|
||||||
// }
|
|
||||||
|
|
||||||
// blastOff();
|
|
@ -1,3 +1,3 @@
|
|||||||
export * from './types';
|
export * from './types';
|
||||||
import Urbit from './Urbit';
|
import { Urbit } from './Urbit';
|
||||||
export { Urbit as default };
|
export { Urbit as default, Urbit };
|
||||||
|
@ -1,41 +1,12 @@
|
|||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
interface HttpResponse {
|
|
||||||
req: http.ClientRequest;
|
|
||||||
res: http.IncomingMessage;
|
|
||||||
data: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function request(
|
|
||||||
url: string,
|
|
||||||
options: http.ClientRequestArgs,
|
|
||||||
body?: string
|
|
||||||
): Promise<HttpResponse> {
|
|
||||||
return new Promise<HttpResponse>((resolve, reject) => {
|
|
||||||
const req = http.request(url, options, res => {
|
|
||||||
let data = "";
|
|
||||||
res.on("data", chunk => {
|
|
||||||
data += chunk;
|
|
||||||
});
|
|
||||||
res.on("end", () => {
|
|
||||||
resolve({ req, res, data });
|
|
||||||
});
|
|
||||||
res.on("error", e => {
|
|
||||||
reject(e);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
if (body) {
|
|
||||||
req.write(body);
|
|
||||||
}
|
|
||||||
req.end();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
export function camelize(str: string) {
|
export function camelize(str: string) {
|
||||||
return str
|
return str
|
||||||
.replace(/\s(.)/g, function($1: string) { return $1.toUpperCase(); })
|
.replace(/\s(.)/g, function ($1: string) {
|
||||||
|
return $1.toUpperCase();
|
||||||
|
})
|
||||||
.replace(/\s/g, '')
|
.replace(/\s/g, '')
|
||||||
.replace(/^(.)/, function($1: string) { return $1.toLowerCase(); });
|
.replace(/^(.)/, function ($1: string) {
|
||||||
|
return $1.toLowerCase();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export function uncamelize(str: string, separator = '-') {
|
export function uncamelize(str: string, separator = '-') {
|
||||||
|
@ -1,6 +1,4 @@
|
|||||||
|
|
||||||
import Urbit from '../src';
|
import Urbit from '../src';
|
||||||
import { Readable } from 'streams';
|
|
||||||
import 'jest';
|
import 'jest';
|
||||||
|
|
||||||
function fakeSSE(messages = [], timeout = 0) {
|
function fakeSSE(messages = [], timeout = 0) {
|
||||||
@ -54,7 +52,7 @@ const fakeFetch = (body) => () =>
|
|||||||
|
|
||||||
const wait = (ms: number) => new Promise((res) => setTimeout(res, ms));
|
const wait = (ms: number) => new Promise((res) => setTimeout(res, ms));
|
||||||
|
|
||||||
process.on('unhandledRejection', () => {
|
process.on('unhandledRejection', (error) => {
|
||||||
console.error(error);
|
console.error(error);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -91,7 +89,7 @@ describe('Initialisation', () => {
|
|||||||
)
|
)
|
||||||
.mockImplementationOnce(() =>
|
.mockImplementationOnce(() =>
|
||||||
Promise.resolve({ ok: true, body: fakeSSE([], 100) })
|
Promise.resolve({ ok: true, body: fakeSSE([], 100) })
|
||||||
)
|
);
|
||||||
|
|
||||||
airlock.onError = jest.fn();
|
airlock.onError = jest.fn();
|
||||||
try {
|
try {
|
||||||
@ -163,7 +161,7 @@ describe('subscription', () => {
|
|||||||
)
|
)
|
||||||
.mockImplementationOnce(() =>
|
.mockImplementationOnce(() =>
|
||||||
Promise.resolve({ ok: false, body: fakeSSE([ack(1, true)]) })
|
Promise.resolve({ ok: false, body: fakeSSE([ack(1, true)]) })
|
||||||
)
|
);
|
||||||
|
|
||||||
const params = {
|
const params = {
|
||||||
app: 'app',
|
app: 'app',
|
||||||
|
@ -1,23 +1,24 @@
|
|||||||
{
|
{
|
||||||
"include": ["src/**/*"],
|
"include": ["src/**/*.ts"],
|
||||||
"exclude": ["node_modules", "dist", "@types"],
|
"exclude": ["node_modules", "dist", "tmp"],
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
"outDir": "./dist",
|
"outDir": "./tmp",
|
||||||
"module": "ESNext",
|
"module": "ESNext",
|
||||||
"noImplicitAny": true,
|
|
||||||
"target": "ESNext",
|
"target": "ESNext",
|
||||||
"pretty": true,
|
"lib": ["ESNext", "DOM"],
|
||||||
"moduleResolution": "node",
|
"moduleResolution": "node",
|
||||||
"esModuleInterop": true,
|
"esModuleInterop": true,
|
||||||
"allowSyntheticDefaultImports": true,
|
"allowSyntheticDefaultImports": true,
|
||||||
"declaration": true,
|
"declaration": true,
|
||||||
"sourceMap": true,
|
"sourceMap": true,
|
||||||
"strict": false,
|
"strict": false,
|
||||||
|
"pretty": true,
|
||||||
|
"noImplicitAny": true,
|
||||||
"noErrorTruncation": true,
|
"noErrorTruncation": true,
|
||||||
"allowJs": true,
|
"allowJs": true,
|
||||||
"baseUrl": ".",
|
"baseUrl": ".",
|
||||||
"paths": {
|
"paths": {
|
||||||
"*" : ["./node_modules/@types/*", "*"]
|
"*": ["./node_modules/@types/*", "*"]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user