diff --git a/.gitignore b/.gitignore
index b1ec694..441d052 100644
--- a/.gitignore
+++ b/.gitignore
@@ -6,7 +6,7 @@ dist/
.env
abc.ts
.vitepress/cache
-docs/.vitepress/cache/
+docs/.vitepress/cache/*
coverage/
todo.md
trickyoperation.ts
\ No newline at end of file
diff --git a/docs/.vitepress/cache/deps/_metadata.json b/docs/.vitepress/cache/deps/_metadata.json
index cc3c5bc..3241c7b 100644
--- a/docs/.vitepress/cache/deps/_metadata.json
+++ b/docs/.vitepress/cache/deps/_metadata.json
@@ -5,55 +5,55 @@
"vue": {
"src": "../../../../node_modules/vue/dist/vue.runtime.esm-bundler.js",
"file": "vue.js",
- "fileHash": "5b5f91d7",
+ "fileHash": "ed6cb684",
"needsInterop": false
},
"vitepress > @vue/devtools-api": {
"src": "../../../../node_modules/@vue/devtools-api/lib/esm/index.js",
"file": "vitepress___@vue_devtools-api.js",
- "fileHash": "2937291a",
+ "fileHash": "61356a80",
"needsInterop": false
},
"adaptivecards": {
"src": "../../../../node_modules/adaptivecards/lib/adaptivecards.js",
"file": "adaptivecards.js",
- "fileHash": "3b8a82eb",
+ "fileHash": "9014f111",
"needsInterop": true
},
"element-plus": {
"src": "../../../../node_modules/element-plus/es/index.mjs",
"file": "element-plus.js",
- "fileHash": "1764f8d9",
+ "fileHash": "dfe8a7e2",
"needsInterop": false
},
"vitepress > @vueuse/integrations/useFocusTrap": {
"src": "../../../../node_modules/@vueuse/integrations/useFocusTrap.mjs",
"file": "vitepress___@vueuse_integrations_useFocusTrap.js",
- "fileHash": "38ac76f9",
+ "fileHash": "73569296",
"needsInterop": false
},
"vitepress > mark.js/src/vanilla.js": {
"src": "../../../../node_modules/mark.js/src/vanilla.js",
"file": "vitepress___mark__js_src_vanilla__js.js",
- "fileHash": "6b6e2012",
+ "fileHash": "7e415ee5",
"needsInterop": false
},
"vitepress > minisearch": {
"src": "../../../../node_modules/minisearch/dist/es/index.js",
"file": "vitepress___minisearch.js",
- "fileHash": "e9985c6c",
+ "fileHash": "99b9ce67",
"needsInterop": false
},
"@element-plus/icons-vue": {
"src": "../../../../node_modules/@element-plus/icons-vue/dist/index.js",
"file": "@element-plus_icons-vue.js",
- "fileHash": "f612aa88",
+ "fileHash": "c01f7292",
"needsInterop": false
},
"monaco-editor": {
"src": "../../../../node_modules/monaco-editor/esm/vs/editor/editor.main.js",
"file": "monaco-editor.js",
- "fileHash": "20679472",
+ "fileHash": "1de3c3af",
"needsInterop": false
}
},
diff --git a/docs/.vitepress/config.mts b/docs/.vitepress/config.mts
index b6a5042..207c3c4 100644
--- a/docs/.vitepress/config.mts
+++ b/docs/.vitepress/config.mts
@@ -113,6 +113,10 @@ export default defineConfig({
text: `💻 Secure Webhooks with a "secret"`,
link: "webhooks.html#securing-webhooks",
},
+ {
+ text: "✉️ Send a SpeedyCard",
+ link: "/send-a-card",
+ },
{
text: "📚 API Docs",
link: "/../api-docs/modules",
diff --git a/docs/.vitepress/util/samples.ts b/docs/.vitepress/util/samples.ts
index 3fba4df..809df50 100644
--- a/docs/.vitepress/util/samples.ts
+++ b/docs/.vitepress/util/samples.ts
@@ -204,11 +204,11 @@ const card = Bot.card()
name: "yellow-warning",
value: `const Bot = new SpeedyBot();
const card = Bot.card()
-.addTitle("⚠️ You're about to do it! ⚠️")
-.addText("Whatever you're about to do, give it a think")
-.setBackgroundImage(
- ''
-)`,
+ .addTitle("⚠️ You're about to do it! ⚠️")
+ .addText("Whatever you're about to do, give it a think")
+ .setBackgroundImage(
+ ''
+ )`,
},
{
label: "Green Success ✅",
diff --git a/docs/new.md b/docs/new.md
index 1cacbd6..35afa90 100644
--- a/docs/new.md
+++ b/docs/new.md
@@ -58,7 +58,7 @@ SpeedyBot does **NOT** log/persist or do anything (except what you tell it to do
## Step II: Send a Test Message with Your Access Token
-- Let's test out your bot access token by sending a **[SpeedyCard](#im-new-here-🐣)** to you as a direct message (tap the 🎲 to shuffle through some examples as inspiration or write your own)
+- Let's test out your bot access token by sending a **[SpeedyCard](./speedycard.md)** to you as a direct message (tap the 🎲 to shuffle through some examples as inspiration or write your own)
@@ -99,7 +99,7 @@ Copy the commands below to get up and running
::: code-group
```sh-vue [🥺 New (recommended)]
-npm init speedybot setup {{ store.state.tokenValid ? `--token ${store.state.token} ` : '' }}--project default
+npx speedybot setup {{ store.state.tokenValid ? `--token ${store.state.token} ` : '' }}--project default
```
```sh-vue [👹 Experienced]
@@ -114,13 +114,15 @@ npm run bot:setup {{ store.state.tokenValid ? store.state.token : '__ACCESS__TOK
::: details Getting errors?
-If you see an error like `npm: command not found` you probably need to install node or compatible runtime (like **[bun](https://bun.sh)** or **[deno](https://deno.com)**) onto your system.
+If you see an error like `npm: command not found` you probably need to install node or a compatible runtime onto your system.
There are many ways to do this, but two easy ways:
-Option 1. Download + install Node from the official site: **[https://nodejs.org/en/download](https://nodejs.org/en/download)**
+**Option 1** Download + install Node from the official site: **[https://nodejs.org/en/download](https://nodejs.org/en/download)**
-Option 2. Download with **[Volta](https://docs.volta.sh/guide/)** in the terminal
+or
+
+**Option 2** Download with **[Volta](https://docs.volta.sh/guide/)** in the terminal
```sh
curl https://get.volta.sh | bash
@@ -128,7 +130,19 @@ curl https://get.volta.sh | bash
volta install node
```
-However you set up your system, make sure to run `node -v` in your terminal to verify node is correctly installed and you can take advantage of its rich ecoysten
+However you set up your system, make sure to run `node -v` in your terminal to verify node is correctly installed and you can get up and running with `npx speedybot setup --project default`:
+
+
:::
@@ -150,7 +164,7 @@ You can now customize this bot however you want by editing the file **[settings/
-You can turn off your bot by press **CTRL-C**
+You can turn off your bot by holding down **CTRL-C** on your keyboard or exiting the terminal
Whether you're just starting out on your conversation design journey or a seasoned pro, SpeedyBot has you covered for crafting bots that can do it all-- securely integrate w/ LLMs + content management systems, **[process file-uploads](./patterns.md#handle-file-uploads)**, **[segment content based on user data + behavior](./patterns.md#restrict-access-pattern)**, create + manage **[SpeedyCards](./speedycard.md)**, ask for a user's location in a privacy-respecting way, and much more.
diff --git a/docs/send-a-card.md b/docs/send-a-card.md
new file mode 100644
index 0000000..9cf0b09
--- /dev/null
+++ b/docs/send-a-card.md
@@ -0,0 +1,172 @@
+---
+# layout: home
+outline: deep
+---
+
+# 🌟 Send a SpeedyCard
+
+SpeedyCards make it speedy and easy for your WebEx bots to send beautifully formatted **[Adaptive Cards](https://developer.webex.com/docs/buttons-and-cards)** without having to wrangle with JSON
+
+But did you know that there's a nifty way to send a SpeedyCard using your own account instead of your bot's? It's easy-as-pie 🥧 and you can do it right from this page
+
+
+
+## Step I: Grab Your Personal Access Token
+
+Login and copy your personal access token here: **[https://developer.webex.com/docs/getting-your-personal-access-token](https://developer.webex.com/docs/getting-your-personal-access-token)**
+
+Heads up-- unlike a **[bot token](https://developer.webex.com/my-apps/new/bot)**, a personal access token will automatically self-destruct after 12 hours
+
+## Step II: Validate Your Token
+
+Once you've got your token, pop it into the box below to validate it & review your bot's details
+
+
+
+## Step III: Send a SpeedyCard! 🚀
+
+
+
+
+
+{{ showJSON ? 'Hide JSON Output' : 'Show JSON Output' }}
+
+The box above is "live" & has typing hints so you can dive in and get started writing SpeedyCards. If you need some inspiration, press the dice 🎲 button button to cycle through some sample SpeedyCards. You can send the card to a specific person or a room
+
+
+
+
+
+
+```json-vue
+{{ typeof jsonData === 'object' ? JSON.stringify(jsonData, null, 2) : jsonData }}
+```
+
+
+
+
+
+
+
+
+
+
+
+
+## (optional) Step IV: Make a Bot to Collect Data from your Cards
+
+
+
+- You may have noticed that if you tried to submit any data back from a card-- nothing happens
+
+- In fact, any user interaction with a card sent from {{ store.state.userData?.emails[0] ?? 'your account'}} right now results in icy radio silence, the data doesn't "go" anywhere
+
+- If you want to collect the data from a SpeedyCard, you'll need a SpeedyBot for that. You can set one up in about 20 seconds (really) by clicking here
+
+
+
+
+
+
diff --git a/docs/speedycard.md b/docs/speedycard.md
index d8bbb09..5d3e734 100644
--- a/docs/speedycard.md
+++ b/docs/speedycard.md
@@ -103,7 +103,6 @@ const initParent = (editor) => {
}
pageReady.value = true
- console.log("##pageReady.value", pageReady.value)
}
const handleSelected = (codeSnippet) => {
if (editorRef) {
diff --git a/test/middleware.test.ts b/test/middleware.test.ts
index 0acdb84..ee76e72 100644
--- a/test/middleware.test.ts
+++ b/test/middleware.test.ts
@@ -10,7 +10,6 @@ describe("Various Messages", () => {
// text passes through
inst.addStep(async ($) => {
- console.log("beer");
expect($.text).toBe("beer");
return $.next;
});