Skip to content
Permalink

Comparing changes

Choose two branches to see what’s changed or to start a new pull request. If you need to, you can also or learn more about diff comparisons.

Open a pull request

Create a new pull request by comparing changes across two branches. If you need to, you can also . Learn more about diff comparisons here.
base repository: hopinc/docs
Failed to load repositories. Confirm that selected base ref is valid, then try again.
Loading
base: main
Choose a base ref
...
head repository: datalinkhq/docs
Failed to load repositories. Confirm that selected head ref is valid, then try again.
Loading
compare: main
Choose a head ref
Can’t automatically merge. Don’t worry, you can still create the pull request.
Loading
Showing with 7,190 additions and 7,747 deletions.
  1. +2 −0 .dockerignore
  2. +3 −3 .eslintrc.js
  3. +7 −7 .gitignore
  4. +9 −0 .gitpod.yml
  5. +1 −1 .prettierignore
  6. +11 −11 .prettierrc
  7. +14 −22 assets/BrandVectors.tsx
  8. +13 −13 components/client.tsx
  9. +3 −3 components/code.module.css
  10. +104 −73 components/code.tsx
  11. +67 −67 context/code.tsx
  12. +4 −5 hop.yml
  13. +5 −5 next-env.d.ts
  14. +37 −37 next.config.js
  15. +35 −37 package.json
  16. +14 −14 pages/_app.js
  17. +19 −19 pages/_document.js
  18. +0 −66 pages/channels/internals/atlas_protocol.mdx
  19. +0 −108 pages/channels/internals/leap.mdx
  20. +0 −5 pages/channels/internals/meta.json
  21. +0 −217 pages/channels/internals/payloads.mdx
  22. +0 −5 pages/channels/meta.json
  23. +0 −100 pages/channels/overview.mdx
  24. +0 −59 pages/channels/reference/creating.mdx
  25. +0 −5 pages/channels/reference/meta.json
  26. +0 −43 pages/channels/reference/sending_messages.mdx
  27. +0 −40 pages/channels/reference/updating_state.mdx
  28. +0 −62 pages/channels/state.mdx
  29. +0 −65 pages/cli.mdx
  30. +0 −51 pages/ignite/deploying.mdx
  31. +0 −64 pages/ignite/gateways.mdx
  32. +0 −72 pages/ignite/images.mdx
  33. +0 −6 pages/ignite/meta.json
  34. +0 −49 pages/ignite/overview.mdx
  35. +0 −63 pages/ignite/project_secrets.mdx
  36. +38 −33 pages/index.mdx
  37. +4 −8 pages/meta.json
  38. +0 −3 pages/pipe/api_reference/meta.json
  39. +0 −56 pages/pipe/api_reference/room.mdx
  40. +0 −133 pages/pipe/client_implementation.mdx
  41. +0 −73 pages/pipe/getting_started.mdx
  42. +0 −8 pages/pipe/meta.json
  43. +0 −32 pages/pipe/overview.mdx
  44. +0 −89 pages/pipe/protocols/llhls.mdx
  45. +0 −3 pages/pipe/protocols/meta.json
  46. +0 −64 pages/pipe/streaming_to_pipe.mdx
  47. +35 −0 pages/reference/api_reference/endpoints/auth.mdx
  48. +34 −0 pages/reference/api_reference/endpoints/create.mdx
  49. +34 −0 pages/reference/api_reference/endpoints/destroy.mdx
  50. +39 −0 pages/reference/api_reference/endpoints/eventpublish.mdx
  51. +63 −0 pages/reference/api_reference/endpoints/ff-fetch.mdx
  52. +36 −0 pages/reference/api_reference/endpoints/ff-set.mdx
  53. +37 −0 pages/reference/api_reference/endpoints/ff-update.mdx
  54. +44 −0 pages/reference/api_reference/endpoints/heartbeat.mdx
  55. +52 −0 pages/reference/api_reference/endpoints/logfetch.mdx
  56. +35 −0 pages/reference/api_reference/endpoints/logpublish.mdx
  57. +14 −0 pages/reference/api_reference/endpoints/meta.json
  58. +41 −0 pages/reference/api_reference/endpoints/playerjoin.mdx
  59. +36 −0 pages/reference/api_reference/endpoints/playerleft.mdx
  60. +3 −0 pages/reference/api_reference/meta.json
  61. +14 −0 pages/reference/api_reference/overview.mdx
  62. +3 −4 pages/reference/meta.json
  63. +0 −55 pages/reference/project_tokens.mdx
  64. +0 −17 pages/reference/regions.mdx
  65. +0 −40 pages/sdks/client/js.mdx
  66. +0 −4 pages/sdks/client/meta.json
  67. +0 −75 pages/sdks/client/react.mdx
  68. +4 −4 pages/sdks/meta.json
  69. +101 −0 pages/sdks/overview.mdx
  70. +48 −0 pages/sdks/sdk/authentication.mdx
  71. +47 −0 pages/sdks/sdk/constructor.mdx
  72. +7 −0 pages/sdks/sdk/meta.json
  73. +15 −0 pages/sdks/sdk/methods/authenticateAsync.mdx
  74. +15 −0 pages/sdks/sdk/methods/getFastFlagAsync.mdx
  75. +15 −0 pages/sdks/sdk/methods/getFastIntAsync.mdx
  76. +15 −0 pages/sdks/sdk/methods/invokeEventAsync.mdx
  77. +15 −0 pages/sdks/sdk/methods/isAuthenticated.mdx
  78. +7 −0 pages/sdks/sdk/methods/meta.json
  79. +1 −0 pages/sdks/sdk/properties/meta.json
  80. +3 −0 pages/sdks/sdk/signals/meta.json
  81. +15 −0 pages/sdks/sdk/signals/onAuthenticated.mdx
  82. +0 −41 pages/sdks/server/js.mdx
  83. +0 −3 pages/sdks/server/meta.json
  84. +5,660 −0 pnpm-lock.yaml
  85. +7 −7 postcss.config.js
  86. +6 −6 public/icons/clipboard.svg
  87. +9 −0 public/icons/logo.svg
  88. +33 −33 styles/globals.css
  89. +74 −74 tailwind.config.js
  90. +87 −87 theme.config.js
  91. +70 −70 theme.ts
  92. +26 −26 tsconfig.json
  93. +0 −5,302 yarn.lock
2 changes: 2 additions & 0 deletions .dockerignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
.yarn
.yarnrc.yml
6 changes: 3 additions & 3 deletions .eslintrc.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
module.exports = {
extends: 'next/core-web-vitals',
};
module.exports = {
extends: 'next/core-web-vitals',
};
14 changes: 7 additions & 7 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
*.log
.yarn/*
!.yarn/releases
!.yarn/plugins
!.yarn/sdks
node_modules
.next
*.log
.yarn/*
!.yarn/releases
!.yarn/plugins
!.yarn/sdks
node_modules
.next
9 changes: 9 additions & 0 deletions .gitpod.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
# This configuration file was automatically generated by Gitpod.
# Please adjust to your needs (see https://www.gitpod.io/docs/config-gitpod-file)
# and commit this file to your remote git repository to share the goodness with others.

tasks:
- init: yarn install && yarn run build
command: yarn run start


2 changes: 1 addition & 1 deletion .prettierignore
Original file line number Diff line number Diff line change
@@ -1 +1 @@
pages/**/*.mdx
pages/**/*.mdx
22 changes: 11 additions & 11 deletions .prettierrc
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
{
"$schema": "http://json.schemastore.org/prettierrc",
"singleQuote": true,
"semi": true,
"printWidth": 80,
"trailingComma": "all",
"arrowParens": "avoid",
"bracketSpacing": false,
"useTabs": true,
"quoteProps": "consistent"
}
{
"$schema": "http://json.schemastore.org/prettierrc",
"singleQuote": true,
"semi": true,
"printWidth": 80,
"trailingComma": "all",
"arrowParens": "avoid",
"bracketSpacing": false,
"useTabs": true,
"quoteProps": "consistent"
}
36 changes: 14 additions & 22 deletions assets/BrandVectors.tsx
Original file line number Diff line number Diff line change
@@ -1,22 +1,14 @@
import {SVGProps} from 'react';

export const HopLogo = (props: SVGProps<SVGSVGElement>) => (
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 160 100" {...props}>
<g id="a1c6c63a-e459-44a3-b4b7-af910ae95872" data-name="Layer 2">
<g id="fa506414-24b2-4115-bfea-5ced8b49bd02" data-name="Layer 1">
<path
d="M30,20a30.09,30.09,0,0,0-10,1.71V0H0V80H20V50a10,10,0,0,1,20,0V80H60V50A30,30,0,0,0,30,20Z"
fill="currentColor"
/>
<path
d="M80,20a30,30,0,1,0,30,30A30,30,0,0,0,80,20Zm0,40A10,10,0,1,1,90,50,10,10,0,0,1,80,60Z"
fill="currentColor"
/>
<path
d="M130,20a30,30,0,0,0-30,30v50h20V78.29A30,30,0,1,0,130,20Zm0,40a10,10,0,1,1,10-10A10,10,0,0,1,130,60Z"
fill="currentColor"
/>
</g>
</g>
</svg>
);
import {SVGProps} from 'react';

export const DatalinkLogo = (props: SVGProps<SVGSVGElement>) => (
<svg version="1.2" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 160 100" {...props}>
<title>logo</title>
<defs>
<image width="532" height="466" id="img1" href=""/>
</defs>
<style>
</style>
<use id="White copy" href="#img1" x="234" y="267"/>
</svg>
);

26 changes: 13 additions & 13 deletions components/client.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
import dynamic from 'next/dynamic';
import {ReactNode} from 'react';

export const NoSSR = dynamic(
async () => {
function Component(props: {children: ReactNode}) {
return <>{props.children}</>;
}

return Component;
},
{ssr: false},
);
import dynamic from 'next/dynamic';
import {ReactNode} from 'react';

export const NoSSR = dynamic(
async () => {
function Component(props: {children: ReactNode}) {
return <>{props.children}</>;
}

return Component;
},
{ssr: false},
);
6 changes: 3 additions & 3 deletions components/code.module.css
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
.code__container [data-rehype-pretty-code-fragment] > pre {
margin: 0;
}
.code__container [data-rehype-pretty-code-fragment] > pre {
margin: 0;
}
177 changes: 104 additions & 73 deletions components/code.tsx
Original file line number Diff line number Diff line change
@@ -1,73 +1,104 @@
import {Children, ReactElement} from 'react';
import clsx from 'clsx';
import styles from './code.module.css';
import {useCurrentLanguage} from '../context/code';

export interface Props {
children: ReactElement[];
}

export function Code(props: Props) {
const children = Children.map(props.children, child => {
const language = child.props.children.props.children.props[
'data-language'
] as string;

return {
language,
Component: child,
};
});

const [activeLanguage, setActiveLanguage] = useCurrentLanguage(
children.map(child => child.language),
);

return (
<div
className={clsx(
'flex flex-col my-5 dark:bg-black rounded-lg space-y-2 p-3 border border-neutral-100 dark:border-neutral-900',
styles.code__container,
)}
>
<div className="flex max-w-full overflow-x-auto divide-x divide-neutral-100 dark:divide-neutral-800">
{children.map(child => {
const active = activeLanguage === child.language;

return (
<div
key={child.language}
className="px-3 first-of-type:pl-0 last-of-type:pr-0"
>
<button
className={clsx(
'transition-colors px-6 py-1 text-xs uppercase tracking-widest inline-block rounded-md',
{
'bg-primary-500 text-primary-50 dark:bg-neutral-800':
active,
'hover:bg-neutral-100 dark:hover:bg-neutral-900': !active,
},
)}
onClick={() => setActiveLanguage(child.language)}
>
{child.language}
</button>
</div>
);
})}
</div>

<div>
{children.map(child => {
const active = activeLanguage === child.language;

return (
<div key={child.language} className={active ? 'block' : 'hidden'}>
{child.Component}
</div>
);
})}
</div>
</div>
);
}
import {Children, ReactElement, useMemo} from 'react';
import clsx from 'clsx';
import styles from './code.module.css';
import {useCurrentLanguage} from '../context/code';

export interface Props {
children: ReactElement[];
}

export function Code(props: Props) {
const children = useMemo(() => {
return Children.map(props.children, child => {
if (Array.isArray(child.props.children)) {
if (child.props.children.length !== 2) {
throw new Error(
'Code component must have exactly two children, title and codeblock',
);
}

const title = child.props.children[0].props.children as string;

const language = child.props.children[1].props.children.props[
'data-language'
] as string;

return {
title,
language,
Component: child.props.children[1],
};
}

const language = child.props.children.props.children.props[
'data-language'
] as string;

return {
language,
Component: child,
};
});
}, [props.children]);

const [activeLanguage, setActiveLanguage] = useCurrentLanguage(
children.map(child => child.language),
);

const activeTitle =
children.find(child => child.language === activeLanguage)?.title ?? null;

return (
<div
className={clsx(
'flex flex-col my-5 dark:bg-black rounded-lg space-y-2 p-3 border border-neutral-100 dark:border-neutral-900',
styles.code__container,
)}
>
<div className="flex max-w-full items-center space-x-2 overflow-x-auto justify-between">
{children.map(child => {
const active = activeLanguage === child.language;

return (
<div
key={child.language}
className="px-3 first-of-type:pl-0 last-of-type:pr-0"
>
<button
className={clsx(
'transition-colors px-6 py-1 text-xs uppercase tracking-widest inline-block rounded-md',
{
'bg-primary-500 text-primary-50 dark:bg-neutral-800':
active,
'hover:bg-neutral-100 dark:hover:bg-neutral-900': !active,
},
)}
onClick={() => setActiveLanguage(child.language)}
>
{child.language}
</button>
</div>
);
})}

{activeTitle && (
<p className="text-neutral-500 dark:text-neutral-400">
{activeTitle}
</p>
)}
</div>

<div>
{children.map(child => {
const active = activeLanguage === child.language;

return (
<div key={child.language} className={active ? 'block' : 'hidden'}>
{child.Component}
</div>
);
})}
</div>
</div>
);
}
Loading