Skip to content

Commit

Permalink
Merge branch 'dev-feimei-1627' of https://github.com/uhawaii-system-i…
Browse files Browse the repository at this point in the history
…ts-ti-iam/uh-groupings into dev-feimei-1627
  • Loading branch information
FeimeiChen committed Mar 29, 2024
2 parents d86366c + 4dfb8e9 commit b777b95
Show file tree
Hide file tree
Showing 17 changed files with 581 additions and 91 deletions.
2 changes: 1 addition & 1 deletion ui/.eslintrc.json
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@
"eslint-plugin-tsdoc"
],
"rules": {
"@stylistic/max-len": ["error", { "code": 120 }],
"@stylistic/max-len": ["warn", { "code": 120 }],
"@stylistic/indent": ["error", 4],
"@stylistic/eol-last": ["error", "always"],
"@stylistic/quotes": ["error", "single", { "allowTemplateLiterals": true }],
Expand Down
1 change: 1 addition & 0 deletions ui/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
"dependencies": {
"@radix-ui/react-dialog": "^1.0.5",
"@radix-ui/react-slot": "^1.0.2",
"@radix-ui/react-tabs": "^1.0.4",
"camaro": "^6.2.2",
"class-variance-authority": "^0.7.0",
"clsx": "^2.1.0",
Expand Down
58 changes: 58 additions & 0 deletions ui/src/app/admin/page.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
import { Tabs, TabsList, TabsTrigger, TabsContent } from '@/components/ui/tabs';

const Admin = () => {
return (
<main>
<div className="bg-seafoam pt-3">
<div className="container">
<h1 className="mb-1 font-bold text-[2rem] text-center md:text-left">UH Groupings Administration</h1>
<p className="pb-8 text-xl text-center md:text-left">
Search for and manage any grouping on behalf of its owner.
Manage the list of UH Groupings administrators.
</p>
</div>
<Tabs defaultValue="manage-groupings">
<div className="container">
<TabsList variant="outline">
<TabsTrigger
value="manage-groupings" variant="outline" >
Manage Groupings
</TabsTrigger>
<TabsTrigger
value="manage-admins" variant="outline" >
Manage Admins
</TabsTrigger>
<TabsTrigger
value="manage-person" variant="outline" >
Manage Person
</TabsTrigger>
</TabsList>
</div>
<TabsContent value="manage-groupings">
<div className="bg-white">
<div className="container">
{/* GroupingsTable goes here */}
</div>
</div>
</TabsContent>
<TabsContent value="manage-admins">
<div className="bg-white">
<div className="container">
{/* AdminTable goes here */}
</div>
</div>
</TabsContent>
<TabsContent value="manage-person">
<div className="bg-white">
<div className="container">
{/* PersonTable goes here */}
</div>
</div>
</TabsContent>
</Tabs>
</div>
</main>
);
}

export default Admin;
22 changes: 22 additions & 0 deletions ui/src/app/groupings/page.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
const Groupings = () => {
return (
<main>
<div className="bg-seafoam pt-3">
<div className="container">
<h1 className="mb-1 font-bold text-[2rem] text-center md:text-left">Manage My Groupings</h1>
<p className="pb-3 text-xl text-center md:text-left">
View and manage groupings I own. Manage members,
configure grouping options and sync destinations.
</p>
</div>
<div className="bg-white">
<div className="container">
{/* GroupingsTable goes here */}
</div>
</div>
</div>
</main>
);
}

export default Groupings;
46 changes: 46 additions & 0 deletions ui/src/app/memberships/page.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
import { Tabs, TabsContent, TabsList, TabsTrigger } from '@/components/ui/tabs';

const Memberships = () => {
return (
<main>
<div className="bg-seafoam pt-3">
<div className="container">
<h1 className="mb-1 font-bold text-[2rem] text-center md:text-left">Manage My Memberships</h1>
<p className="pb-8 text-xl text-center md:text-left">
View and manage my memberships. Search for new groupings to join as a member.
</p>
</div>
<Tabs defaultValue="current-memberships">
<div className="container">
<TabsList variant="outline">
<TabsTrigger
value="current-memberships" variant="outline">
Current Memberships
</TabsTrigger>
<TabsTrigger
value="membership-opportunities" variant="outline">
Membership Opportunities
</TabsTrigger>
</TabsList>
</div>
<TabsContent value="current-memberships">
<div className="bg-white">
<div className="container">
{/* MembershipsTable goes here */}
</div>
</div>
</TabsContent>
<TabsContent value="membership-opportunities">
<div className="bg-white">
<div className="container">
{/* MembershipsTable goes here */}
</div>
</div>
</TabsContent>
</Tabs>
</div>
</main>
);
}

export default Memberships;
2 changes: 1 addition & 1 deletion ui/src/components/layout/navbar/Navbar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ const Navbar = async () => {
const currentUser = await getCurrentUser();

return (
<nav className="border-b-[1px] pointer-events-auto">
<nav className="bg-white border-b-[1px] pointer-events-auto sticky top-0">
<div className="container py-2">
<div className="flex justify-between">
<Link href="/" className="lg:inline hidden">
Expand Down
8 changes: 4 additions & 4 deletions ui/src/components/ui/button.tsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import * as React from 'react'
import { Slot } from '@radix-ui/react-slot'
import { cva, type VariantProps } from 'class-variance-authority'
import * as React from 'react';
import { Slot } from '@radix-ui/react-slot';
import { cva, type VariantProps } from 'class-variance-authority';

import { cn } from '@/components/ui/utils'
import { cn } from '@/components/ui/utils';

const buttonVariants = cva(
`inline-flex items-center justify-center whitespace-nowrap rounded-[0.25rem] text-base font-normal ring-offset-white
Expand Down
12 changes: 6 additions & 6 deletions ui/src/components/ui/sheet.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
'use client'
'use client';

import * as React from 'react'
import * as SheetPrimitive from '@radix-ui/react-dialog'
import { cva, type VariantProps } from 'class-variance-authority'
import { X } from 'lucide-react'
import * as React from 'react';
import * as SheetPrimitive from '@radix-ui/react-dialog';
import { cva, type VariantProps } from 'class-variance-authority';
import { X } from 'lucide-react';

import { cn } from '@/components/ui/utils'
import { cn } from '@/components/ui/utils';

const Sheet = SheetPrimitive.Root;

Expand Down
93 changes: 93 additions & 0 deletions ui/src/components/ui/tabs.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
'use client';

import * as React from 'react';
import * as TabsPrimitive from '@radix-ui/react-tabs';
import { cva, type VariantProps } from 'class-variance-authority';
import { cn } from './utils';

const Tabs = TabsPrimitive.Root

const tabsListVariants = cva(
'inline-flex',
{
variants: {
variant: {
default: 'items-center justify-center h-10 rounded-md bg-muted p-1 text-muted-foreground',
outline: '',
},
},
defaultVariants: {
variant: 'default',
},
}
)
const tabsTriggerVariants = cva(
'inline-flex items-center justify-center',
{
variants: {
variant: {
default: `whitespace-nowrap rounded-sm px-3 py-1.5 text-sm font-medium ring-offset-background
transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring
focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50
data-[state=active]:bg-background data-[state=active]:text-foreground
data-[state=active]:shadow-sm`,
outline: `px-4 py-2 text-base font-medium ring-offset-background transition-all
data-[state=active]:bg-white data-[state=active]:rounded-t data-[state=active]:border-b-5
data-[state=active]:border-black data-[state=active]:text-foreground text-muted-foreground`,
},
},
defaultVariants: {
variant: 'default',
},
}
)
interface TabsListProps
extends React.ComponentPropsWithoutRef<typeof TabsPrimitive.List>,
VariantProps<typeof tabsListVariants> {}

const TabsList = React.forwardRef<
React.ElementRef<typeof TabsPrimitive.List>,
TabsListProps
>(({ className, variant, ...props }, ref) => (
<TabsPrimitive.List
ref={ref}
className={cn(tabsListVariants({ variant, className }))}
{...props}
/>
))
TabsList.displayName = TabsPrimitive.List.displayName

interface TabsTriggerProps
extends React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger>,
VariantProps<typeof tabsTriggerVariants> {}

const TabsTrigger = React.forwardRef<
React.ElementRef<typeof TabsPrimitive.Trigger>,
TabsTriggerProps
>(({ className, variant, ...props }, ref) => (
<TabsPrimitive.Trigger
ref={ref}
className={cn(tabsTriggerVariants({ variant, className }))}
{...props}
/>
))
TabsTrigger.displayName = TabsPrimitive.Trigger.displayName


const TabsContent = React.forwardRef<
React.ElementRef<typeof TabsPrimitive.Content>,
React.ComponentPropsWithoutRef<typeof TabsPrimitive.Content>
>(({ className, ...props }, ref) => (
<TabsPrimitive.Content
ref={ref}
className={cn(
`ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring
focus-visible:ring-offset-2`,
className
)}
{...props}
/>
))
TabsContent.displayName = TabsPrimitive.Content.displayName

export { Tabs, TabsList, TabsTrigger, TabsContent }
22 changes: 21 additions & 1 deletion ui/src/services/EmailService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,28 @@ export type EmailResult = {
text: string
}

/**
* Sends feedback to Groupings API to send email.
*
* @param feedback - the feedback
*
* @returns The EmailResult
*/
export const sendFeedback = async (feedback: Feedback): Promise<EmailResult & ApiError> => {
const currentUser = await getCurrentUser();
const endpoint = `${baseUrl}/email/send/feedback`;
return postRequest(endpoint, currentUser.uid, feedback);
return postRequest<EmailResult>(endpoint, currentUser.uid, feedback);
}

/**
* Sends feedback to Groupings API to send stack trace email.
*
* @param stackTrace - the stack trace
*
* @returns The EmailResult
*/
export const sendStackTrace = async (stackTrace: string): Promise<EmailResult & ApiError> => {
const currentUser = await getCurrentUser();
const endpoint = `${baseUrl}/email/send/stack-trace`;
return postRequest<EmailResult>(endpoint, currentUser.uid, stackTrace, 'text/plain');
}
Loading

0 comments on commit b777b95

Please sign in to comment.