-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
67 changed files
with
1,837 additions
and
1,285 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
# Shirt Shop Flags SDK Example | ||
|
||
This example uses the [Flags SDK](https://flags-sdk.dev) along with the [Flags Explorer](https://vercel.com/docs/workflow-collaboration/feature-flags/using-vercel-toolbar) and `@vercel/analytics`. | ||
|
||
## Demo | ||
|
||
[https://shirt-shop.labs.vercel.dev/](https://shirt-shop.labs.vercel.dev/) | ||
|
||
## How it works | ||
|
||
This demo uses two feature flags defined in code control the visibility of two banners on the page. | ||
Both flags are configured to show/hide each banner 50% of the time. | ||
|
||
Once you visit the page, you can see a variation of both/one/none of the banners. | ||
Since this example is using a stable id to identify users, you will see the same variation all the time. | ||
|
||
To test different variations, you can use the Dev Tools at the bottom to reset the stable id and reload the page. | ||
This allows you to test different variations of the banners. | ||
|
||
This templates also tracks analytics events in Vercel Analytics. | ||
|
||
If you deployed your own instance of this example you can also use the [Flags Explorer](https://vercel.com/docs/workflow-collaboration/feature-flags/using-vercel-toolbar) to test different variations by creating overrides. | ||
|
||
## Deploy this template | ||
|
||
[data:image/s3,"s3://crabby-images/c5542/c55422930910a32cc5fd25f6bee6cdc3ec8e835f" alt="Deploy with Vercel"](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2Fvercel%2Fflags%2Ftree%2Fmain%2Fexamples%2Fshirt-shop&env=FLAGS_SECRET&envDescription=The+FLAGS_SECRET+will+be+used+by+the+Flags+Explorer+to+securely+overwrite+feature+flags.+Must+be+32+random+bytes%2C+base64-encoded.+Use+the+generated+value+or+set+your+own.&envLink=https%3A%2F%2Fvercel.com%2Fdocs%2Fworkflow-collaboration%2Ffeature-flags%2Fsupporting-feature-flags%23flags_secret-environment-variable&project-name=shirt-shop-flags-sdk-example&repository-name=shirt-shop-flags-sdk-example) | ||
|
||
### Step 1: Link the project | ||
|
||
In order to use the Flags Explorer, you need to link the project on your local machine. | ||
|
||
```bash | ||
vercel link | ||
``` | ||
|
||
Select the project from the list you just deployed. | ||
|
||
### Step 2: Pull all environment variables | ||
|
||
This allows the Flags SDK and the Flags Explorer to work correctly, by getting additional metadata. | ||
|
||
```bash | ||
vercel env pull | ||
``` | ||
|
||
### Step 2: Install dependencies | ||
|
||
```bash | ||
npm install | ||
``` | ||
|
||
### Step 3: Run the project | ||
|
||
```bash | ||
npm run dev | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
import { AddToCartButton } from '@/components/add-to-cart-button'; | ||
import { FreeDeliveryBanner } from '@/components/banners/free-delivery-banner'; | ||
import { SummerBanner } from '@/components/banners/summer-banner'; | ||
import { ColorPicker } from '@/components/color-picker'; | ||
import { DevTools } from '@/components/dev-tools'; | ||
import { Footer } from '@/components/footer'; | ||
import { ImageGallery } from '@/components/image-gallery'; | ||
import { Navigation } from '@/components/navigation'; | ||
import { ProductDetails } from '@/components/product-details'; | ||
import { ProductHeader } from '@/components/product-header'; | ||
import { SizePicker } from '@/components/size-picker'; | ||
import { | ||
productFlags, | ||
showFreeDeliveryBannerFlag, | ||
showSummerBannerFlag, | ||
} from '@/flags'; | ||
import { getPrecomputed } from 'flags/next'; | ||
|
||
export default async function Page(props: { | ||
params: Promise<{ code: string }>; | ||
}) { | ||
const params = await props.params; | ||
|
||
const [showSummerBanner, showFreeDeliveryBanner] = await getPrecomputed( | ||
[showSummerBannerFlag, showFreeDeliveryBannerFlag], | ||
productFlags, | ||
params.code, | ||
); | ||
|
||
return ( | ||
<div className="bg-white"> | ||
<FreeDeliveryBanner show={showFreeDeliveryBanner} /> | ||
<Navigation /> | ||
<SummerBanner show={showSummerBanner} /> | ||
|
||
<main className="mx-auto max-w-2xl px-4 pb-16 sm:px-6 sm:pb-24 lg:max-w-7xl lg:px-8"> | ||
<div className="lg:grid lg:auto-rows-min lg:grid-cols-12 lg:gap-x-8"> | ||
<ProductHeader /> | ||
<ImageGallery /> | ||
|
||
<div className="mt-8 lg:col-span-5"> | ||
<ColorPicker /> | ||
<SizePicker /> | ||
<AddToCartButton /> | ||
<ProductDetails /> | ||
</div> | ||
</div> | ||
</main> | ||
|
||
<Footer /> | ||
<DevTools /> | ||
</div> | ||
); | ||
} |
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
@import 'tailwindcss'; |
7 changes: 2 additions & 5 deletions
7
examples/summer-sale/app/layout.tsx → examples/shirt-shop/app/layout.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
'use client'; | ||
|
||
import { track } from '@vercel/analytics'; | ||
import { useEffect } from 'react'; | ||
|
||
export function AddToCartButton() { | ||
useEffect(() => { | ||
track('add_to_cart:viewed'); | ||
}, []); | ||
|
||
return ( | ||
<button | ||
type="button" | ||
className="mt-8 flex w-full items-center justify-center rounded-full border border-transparent bg-blue-600 px-8 py-3 text-base font-medium text-white hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-offset-2" | ||
onClick={() => track('add_to_cart:clicked')} | ||
> | ||
Add to cart | ||
</button> | ||
); | ||
} |
18 changes: 18 additions & 0 deletions
18
examples/shirt-shop/components/banners/free-delivery-banner.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
'use client'; | ||
|
||
import { track } from '@vercel/analytics'; | ||
import { useEffect } from 'react'; | ||
|
||
export function FreeDeliveryBanner(props: { show: boolean }) { | ||
useEffect(() => { | ||
if (props.show) track('free_delivery_banner:viewed'); | ||
}, [props.show]); | ||
|
||
if (!props.show) return null; | ||
|
||
return ( | ||
<div className="px-4 py-2 bg-gray-950 text-white text-center text text-sm font-medium"> | ||
Get free delivery on orders over $100 | ||
</div> | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
'use client'; | ||
|
||
import { Radio, RadioGroup } from '@headlessui/react'; | ||
import clsx from 'clsx'; | ||
import { useState } from 'react'; | ||
|
||
const colors = [ | ||
{ name: 'Black', bgColor: 'bg-gray-900', selectedColor: 'ring-gray-900' }, | ||
{ name: 'White', bgColor: 'bg-white', selectedColor: 'ring-gray-300' }, | ||
{ name: 'Blue', bgColor: 'bg-blue-500', selectedColor: 'ring-blue-500' }, | ||
]; | ||
|
||
export function ColorPicker() { | ||
const [selectedColor, setSelectedColor] = useState(colors[0]); | ||
|
||
return ( | ||
<div> | ||
<h2 className="text-sm font-medium text-gray-900">Color</h2> | ||
<fieldset aria-label="Choose a color" className="mt-2"> | ||
<RadioGroup | ||
value={selectedColor} | ||
onChange={setSelectedColor} | ||
className="flex items-center gap-x-3" | ||
> | ||
{colors.map((color) => ( | ||
<Radio | ||
key={color.name} | ||
value={color} | ||
aria-label={color.name} | ||
className={clsx( | ||
color.selectedColor, | ||
'relative -m-0.5 flex cursor-pointer items-center justify-center rounded-full p-0.5 focus:outline-hidden data-checked:ring-2 data-focus:data-checked:ring-3 data-focus:data-checked:ring-offset-1', | ||
)} | ||
> | ||
<span | ||
aria-hidden="true" | ||
className={clsx( | ||
color.bgColor, | ||
'size-8 rounded-full border border-black/10', | ||
)} | ||
/> | ||
</Radio> | ||
))} | ||
</RadioGroup> | ||
</fieldset> | ||
</div> | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
'use client'; | ||
|
||
import { ArrowPathIcon } from '@heroicons/react/24/outline'; | ||
import { useRouter } from 'next/navigation'; | ||
|
||
export function DevTools() { | ||
const router = useRouter(); | ||
|
||
const deleteCookie = () => { | ||
document.cookie = | ||
'stable-id=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;'; | ||
router.refresh(); | ||
}; | ||
|
||
return ( | ||
<div className="fixed bottom-2 right-2 p-3 bg-[#333333] rounded shadow-lg z-50 flex flex-col gap-2"> | ||
<span className="text-white font-mono text-xs">Dev Tools</span> | ||
<button | ||
type="button" | ||
className="bg-white text-black font-mono text-xs rounded px-2 py-1 flex items-center gap-2 cursor-pointer hover:bg-gray-200 transition-colors active:bg-gray-300" | ||
onClick={deleteCookie} | ||
> | ||
<ArrowPathIcon className="w-4 h-4" /> | ||
Reset Stable ID | ||
</button> | ||
</div> | ||
); | ||
} |
Oops, something went wrong.