* Comment model * Framework, model, policy, presenter, api endpoint etc * Iteration, first pass of UI * fixes, refactors * Comment commands * comment socket support * typing indicators * comment component, styling * wip * right sidebar resize * fix: CMD+Enter submit * Add usePersistedState fix: Main page scrolling on comment highlight * drafts * Typing indicator * refactor * policies * Click thread to highlight Improve comment timestamps * padding * Comment menu v1 * Change comments to use editor * Basic comment editing * fix: Hide commenting button when disabled at team level * Enable opening sidebar without mark * Move selected comment to location state * Add comment delete confirmation * Add comment count to document meta * fix: Comment sidebar togglable Add copy link to comment * stash * Restore History changes * Refactor right sidebar to allow for comment animation * Update to new router best practices * stash * Various improvements * stash * Handle click outside * Fix incorrect placeholder in input fix: Input box appearing on other sessions erroneously * stash * fix: Don't leave orphaned child comments * styling * stash * Enable comment toggling again * Edit styling, merge conflicts * fix: Cannot navigate from insights to comments * Remove draft comment mark on click outside * Fix: Empty comment sidebar, tsc * Remove public toggle * fix: All comments are recessed fix: Comments should not be printed * fix: Associated mark should be removed on comment delete * Revert unused changes * Empty state, basic RTL support * Create dont toggle comment mark * Make it feel more snappy * Highlight active comment in text * fix animation * RTL support * Add reply CTA * Translations
58 lines
2.2 KiB
TypeScript
58 lines
2.2 KiB
TypeScript
import { z } from "zod";
|
|
import { UserRole } from "@server/models/User";
|
|
import BaseSchema from "@server/routes/api/BaseSchema";
|
|
|
|
export const TeamsUpdateSchema = BaseSchema.extend({
|
|
body: z.object({
|
|
/** Team name */
|
|
name: z.string().optional(),
|
|
/** Avatar URL */
|
|
avatarUrl: z.string().optional(),
|
|
/** The subdomain to access the team */
|
|
subdomain: z.string().optional(),
|
|
/** Whether public sharing is enabled */
|
|
sharing: z.boolean().optional(),
|
|
/** Whether siginin with email is enabled */
|
|
guestSignin: z.boolean().optional(),
|
|
/** Whether third-party document embeds are enabled */
|
|
documentEmbeds: z.boolean().optional(),
|
|
/** Whether team members are able to create new collections */
|
|
memberCollectionCreate: z.boolean().optional(),
|
|
/** Whether collaborative editing is enabled */
|
|
collaborativeEditing: z.boolean().optional(),
|
|
/** The default landing collection for the team */
|
|
defaultCollectionId: z.string().uuid().nullish(),
|
|
/** The default user role */
|
|
defaultUserRole: z
|
|
.string()
|
|
.refine((val) => Object.values(UserRole).includes(val as UserRole))
|
|
.optional(),
|
|
/** Whether new users must be invited to join the team */
|
|
inviteRequired: z.boolean().optional(),
|
|
/** Domains allowed to sign-in with SSO */
|
|
allowedDomains: z.array(z.string()).optional(),
|
|
/** Team preferences */
|
|
preferences: z
|
|
.object({
|
|
/** Whether documents have a separate edit mode instead of seamless editing. */
|
|
seamlessEdit: z.boolean().optional(),
|
|
/** Whether to use team logo across the app for branding. */
|
|
publicBranding: z.boolean().optional(),
|
|
/** Whether viewers should see download options. */
|
|
viewersCanExport: z.boolean().optional(),
|
|
/** Whether commenting is enabled */
|
|
commenting: z.boolean().optional(),
|
|
/** The custom theme for the team. */
|
|
customTheme: z
|
|
.object({
|
|
accent: z.string().min(4).max(7).regex(/^#/).optional(),
|
|
accentText: z.string().min(4).max(7).regex(/^#/).optional(),
|
|
})
|
|
.optional(),
|
|
})
|
|
.optional(),
|
|
}),
|
|
});
|
|
|
|
export type TeamsUpdateSchemaReq = z.infer<typeof TeamsUpdateSchema>;
|