mirror of
https://github.com/ilyakooo0/urbit.git
synced 2025-01-04 13:19:48 +03:00
interface: inject location of tutorial group at compile tim
This commit is contained in:
parent
1e7a09714b
commit
07518e5cff
@ -1,4 +1,5 @@
|
|||||||
const path = require('path');
|
const path = require('path');
|
||||||
|
const webpack = require('webpack');
|
||||||
// const HtmlWebpackPlugin = require('html-webpack-plugin');
|
// const HtmlWebpackPlugin = require('html-webpack-plugin');
|
||||||
// const { CleanWebpackPlugin } = require('clean-webpack-plugin');
|
// const { CleanWebpackPlugin } = require('clean-webpack-plugin');
|
||||||
const urbitrc = require('./urbitrc');
|
const urbitrc = require('./urbitrc');
|
||||||
@ -117,7 +118,15 @@ module.exports = {
|
|||||||
devtool: 'inline-source-map',
|
devtool: 'inline-source-map',
|
||||||
devServer: devServer,
|
devServer: devServer,
|
||||||
plugins: [
|
plugins: [
|
||||||
new UrbitShipPlugin(urbitrc)
|
new UrbitShipPlugin(urbitrc),
|
||||||
|
new webpack.DefinePlugin({
|
||||||
|
'process.env.TUTORIAL_HOST': JSON.stringify('~hastuc-dibtux'),
|
||||||
|
'process.env.TUTORIAL_GROUP': JSON.stringify('beginner-island'),
|
||||||
|
'process.env.TUTORIAL_CHAT': JSON.stringify('chat-8401'),
|
||||||
|
'process.env.TUTORIAL_BOOK': JSON.stringify('notebook-9148'),
|
||||||
|
'process.env.TUTORIAL_LINKS': JSON.stringify('link-4353'),
|
||||||
|
})
|
||||||
|
|
||||||
// new CleanWebpackPlugin(),
|
// new CleanWebpackPlugin(),
|
||||||
// new HtmlWebpackPlugin({
|
// new HtmlWebpackPlugin({
|
||||||
// title: 'Hot Module Replacement',
|
// title: 'Hot Module Replacement',
|
||||||
|
@ -56,8 +56,13 @@ module.exports = {
|
|||||||
new CleanWebpackPlugin(),
|
new CleanWebpackPlugin(),
|
||||||
new webpack.DefinePlugin({
|
new webpack.DefinePlugin({
|
||||||
'process.env.LANDSCAPE_STREAM': JSON.stringify(process.env.LANDSCAPE_STREAM),
|
'process.env.LANDSCAPE_STREAM': JSON.stringify(process.env.LANDSCAPE_STREAM),
|
||||||
'process.env.LANDSCAPE_SHORTHASH': JSON.stringify(process.env.LANDSCAPE_SHORTHASH)
|
'process.env.LANDSCAPE_SHORTHASH': JSON.stringify(process.env.LANDSCAPE_SHORTHASH),
|
||||||
})
|
'process.env.TUTORIAL_HOST': JSON.stringify('~hastuc-dibtux'),
|
||||||
|
'process.env.TUTORIAL_GROUP': JSON.stringify('beginner-island'),
|
||||||
|
'process.env.TUTORIAL_CHAT': JSON.stringify('chat-8401'),
|
||||||
|
'process.env.TUTORIAL_BOOK': JSON.stringify('notebook-9148'),
|
||||||
|
'process.env.TUTORIAL_LINKS': JSON.stringify('links-4353'),
|
||||||
|
}),
|
||||||
// new HtmlWebpackPlugin({
|
// new HtmlWebpackPlugin({
|
||||||
// title: 'Hot Module Replacement',
|
// title: 'Hot Module Replacement',
|
||||||
// template: './public/index.html',
|
// template: './public/index.html',
|
||||||
|
@ -1,14 +1,17 @@
|
|||||||
import { TutorialProgress, Associations } from "~/types";
|
import { TutorialProgress, Associations } from "~/types";
|
||||||
import {
|
import { AlignX, AlignY } from "~/logic/lib/relativePosition";
|
||||||
AlignX,
|
|
||||||
AlignY,
|
|
||||||
} from "~/logic/lib/relativePosition";
|
|
||||||
|
|
||||||
export const MODAL_WIDTH = 256;
|
export const MODAL_WIDTH = 256;
|
||||||
export const MODAL_HEIGHT = 180;
|
export const MODAL_HEIGHT = 180;
|
||||||
export const MODAL_WIDTH_PX = `${MODAL_WIDTH}px`;
|
export const MODAL_WIDTH_PX = `${MODAL_WIDTH}px`;
|
||||||
export const MODAL_HEIGHT_PX = `${MODAL_HEIGHT}px`;
|
export const MODAL_HEIGHT_PX = `${MODAL_HEIGHT}px`;
|
||||||
|
|
||||||
|
export const TUTORIAL_HOST = process.env.TUTORIAL_HOST;
|
||||||
|
export const TUTORIAL_GROUP = process.env.TUTORIAL_GROUP;
|
||||||
|
export const TUTORIAL_CHAT = process.env.TUTORIAL_CHAT;
|
||||||
|
export const TUTORIAL_BOOK = process.env.TUTORIAL_BOOK;
|
||||||
|
export const TUTORIAL_LINKS = process.env.TUTORIAL_LINKS;
|
||||||
|
|
||||||
interface StepDetail {
|
interface StepDetail {
|
||||||
title: string;
|
title: string;
|
||||||
description: string;
|
description: string;
|
||||||
@ -20,19 +23,22 @@ interface StepDetail {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function hasTutorialGroup(props: { associations: Associations }) {
|
export function hasTutorialGroup(props: { associations: Associations }) {
|
||||||
return '/ship/~hastuc-dibtux/beginner-island' in props.associations.groups;
|
return (
|
||||||
|
`/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}` in props.associations.groups
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export const progressDetails: Record<TutorialProgress, StepDetail> = {
|
export const progressDetails: Record<TutorialProgress, StepDetail> = {
|
||||||
hidden: {} as any,
|
hidden: {} as any,
|
||||||
done: {
|
done: {
|
||||||
title: "End",
|
title: "End",
|
||||||
description: "This tutorial is finished. Would you like to leave Beginner Island?",
|
description:
|
||||||
|
"This tutorial is finished. Would you like to leave Beginner Island?",
|
||||||
url: "/",
|
url: "/",
|
||||||
alignX: "right",
|
alignX: "right",
|
||||||
alignY: "top",
|
alignY: "top",
|
||||||
offsetX: MODAL_WIDTH + 8,
|
offsetX: MODAL_WIDTH + 8,
|
||||||
offsetY: 0
|
offsetY: 0,
|
||||||
},
|
},
|
||||||
start: {
|
start: {
|
||||||
title: "New group added",
|
title: "New group added",
|
||||||
@ -42,21 +48,23 @@ export const progressDetails: Record<TutorialProgress, StepDetail> = {
|
|||||||
alignX: "right",
|
alignX: "right",
|
||||||
alignY: "top",
|
alignY: "top",
|
||||||
offsetX: MODAL_WIDTH + 8,
|
offsetX: MODAL_WIDTH + 8,
|
||||||
offsetY: 0
|
offsetY: 0,
|
||||||
},
|
},
|
||||||
'group-desc': {
|
"group-desc": {
|
||||||
title: "What's a group",
|
title: "What's a group",
|
||||||
description: "A group contains members and tends to be centered around a topic or multiple topics.",
|
description:
|
||||||
url: "/~landscape/ship/~hastuc-dibtux/beginner-island",
|
"A group contains members and tends to be centered around a topic or multiple topics.",
|
||||||
|
url: `/~landscape/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}`,
|
||||||
alignX: "left",
|
alignX: "left",
|
||||||
alignY: "top",
|
alignY: "top",
|
||||||
offsetX: MODAL_WIDTH + 8,
|
offsetX: MODAL_WIDTH + 8,
|
||||||
offsetY: (MODAL_HEIGHT / 2) - 8,
|
offsetY: MODAL_HEIGHT / 2 - 8,
|
||||||
},
|
},
|
||||||
channels: {
|
channels: {
|
||||||
title: "Channels",
|
title: "Channels",
|
||||||
description: "Inside a group you have three types of Channels: Chat, Collection, or Notebook. Mix and match these depending on your group context!",
|
description:
|
||||||
url: "/~landscape/ship/~hastuc-dibtux/beginner-island",
|
"Inside a group you have three types of Channels: Chat, Collection, or Notebook. Mix and match these depending on your group context!",
|
||||||
|
url: `/~landscape/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}`,
|
||||||
alignY: "top",
|
alignY: "top",
|
||||||
alignX: "right",
|
alignX: "right",
|
||||||
offsetX: MODAL_WIDTH + 8,
|
offsetX: MODAL_WIDTH + 8,
|
||||||
@ -64,8 +72,9 @@ export const progressDetails: Record<TutorialProgress, StepDetail> = {
|
|||||||
},
|
},
|
||||||
chat: {
|
chat: {
|
||||||
title: "Chat",
|
title: "Chat",
|
||||||
description: "Chat channels are for messaging within your group. Direct Messages are also supported, and are accessible from the “DMs” tile on the homescreen",
|
description:
|
||||||
url: "/~landscape/ship/~hastuc-dibtux/beginner-island/resource/chat/ship/~hastuc-dibtux/chat-8401",
|
"Chat channels are for messaging within your group. Direct Messages are also supported, and are accessible from the “DMs” tile on the homescreen",
|
||||||
|
url: `/~landscape/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}/resource/chat/ship/${TUTORIAL_HOST}/${TUTORIAL_CHAT}`,
|
||||||
alignY: "top",
|
alignY: "top",
|
||||||
alignX: "right",
|
alignX: "right",
|
||||||
offsetX: 0,
|
offsetX: 0,
|
||||||
@ -73,8 +82,9 @@ export const progressDetails: Record<TutorialProgress, StepDetail> = {
|
|||||||
},
|
},
|
||||||
link: {
|
link: {
|
||||||
title: "Collection",
|
title: "Collection",
|
||||||
description: "A collection is where you can share and view links, images, and other media within your group. Every item in a Collection can have it’s own comment thread.",
|
description:
|
||||||
url: "/~landscape/ship/~hastuc-dibtux/beginner-island/resource/link/ship/~hastuc-dibtux/link-4353",
|
"A collection is where you can share and view links, images, and other media within your group. Every item in a Collection can have it’s own comment thread.",
|
||||||
|
url: `/~landscape/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}/resource/link/ship/${TUTORIAL_HOST}/${TUTORIAL_LINKS}`,
|
||||||
alignY: "top",
|
alignY: "top",
|
||||||
alignX: "right",
|
alignX: "right",
|
||||||
offsetX: 0,
|
offsetX: 0,
|
||||||
@ -82,8 +92,9 @@ export const progressDetails: Record<TutorialProgress, StepDetail> = {
|
|||||||
},
|
},
|
||||||
publish: {
|
publish: {
|
||||||
title: "Notebook",
|
title: "Notebook",
|
||||||
description: "Notebooks are for creating long-form content within your group. Use markdown to create rich posts with headers, lists and images.",
|
description:
|
||||||
url: "/~landscape/ship/~hastuc-dibtux/beginner-island/resource/publish/ship/~hastuc-dibtux/notebook-9148",
|
"Notebooks are for creating long-form content within your group. Use markdown to create rich posts with headers, lists and images.",
|
||||||
|
url: `/~landscape/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}/resource/publish/ship/${TUTORIAL_HOST}/${TUTORIAL_BOOK}`,
|
||||||
alignY: "top",
|
alignY: "top",
|
||||||
alignX: "right",
|
alignX: "right",
|
||||||
offsetX: 0,
|
offsetX: 0,
|
||||||
@ -91,8 +102,9 @@ export const progressDetails: Record<TutorialProgress, StepDetail> = {
|
|||||||
},
|
},
|
||||||
notifications: {
|
notifications: {
|
||||||
title: "Notifications",
|
title: "Notifications",
|
||||||
description: "Subscribing to a channel will send you notifications when there are new updates. You will also receive a notification when someone mentions your name in a channel.",
|
description:
|
||||||
url: "/~landscape/ship/~hastuc-dibtux/beginner-island/resource/publish/ship/~hastuc-dibtux/notebook-9148/settings#notifications",
|
"Subscribing to a channel will send you notifications when there are new updates. You will also receive a notification when someone mentions your name in a channel.",
|
||||||
|
url: `/~landscape/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}/resource/publish/ship/${TUTORIAL_HOST}/${TUTORIAL_BOOK}/settings#notifications`,
|
||||||
alignY: "top",
|
alignY: "top",
|
||||||
alignX: "right",
|
alignX: "right",
|
||||||
offsetX: 0,
|
offsetX: 0,
|
||||||
@ -100,21 +112,22 @@ export const progressDetails: Record<TutorialProgress, StepDetail> = {
|
|||||||
},
|
},
|
||||||
profile: {
|
profile: {
|
||||||
title: "Profile",
|
title: "Profile",
|
||||||
description: "Your profile is customizable and can be shared with other ships. Enter as much or as little information as you’d like.",
|
description:
|
||||||
|
"Your profile is customizable and can be shared with other ships. Enter as much or as little information as you’d like.",
|
||||||
url: `/~profile/~${window.ship}`,
|
url: `/~profile/~${window.ship}`,
|
||||||
alignY: "top",
|
alignY: "top",
|
||||||
alignX: "right",
|
alignX: "right",
|
||||||
offsetX: -300 + (MODAL_WIDTH / 2),
|
offsetX: -300 + MODAL_WIDTH / 2,
|
||||||
offsetY: -120 + (MODAL_HEIGHT / 2),
|
offsetY: -120 + MODAL_HEIGHT / 2,
|
||||||
},
|
},
|
||||||
leap: {
|
leap: {
|
||||||
title: "Leap",
|
title: "Leap",
|
||||||
description: "Leap allows you to go to a specific channel, message, collection, profile or group simply by typing in a command or selecting a shortcut from the dropdown menu.",
|
description:
|
||||||
|
"Leap allows you to go to a specific channel, message, collection, profile or group simply by typing in a command or selecting a shortcut from the dropdown menu.",
|
||||||
url: `/~profile/~${window.ship}`,
|
url: `/~profile/~${window.ship}`,
|
||||||
alignY: "top",
|
alignY: "top",
|
||||||
alignX: "left",
|
alignX: "left",
|
||||||
offsetX: 0,
|
offsetX: 0,
|
||||||
offsetY: -32,
|
offsetY: -32,
|
||||||
}
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -20,6 +20,11 @@ import { JoinGroup } from "~/views/landscape/components/JoinGroup";
|
|||||||
import { Helmet } from 'react-helmet';
|
import { Helmet } from 'react-helmet';
|
||||||
import useLocalState from "~/logic/state/local";
|
import useLocalState from "~/logic/state/local";
|
||||||
import { useWaitForProps } from '~/logic/lib/useWaitForProps';
|
import { useWaitForProps } from '~/logic/lib/useWaitForProps';
|
||||||
|
import {
|
||||||
|
hasTutorialGroup,
|
||||||
|
TUTORIAL_GROUP,
|
||||||
|
TUTORIAL_HOST
|
||||||
|
} from '~/logic/lib/tutorialModal';
|
||||||
|
|
||||||
const ScrollbarLessBox = styled(Box)`
|
const ScrollbarLessBox = styled(Box)`
|
||||||
scrollbar-width: none !important;
|
scrollbar-width: none !important;
|
||||||
@ -75,7 +80,7 @@ export default function LaunchApp(props) {
|
|||||||
const onContinue = async (e) => {
|
const onContinue = async (e) => {
|
||||||
e.stopPropagation();
|
e.stopPropagation();
|
||||||
if(!hasTutorialGroup(props)) {
|
if(!hasTutorialGroup(props)) {
|
||||||
await props.api.groups.join('~hastuc-dibtux', 'beginner-island');
|
await props.api.groups.join(TUTORIAL_HOST, TUTORIAL_GROUP);
|
||||||
await waiter(hasTutorialGroup);
|
await waiter(hasTutorialGroup);
|
||||||
}
|
}
|
||||||
nextTutStep();
|
nextTutStep();
|
||||||
|
@ -8,6 +8,7 @@ import { alphabeticalOrder } from "~/logic/lib/util";
|
|||||||
import { getUnreadCount, getNotificationCount } from "~/logic/lib/hark";
|
import { getUnreadCount, getNotificationCount } from "~/logic/lib/hark";
|
||||||
import Tile from "../components/tiles/tile";
|
import Tile from "../components/tiles/tile";
|
||||||
import { useTutorialModal } from "~/views/components/useTutorialModal";
|
import { useTutorialModal } from "~/views/components/useTutorialModal";
|
||||||
|
import {TUTORIAL_HOST, TUTORIAL_GROUP} from "~/logic/lib/tutorialModal";
|
||||||
|
|
||||||
interface GroupsProps {
|
interface GroupsProps {
|
||||||
associations: Associations;
|
associations: Associations;
|
||||||
@ -75,7 +76,7 @@ interface GroupProps {
|
|||||||
function Group(props: GroupProps) {
|
function Group(props: GroupProps) {
|
||||||
const { path, title, unreads, updates, first = false } = props;
|
const { path, title, unreads, updates, first = false } = props;
|
||||||
const anchorRef = useRef<HTMLElement>(null);
|
const anchorRef = useRef<HTMLElement>(null);
|
||||||
const isTutorialGroup = path === '/ship/~hastuc-dibtux/beginner-island';
|
const isTutorialGroup = path === `/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}`;
|
||||||
useTutorialModal(
|
useTutorialModal(
|
||||||
'start',
|
'start',
|
||||||
isTutorialGroup,
|
isTutorialGroup,
|
||||||
|
@ -3,6 +3,7 @@ import { Metadata } from "~/types";
|
|||||||
import { Col, Row, Text } from "@tlon/indigo-react";
|
import { Col, Row, Text } from "@tlon/indigo-react";
|
||||||
import { MetadataIcon } from "./MetadataIcon";
|
import { MetadataIcon } from "./MetadataIcon";
|
||||||
import { useTutorialModal } from "~/views/components/useTutorialModal";
|
import { useTutorialModal } from "~/views/components/useTutorialModal";
|
||||||
|
import {TUTORIAL_HOST, TUTORIAL_GROUP} from "~/logic/lib/tutorialModal";
|
||||||
|
|
||||||
interface GroupSummaryProps {
|
interface GroupSummaryProps {
|
||||||
metadata: Metadata;
|
metadata: Metadata;
|
||||||
@ -17,7 +18,7 @@ export function GroupSummary(props: GroupSummaryProps) {
|
|||||||
const anchorRef = useRef<HTMLElement | null>(null);
|
const anchorRef = useRef<HTMLElement | null>(null);
|
||||||
useTutorialModal(
|
useTutorialModal(
|
||||||
"group-desc",
|
"group-desc",
|
||||||
resource === "/ship/~hastuc-dibtux/beginner-island",
|
resource === `/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}`,
|
||||||
anchorRef.current
|
anchorRef.current
|
||||||
);
|
);
|
||||||
return (
|
return (
|
||||||
|
@ -10,6 +10,7 @@ import { Sigil } from '~/logic/lib/sigil';
|
|||||||
import urbitOb from 'urbit-ob';
|
import urbitOb from 'urbit-ob';
|
||||||
import { getModuleIcon, getItemTitle, uxToHex } from "~/logic/lib/util";
|
import { getModuleIcon, getItemTitle, uxToHex } from "~/logic/lib/util";
|
||||||
import {useTutorialModal} from "~/views/components/useTutorialModal";
|
import {useTutorialModal} from "~/views/components/useTutorialModal";
|
||||||
|
import {TUTORIAL_HOST, TUTORIAL_GROUP} from "~/logic/lib/tutorialModal";
|
||||||
|
|
||||||
function SidebarItemIndicator(props: { status?: SidebarItemStatus }) {
|
function SidebarItemIndicator(props: { status?: SidebarItemStatus }) {
|
||||||
switch (props.status) {
|
switch (props.status) {
|
||||||
@ -45,7 +46,7 @@ export function SidebarItem(props: {
|
|||||||
const anchorRef = useRef<HTMLElement | null>(null)
|
const anchorRef = useRef<HTMLElement | null>(null)
|
||||||
useTutorialModal(
|
useTutorialModal(
|
||||||
mod as any,
|
mod as any,
|
||||||
groupPath === '/ship/~hastuc-dibtux/beginner-island',
|
groupPath === `/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}`,
|
||||||
anchorRef.current
|
anchorRef.current
|
||||||
);
|
);
|
||||||
const app = apps[appName];
|
const app = apps[appName];
|
||||||
|
@ -11,6 +11,8 @@ import {
|
|||||||
MODAL_WIDTH_PX,
|
MODAL_WIDTH_PX,
|
||||||
MODAL_WIDTH,
|
MODAL_WIDTH,
|
||||||
MODAL_HEIGHT,
|
MODAL_HEIGHT,
|
||||||
|
TUTORIAL_HOST,
|
||||||
|
TUTORIAL_GROUP,
|
||||||
} from "~/logic/lib/tutorialModal";
|
} from "~/logic/lib/tutorialModal";
|
||||||
import { getRelativePosition } from "~/logic/lib/relativePosition";
|
import { getRelativePosition } from "~/logic/lib/relativePosition";
|
||||||
import { StatelessAsyncButton } from "~/views/components/StatelessAsyncButton";
|
import { StatelessAsyncButton } from "~/views/components/StatelessAsyncButton";
|
||||||
@ -80,7 +82,7 @@ export function TutorialModal(props: { api: GlobalApi }) {
|
|||||||
}, [hideTutorial, props.api]);
|
}, [hideTutorial, props.api]);
|
||||||
|
|
||||||
const leaveGroup = useCallback(async () => {
|
const leaveGroup = useCallback(async () => {
|
||||||
await props.api.groups.leaveGroup("~hastuc-dibtux", "beginner-island");
|
await props.api.groups.leaveGroup(TUTORIAL_HOST, TUTORIAL_GROUP);
|
||||||
}, [props.api]);
|
}, [props.api]);
|
||||||
|
|
||||||
const progressIdx = progress.findIndex((p) => p === tutorialProgress);
|
const progressIdx = progress.findIndex((p) => p === tutorialProgress);
|
||||||
|
Loading…
Reference in New Issue
Block a user