Skip to content

Commit

Permalink
refr(enso-org/cloud-v2#1088): Make Project fields camelCase (#9653)
Browse files Browse the repository at this point in the history
  • Loading branch information
indiv0 authored Apr 11, 2024
1 parent 3ecc3ae commit f80e005
Show file tree
Hide file tree
Showing 8 changed files with 32 additions and 48 deletions.
14 changes: 6 additions & 8 deletions app/ide-desktop/lib/dashboard/e2e/api.ts
Original file line number Diff line number Diff line change
Expand Up @@ -111,8 +111,7 @@ export async function mockApi({ page }: MockParams) {
id: backend.ProjectId('project-' + uniqueString.uniqueString()),
projectState: {
type: backend.ProjectState.opened,
// eslint-disable-next-line @typescript-eslint/naming-convention
volume_id: '',
volumeId: '',
},
title,
modifiedAt: dateTime.toRfc3339(new Date()),
Expand Down Expand Up @@ -350,23 +349,23 @@ export async function mockApi({ page }: MockParams) {
const projectId = request.url().match(/[/]projects[/](.+?)[/]copy/)?.[1] ?? ''
await route.fulfill({
json: {
/* eslint-disable @typescript-eslint/naming-convention */
organizationId: defaultOrganizationId,
projectId: backend.ProjectId(projectId),
name: 'example project name',
state: {
type: backend.ProjectState.opened,
volume_id: '',
opened_by: defaultEmail,
volumeId: '',
openedBy: defaultEmail,
},
packageName: 'Project_root',
// eslint-disable-next-line @typescript-eslint/naming-convention
ide_version: null,
// eslint-disable-next-line @typescript-eslint/naming-convention
engine_version: {
value: '2023.2.1-nightly.2023.9.29',
lifecycle: backend.VersionLifecycle.development,
},
address: backend.Address('ws://example.com/'),
/* eslint-enable @typescript-eslint/naming-convention */
} satisfies backend.ProjectRaw,
})
}
Expand Down Expand Up @@ -626,8 +625,7 @@ export async function mockApi({ page }: MockParams) {
organizationId: defaultOrganizationId,
packageName: 'Project_root',
projectId: id,
// eslint-disable-next-line @typescript-eslint/naming-convention
state: { type: backend.ProjectState.opened, volume_id: '' },
state: { type: backend.ProjectState.opened, volumeId: '' },
}
addProject(title, {
description: null,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -103,13 +103,10 @@ export default function ProjectIcon(props: ProjectIconProps) {
type: newState,
})
if (!backendModule.IS_OPENING_OR_OPENED[newState]) {
// eslint-disable-next-line @typescript-eslint/naming-convention, @typescript-eslint/no-unused-vars
const { opened_by, ...newProjectState2 } = newProjectState
newProjectState = newProjectState2
newProjectState = object.omit(newProjectState, 'openedBy')
} else if (user != null) {
newProjectState = object.merge(newProjectState, {
// eslint-disable-next-line @typescript-eslint/naming-convention
opened_by: user.email,
openedBy: user.email,
})
}
return object.merge(oldItem, { projectState: newProjectState })
Expand All @@ -123,7 +120,7 @@ export default function ProjectIcon(props: ProjectIconProps) {
>(null)
const [shouldOpenWhenReady, setShouldOpenWhenReady] = React.useState(false)
const [isRunningInBackground, setIsRunningInBackground] = React.useState(
item.projectState.execute_async ?? false
item.projectState.executeAsync ?? false
)
const [shouldSwitchPage, setShouldSwitchPage] = React.useState(false)
const [toastId, setToastId] = React.useState<toast.Id | null>(null)
Expand All @@ -132,7 +129,7 @@ export default function ProjectIcon(props: ProjectIconProps) {
const [closeProjectAbortController, setCloseProjectAbortController] =
React.useState<AbortController | null>(null)
const isOtherUserUsingProject =
backend.type !== backendModule.BackendType.local && item.projectState.opened_by !== user?.email
backend.type !== backendModule.BackendType.local && item.projectState.openedBy !== user?.email

const openProject = React.useCallback(
async (shouldRunInBackground: boolean) => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,8 +73,8 @@ export default function ProjectNameColumn(props: ProjectNameColumnProps) {
permissions.PERMISSION_ACTION_CAN_EXECUTE[ownPermission.permission]))
const isOtherUserUsingProject =
backend.type !== backendModule.BackendType.local &&
projectState.opened_by != null &&
projectState.opened_by !== user?.email
projectState.openedBy != null &&
projectState.openedBy !== user?.email

const setIsEditing = (isEditingName: boolean) => {
if (isEditable) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -96,8 +96,8 @@ export default function AssetContextMenu(props: AssetContextMenuProps) {
const isOtherUserUsingProject =
backend.type !== backendModule.BackendType.local &&
backendModule.assetIsProject(asset) &&
asset.projectState.opened_by != null &&
asset.projectState.opened_by !== user?.email
asset.projectState.openedBy != null &&
asset.projectState.openedBy !== user?.email
const setAsset = setAssetHooks.useSetAsset(asset, setItem)

return category === Category.trash ? (
Expand Down
6 changes: 2 additions & 4 deletions app/ide-desktop/lib/dashboard/src/layouts/AssetsTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -1498,10 +1498,8 @@ export default function AssetsTable(props: AssetsTableProps) {
permissions: permissions.tryGetSingletonOwnerPermission(user),
projectState: {
type: backendModule.ProjectState.placeholder,
// eslint-disable-next-line @typescript-eslint/naming-convention
volume_id: '',
// eslint-disable-next-line @typescript-eslint/naming-convention
...(user != null ? { opened_by: user.email } : {}),
volumeId: '',
...(user != null ? { openedBy: user.email } : {}),
...(path != null ? { path } : {}),
},
labels: [],
Expand Down
24 changes: 10 additions & 14 deletions app/ide-desktop/lib/dashboard/src/services/Backend.ts
Original file line number Diff line number Diff line change
Expand Up @@ -160,19 +160,17 @@ export enum ProjectState {
/** Wrapper around a project state value. */
export interface ProjectStateType {
readonly type: ProjectState
/* eslint-disable @typescript-eslint/naming-convention */
readonly volume_id: string
readonly instance_id?: string
readonly execute_async?: boolean
readonly volumeId: string
readonly instanceId?: string
readonly executeAsync?: boolean
readonly address?: string
readonly security_group_id?: string
readonly ec2_id?: string
readonly ec2_public_ip_address?: string
readonly current_session_id?: string
readonly opened_by?: EmailAddress
readonly securityGroupId?: string
readonly ec2Id?: string
readonly ec2PublicIpAddress?: string
readonly currentSessionId?: string
readonly openedBy?: EmailAddress
/** Only present on the Local backend. */
readonly path?: Path
/* eslint-enable @typescript-eslint/naming-convention */
}

export const IS_OPENING: Readonly<Record<ProjectState, boolean>> = {
Expand Down Expand Up @@ -711,10 +709,8 @@ export function createPlaceholderProjectAsset(
modifiedAt: dateTime.toRfc3339(new Date()),
projectState: {
type: ProjectState.new,
// eslint-disable-next-line @typescript-eslint/naming-convention
volume_id: '',
// eslint-disable-next-line @typescript-eslint/naming-convention
...(organization != null ? { opened_by: organization.email } : {}),
volumeId: '',
...(organization != null ? { openedBy: organization.email } : {}),
...(path != null ? { path } : {}),
},
labels: [],
Expand Down
15 changes: 5 additions & 10 deletions app/ide-desktop/lib/dashboard/src/services/LocalBackend.ts
Original file line number Diff line number Diff line change
Expand Up @@ -152,8 +152,7 @@ export default class LocalBackend extends Backend {
type:
this.projectManager.projects.get(entry.metadata.id)?.state ??
backend.ProjectState.closed,
// eslint-disable-next-line @typescript-eslint/naming-convention
volume_id: '',
volumeId: '',
path: entry.path,
},
labels: [],
Expand Down Expand Up @@ -189,8 +188,7 @@ export default class LocalBackend extends Backend {
packageName: project.name,
state: {
type: backend.ProjectState.closed,
// eslint-disable-next-line @typescript-eslint/naming-convention
volume_id: '',
volumeId: '',
},
jsonAddress: null,
binaryAddress: null,
Expand Down Expand Up @@ -221,8 +219,7 @@ export default class LocalBackend extends Backend {
packageName: project.projectName,
state: {
type: backend.ProjectState.closed,
// eslint-disable-next-line @typescript-eslint/naming-convention
volume_id: '',
volumeId: '',
path,
},
}
Expand Down Expand Up @@ -284,8 +281,7 @@ export default class LocalBackend extends Backend {
projectId,
state: {
type: this.projectManager.projects.get(id)?.state ?? backend.ProjectState.closed,
// eslint-disable-next-line @typescript-eslint/naming-convention
volume_id: '',
volumeId: '',
},
}
}
Expand All @@ -308,8 +304,7 @@ export default class LocalBackend extends Backend {
projectId,
state: {
type: backend.ProjectState.opened,
// eslint-disable-next-line @typescript-eslint/naming-convention
volume_id: '',
volumeId: '',
},
}
}
Expand Down
2 changes: 1 addition & 1 deletion app/ide-desktop/lib/dashboard/src/utilities/object.ts
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ export function singletonObjectOrNull(value: unknown): [] | [object] {
// === omit ===
// ============

/** UNSAFE when `Ks` contains strings that are not in the runtie array. */
/** UNSAFE when `Ks` contains strings that are not in the runtime array. */
export function omit<T, Ks extends readonly (string & keyof T)[] | []>(
object: T,
...keys: Ks
Expand Down

0 comments on commit f80e005

Please sign in to comment.