|
1 | 1 | import { |
2 | 2 | DbItemKind, |
| 3 | + LocalDatabaseDbItem, |
| 4 | + LocalListDbItem, |
| 5 | + RemoteOwnerDbItem, |
| 6 | + RemoteRepoDbItem, |
| 7 | + RemoteSystemDefinedListDbItem, |
3 | 8 | RemoteUserDefinedListDbItem, |
| 9 | + RootLocalDbItem, |
4 | 10 | RootRemoteDbItem, |
5 | 11 | } from "../../src/databases/db-item"; |
6 | 12 |
|
7 | | -export function createRootRemoteDbItem(): RootRemoteDbItem { |
| 13 | +// Root Remote Db Items |
| 14 | +export function createRootRemoteDbItem({ |
| 15 | + children = [], |
| 16 | + expanded = false, |
| 17 | +}: { |
| 18 | + children?: Array< |
| 19 | + | RemoteOwnerDbItem |
| 20 | + | RemoteSystemDefinedListDbItem |
| 21 | + | RemoteUserDefinedListDbItem |
| 22 | + >; |
| 23 | + expanded?: boolean; |
| 24 | +}): RootRemoteDbItem { |
8 | 25 | return { |
9 | 26 | kind: DbItemKind.RootRemote, |
10 | | - children: [], |
11 | | - expanded: false, |
| 27 | + children, |
| 28 | + expanded, |
| 29 | + }; |
| 30 | +} |
| 31 | + |
| 32 | +export function createRemoteOwnerDbItem({ |
| 33 | + ownerName = `owner${getRandomInt()}`, |
| 34 | + selected = false, |
| 35 | +}: { |
| 36 | + ownerName?: string; |
| 37 | + selected?: boolean; |
| 38 | +}): RemoteOwnerDbItem { |
| 39 | + return { |
| 40 | + kind: DbItemKind.RemoteOwner, |
| 41 | + selected, |
| 42 | + ownerName, |
| 43 | + }; |
| 44 | +} |
| 45 | + |
| 46 | +export function createRemoteRepoDbItem({ |
| 47 | + repoFullName = `repoFullName${getRandomInt()}`, |
| 48 | + selected = false, |
| 49 | + parentListName = undefined, |
| 50 | +}: { |
| 51 | + repoFullName?: string; |
| 52 | + selected?: boolean; |
| 53 | + parentListName?: string; |
| 54 | +}): RemoteRepoDbItem { |
| 55 | + return { |
| 56 | + kind: DbItemKind.RemoteRepo, |
| 57 | + selected, |
| 58 | + repoFullName, |
| 59 | + parentListName, |
| 60 | + }; |
| 61 | +} |
| 62 | + |
| 63 | +export function createRemoteSystemDefinedListDbItem({ |
| 64 | + listName = `top_${getRandomInt()}`, |
| 65 | + listDisplayName = `Display Name`, |
| 66 | + listDescription = `Description`, |
| 67 | + selected = false, |
| 68 | +}: { |
| 69 | + listName?: string; |
| 70 | + listDisplayName?: string; |
| 71 | + listDescription?: string; |
| 72 | + selected?: boolean; |
| 73 | +}): RemoteSystemDefinedListDbItem { |
| 74 | + return { |
| 75 | + kind: DbItemKind.RemoteSystemDefinedList, |
| 76 | + selected, |
| 77 | + listName, |
| 78 | + listDisplayName, |
| 79 | + listDescription, |
12 | 80 | }; |
13 | 81 | } |
14 | 82 |
|
15 | 83 | export function createRemoteUserDefinedListDbItem({ |
16 | | - name = "list1", |
| 84 | + expanded = false, |
| 85 | + selected = false, |
| 86 | + listName = `list${getRandomInt()}`, |
| 87 | + repos = [ |
| 88 | + createRemoteRepoDbItem({ |
| 89 | + parentListName: listName, |
| 90 | + }), |
| 91 | + ], |
17 | 92 | }: { |
18 | | - name: string; |
| 93 | + listName?: string; |
| 94 | + expanded?: boolean; |
| 95 | + selected?: boolean; |
| 96 | + repos?: RemoteRepoDbItem[]; |
19 | 97 | }): RemoteUserDefinedListDbItem { |
20 | 98 | return { |
21 | 99 | kind: DbItemKind.RemoteUserDefinedList, |
22 | | - selected: false, |
23 | | - expanded: false, |
24 | | - listName: name, |
25 | | - repos: [ |
26 | | - { |
27 | | - kind: DbItemKind.RemoteRepo, |
28 | | - selected: false, |
29 | | - repoFullName: "repo1", |
30 | | - parentListName: name, |
31 | | - }, |
32 | | - ], |
| 100 | + expanded, |
| 101 | + selected, |
| 102 | + listName, |
| 103 | + repos, |
33 | 104 | }; |
34 | 105 | } |
| 106 | + |
| 107 | +// Root Local Db Items |
| 108 | +export function createRootLocalDbItem({ |
| 109 | + children = [], |
| 110 | + expanded = false, |
| 111 | +}: { |
| 112 | + children?: Array<LocalDatabaseDbItem | LocalListDbItem>; |
| 113 | + expanded?: boolean; |
| 114 | +}): RootLocalDbItem { |
| 115 | + return { |
| 116 | + kind: DbItemKind.RootLocal, |
| 117 | + children, |
| 118 | + expanded, |
| 119 | + }; |
| 120 | +} |
| 121 | + |
| 122 | +export function createLocalDatabaseDbItem({ |
| 123 | + databaseName = `database${getRandomInt()}`, |
| 124 | + dateAdded = getRandomInt(), |
| 125 | + language = `language${getRandomInt()}`, |
| 126 | + storagePath = `storagePath${getRandomInt()}`, |
| 127 | + selected = false, |
| 128 | +}: { |
| 129 | + databaseName?: string; |
| 130 | + dateAdded?: number; |
| 131 | + language?: string; |
| 132 | + storagePath?: string; |
| 133 | + selected?: boolean; |
| 134 | +}): LocalDatabaseDbItem { |
| 135 | + return { |
| 136 | + kind: DbItemKind.LocalDatabase, |
| 137 | + selected, |
| 138 | + databaseName, |
| 139 | + dateAdded, |
| 140 | + language, |
| 141 | + storagePath, |
| 142 | + }; |
| 143 | +} |
| 144 | + |
| 145 | +export function createLocalListDbItem({ |
| 146 | + listName = `top_${getRandomInt()}`, |
| 147 | + selected = false, |
| 148 | + expanded = false, |
| 149 | + databases = [], |
| 150 | +}: { |
| 151 | + listName?: string; |
| 152 | + databases?: LocalDatabaseDbItem[]; |
| 153 | + selected?: boolean; |
| 154 | + expanded?: boolean; |
| 155 | +}): LocalListDbItem { |
| 156 | + return { |
| 157 | + kind: DbItemKind.LocalList, |
| 158 | + selected, |
| 159 | + expanded, |
| 160 | + databases, |
| 161 | + listName, |
| 162 | + }; |
| 163 | +} |
| 164 | + |
| 165 | +function getRandomInt() { |
| 166 | + return Math.floor(Math.random() * 100); |
| 167 | +} |
0 commit comments