@lifeready/core 6.0.5 → 6.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/bundles/lifeready-core.umd.js +3474 -7307
  2. package/bundles/lifeready-core.umd.js.map +1 -1
  3. package/bundles/lifeready-core.umd.min.js +1 -1
  4. package/bundles/lifeready-core.umd.min.js.map +1 -1
  5. package/esm2015/lib/auth2/auth.config.js +57 -0
  6. package/esm2015/lib/auth2/auth2.gql.private.js +8 -1
  7. package/esm2015/lib/auth2/auth2.service.js +3 -4
  8. package/esm2015/lib/auth2/auth2.types.js +1 -1
  9. package/esm2015/lib/file-upload/file-upload.service.js +4 -4
  10. package/esm2015/lib/idle/idle.service.js +1 -2
  11. package/esm2015/lib/item2/item2.service.js +15 -45
  12. package/esm2015/lib/key/key-meta.service.js +16 -8
  13. package/esm2015/lib/key-exchange/key-exchange2.service.js +6 -25
  14. package/esm2015/lib/life-ready.module.js +2 -9
  15. package/esm2015/lib/password/password.service.js +1 -1
  16. package/esm2015/lib/profile/profile-details.service.js +120 -75
  17. package/esm2015/lib/profile/profile.gql.js +134 -1
  18. package/esm2015/lib/profile/profile.service.js +8 -5
  19. package/esm2015/lib/profile/profile.types.js +14 -3
  20. package/esm2015/lib/shared-contact-card/shared-contact-card.service.js +2 -2
  21. package/esm2015/lib/tp-password-reset/tp-password-reset.types.js +1 -1
  22. package/esm2015/lib/trusted-party/trusted-party2.service.js +3 -7
  23. package/esm2015/lifeready-core.js +7 -9
  24. package/esm2015/public-api.js +2 -20
  25. package/fesm2015/lifeready-core.js +3206 -6520
  26. package/fesm2015/lifeready-core.js.map +1 -1
  27. package/lib/auth2/auth2.gql.private.d.ts +15 -2
  28. package/lib/auth2/auth2.service.d.ts +1 -1
  29. package/lib/auth2/auth2.types.d.ts +19 -2
  30. package/lib/file-upload/file-upload.service.d.ts +2 -2
  31. package/lib/item2/item2.service.d.ts +11 -74
  32. package/lib/key/key-meta.service.d.ts +8 -1
  33. package/lib/key-exchange/key-exchange2.service.d.ts +5 -66
  34. package/lib/password/password.service.d.ts +1 -1
  35. package/lib/profile/profile-details.service.d.ts +10 -11
  36. package/lib/profile/profile.gql.d.ts +12 -0
  37. package/lib/profile/profile.service.d.ts +1 -3
  38. package/lib/profile/profile.types.d.ts +31 -4
  39. package/lib/shared-contact-card/shared-contact-card.service.d.ts +1 -2
  40. package/lib/tp-password-reset/tp-password-reset.types.d.ts +3 -3
  41. package/lib/trusted-party/trusted-party2.service.d.ts +2 -7
  42. package/lifeready-core.d.ts +6 -8
  43. package/lifeready-core.metadata.json +1 -1
  44. package/package.json +1 -1
  45. package/public-api.d.ts +1 -19
  46. package/esm2015/lib/auth/auth.config.js +0 -57
  47. package/esm2015/lib/auth/auth.gql.js +0 -16
  48. package/esm2015/lib/auth/auth.types.js +0 -18
  49. package/esm2015/lib/auth/life-ready-auth.service.js +0 -568
  50. package/esm2015/lib/category/category-meta.service.js +0 -99
  51. package/esm2015/lib/category/category.gql.js +0 -385
  52. package/esm2015/lib/category/category.service.js +0 -361
  53. package/esm2015/lib/category/category.types.js +0 -29
  54. package/esm2015/lib/key-exchange/key-exchange.gql.js +0 -188
  55. package/esm2015/lib/key-exchange/key-exchange.service.js +0 -436
  56. package/esm2015/lib/key-exchange/key-exchange.types.js +0 -7
  57. package/esm2015/lib/message/message.gql.js +0 -32
  58. package/esm2015/lib/message/message.service.js +0 -118
  59. package/esm2015/lib/message/message.types.js +0 -2
  60. package/esm2015/lib/plan/plan.gql.js +0 -123
  61. package/esm2015/lib/plan/plan.service.js +0 -150
  62. package/esm2015/lib/plan/plan.types.js +0 -11
  63. package/esm2015/lib/record/record-attachment.service.js +0 -102
  64. package/esm2015/lib/record/record.gql.js +0 -182
  65. package/esm2015/lib/record/record.service.js +0 -194
  66. package/esm2015/lib/record/record.types.js +0 -15
  67. package/esm2015/lib/record-type/record-type.service.js +0 -75
  68. package/esm2015/lib/record-type/record-type.types.js +0 -28
  69. package/esm2015/lib/trusted-party/trusted-party.gql.js +0 -148
  70. package/esm2015/lib/trusted-party/trusted-party.service.js +0 -308
  71. package/esm2015/lib/trusted-party/trusted-party.types.js +0 -41
  72. package/lib/auth/auth.gql.d.ts +0 -12
  73. package/lib/auth/auth.types.d.ts +0 -52
  74. package/lib/auth/life-ready-auth.service.d.ts +0 -73
  75. package/lib/category/category-meta.service.d.ts +0 -23
  76. package/lib/category/category.gql.d.ts +0 -44
  77. package/lib/category/category.service.d.ts +0 -66
  78. package/lib/category/category.types.d.ts +0 -75
  79. package/lib/key-exchange/key-exchange.gql.d.ts +0 -9
  80. package/lib/key-exchange/key-exchange.service.d.ts +0 -37
  81. package/lib/key-exchange/key-exchange.types.d.ts +0 -188
  82. package/lib/message/message.gql.d.ts +0 -13
  83. package/lib/message/message.service.d.ts +0 -36
  84. package/lib/message/message.types.d.ts +0 -12
  85. package/lib/plan/plan.gql.d.ts +0 -11
  86. package/lib/plan/plan.service.d.ts +0 -34
  87. package/lib/plan/plan.types.d.ts +0 -32
  88. package/lib/record/record-attachment.service.d.ts +0 -16
  89. package/lib/record/record.gql.d.ts +0 -14
  90. package/lib/record/record.service.d.ts +0 -25
  91. package/lib/record/record.types.d.ts +0 -56
  92. package/lib/record-type/record-type.service.d.ts +0 -11
  93. package/lib/record-type/record-type.types.d.ts +0 -50
  94. package/lib/trusted-party/trusted-party.gql.d.ts +0 -9
  95. package/lib/trusted-party/trusted-party.service.d.ts +0 -43
  96. package/lib/trusted-party/trusted-party.types.d.ts +0 -101
  97. /package/lib/{auth → auth2}/auth.config.d.ts +0 -0
@@ -1,182 +0,0 @@
1
- import gql from 'graphql-tag';
2
- import { DEFAULT_BREADCRUMB_DEPTH, parentCategoriesField, } from '../category/category.gql';
3
- import { KeyGraphFragment } from '../_common/queries.gql';
4
- export var FileType;
5
- (function (FileType) {
6
- FileType["RecordContent"] = "record-content";
7
- FileType["RecordAttachment"] = "record-attachment";
8
- })(FileType || (FileType = {}));
9
- export const RecordContentFilter = JSON.stringify({
10
- filter: [
11
- {
12
- contains: {
13
- fileType: FileType.RecordContent,
14
- },
15
- },
16
- ],
17
- });
18
- export const RecordAttachmentFilter = JSON.stringify({
19
- filter: [
20
- {
21
- contains: {
22
- fileType: FileType.RecordAttachment,
23
- },
24
- },
25
- ],
26
- });
27
- export const GetRecordQuery = (depth = DEFAULT_BREADCRUMB_DEPTH) => gql `
28
- query Record(
29
- $id: LrRelayIdInput!,
30
- $cachedKeyIds: [LrRelayIdInput!],
31
- $categoryFilter: LrJSONFilter,
32
- $contentFilter: LrJSONFilter,
33
- $attachmentsFilter: LrJSONFilter,
34
- ) {
35
- record: directory(id: $id) {
36
- id
37
- keyId
38
- archived
39
- plainMeta
40
- cipherMeta
41
- created
42
- modified
43
- confidentiality {
44
- isConfidential
45
- method
46
- }
47
- ${parentCategoriesField(depth)}
48
- content: childFileLinks(plainMeta: $contentFilter) {
49
- edges {
50
- node {
51
- childFile {
52
- id
53
- keyId
54
- archived
55
- currentVersion {
56
- state {
57
- id
58
- keyId
59
- plainMeta
60
- cipherMeta
61
- created
62
- modified
63
- }
64
- }
65
- versions {
66
- edges {
67
- node {
68
- operation
69
- }
70
- }
71
- }
72
- }
73
- }
74
- }
75
- }
76
- attachments: childFileLinks(plainMeta: $attachmentsFilter) {
77
- edges {
78
- node {
79
- childFile {
80
- id
81
- keyId
82
- archived
83
- currentVersion {
84
- state {
85
- id
86
- keyId
87
- plainMeta
88
- cipherMeta
89
- contentResource
90
- }
91
- }
92
- versions {
93
- edges {
94
- node {
95
- operation
96
- }
97
- }
98
- }
99
- }
100
- }
101
- }
102
- }
103
- }
104
- keyGraph(cachedKeyIds: $cachedKeyIds) {
105
- ...KeyGraphFragment
106
- }
107
- }
108
- ${KeyGraphFragment}
109
- `;
110
- export const CreateRecordContainerMutation = gql `
111
- mutation CreateRecordContainer(
112
- $plainMeta: LrJSONString
113
- $cipherMeta: String
114
- $parentDirectories: [ParentDirectoryInput!]
115
- $parentRootDirectory: ParentRootDirectoryInput
116
- ) {
117
- new: createDirectory(
118
- input: {
119
- plainMeta: $plainMeta
120
- cipherMeta: $cipherMeta
121
- parentDirectories: $parentDirectories
122
- parentRootDirectory: $parentRootDirectory
123
- }
124
- ) {
125
- category: directory {
126
- id
127
- keyId
128
- }
129
- }
130
- }
131
- `;
132
- export const CreateRecordMutation = gql `
133
- mutation CreateFile($input: CreateFileInput!) {
134
- createFile(input: $input) {
135
- file {
136
- id
137
- }
138
- }
139
- }
140
- `;
141
- export const UpdateRecordContainerMutation = gql `
142
- mutation UpdateRecord($input: UpdateDirectoryInput!) {
143
- updateDirectory(input: $input) {
144
- directory {
145
- id
146
- }
147
- }
148
- }
149
- `;
150
- export const UpdateRecordMutation = gql `
151
- mutation UpdateFile($input: UpdateFileInput!) {
152
- updateFile(input: $input) {
153
- file {
154
- id
155
- }
156
- }
157
- }
158
- `;
159
- export const DeleteRecordMutation = gql `
160
- mutation DeleteRecord($recordId: LrRelayIdInput!) {
161
- deleteDirectory(input: { directoryId: $recordId }) {
162
- id
163
- }
164
- }
165
- `;
166
- export const CreateFileMutation = gql `
167
- mutation CreateFile($input: CreateFileInput!) {
168
- createFile(input: $input) {
169
- file {
170
- id
171
- }
172
- }
173
- }
174
- `;
175
- export const DeleteFileMutation = gql `
176
- mutation DeleteFile($fileId: LrRelayIdInput!) {
177
- deleteFile(input: { fileId: $fileId }) {
178
- id
179
- }
180
- }
181
- `;
182
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLmdxbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9yZWNvcmQvcmVjb3JkLmdxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEdBQUcsTUFBTSxhQUFhLENBQUM7QUFDOUIsT0FBTyxFQUNMLHdCQUF3QixFQUN4QixxQkFBcUIsR0FDdEIsTUFBTSwwQkFBMEIsQ0FBQztBQUNsQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUUxRCxNQUFNLENBQU4sSUFBWSxRQUdYO0FBSEQsV0FBWSxRQUFRO0lBQ2xCLDRDQUFnQyxDQUFBO0lBQ2hDLGtEQUFzQyxDQUFBO0FBQ3hDLENBQUMsRUFIVyxRQUFRLEtBQVIsUUFBUSxRQUduQjtBQUVELE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDaEQsTUFBTSxFQUFFO1FBQ047WUFDRSxRQUFRLEVBQUU7Z0JBQ1IsUUFBUSxFQUFFLFFBQVEsQ0FBQyxhQUFhO2FBQ2pDO1NBQ0Y7S0FDRjtDQUNGLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDbkQsTUFBTSxFQUFFO1FBQ047WUFDRSxRQUFRLEVBQUU7Z0JBQ1IsUUFBUSxFQUFFLFFBQVEsQ0FBQyxnQkFBZ0I7YUFDcEM7U0FDRjtLQUNGO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLENBQUMsS0FBSyxHQUFHLHdCQUF3QixFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O01Bb0JqRSxxQkFBcUIsQ0FBQyxLQUFLLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7RUE2RGhDLGdCQUFnQjtDQUNqQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sNkJBQTZCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0FxQi9DLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUXRDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUS9DLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxHQUFHLENBQUE7Ozs7Ozs7O0NBUXRDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxHQUFHLENBQUE7Ozs7OztDQU10QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7OztDQVFwQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Q0FNcEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBncWwgZnJvbSAnZ3JhcGhxbC10YWcnO1xuaW1wb3J0IHtcbiAgREVGQVVMVF9CUkVBRENSVU1CX0RFUFRILFxuICBwYXJlbnRDYXRlZ29yaWVzRmllbGQsXG59IGZyb20gJy4uL2NhdGVnb3J5L2NhdGVnb3J5LmdxbCc7XG5pbXBvcnQgeyBLZXlHcmFwaEZyYWdtZW50IH0gZnJvbSAnLi4vX2NvbW1vbi9xdWVyaWVzLmdxbCc7XG5cbmV4cG9ydCBlbnVtIEZpbGVUeXBlIHtcbiAgUmVjb3JkQ29udGVudCA9ICdyZWNvcmQtY29udGVudCcsXG4gIFJlY29yZEF0dGFjaG1lbnQgPSAncmVjb3JkLWF0dGFjaG1lbnQnLFxufVxuXG5leHBvcnQgY29uc3QgUmVjb3JkQ29udGVudEZpbHRlciA9IEpTT04uc3RyaW5naWZ5KHtcbiAgZmlsdGVyOiBbXG4gICAge1xuICAgICAgY29udGFpbnM6IHtcbiAgICAgICAgZmlsZVR5cGU6IEZpbGVUeXBlLlJlY29yZENvbnRlbnQsXG4gICAgICB9LFxuICAgIH0sXG4gIF0sXG59KTtcblxuZXhwb3J0IGNvbnN0IFJlY29yZEF0dGFjaG1lbnRGaWx0ZXIgPSBKU09OLnN0cmluZ2lmeSh7XG4gIGZpbHRlcjogW1xuICAgIHtcbiAgICAgIGNvbnRhaW5zOiB7XG4gICAgICAgIGZpbGVUeXBlOiBGaWxlVHlwZS5SZWNvcmRBdHRhY2htZW50LFxuICAgICAgfSxcbiAgICB9LFxuICBdLFxufSk7XG5cbmV4cG9ydCBjb25zdCBHZXRSZWNvcmRRdWVyeSA9IChkZXB0aCA9IERFRkFVTFRfQlJFQURDUlVNQl9ERVBUSCkgPT4gZ3FsYFxucXVlcnkgUmVjb3JkKFxuICAkaWQ6IExyUmVsYXlJZElucHV0ISxcbiAgJGNhY2hlZEtleUlkczogW0xyUmVsYXlJZElucHV0IV0sXG4gICRjYXRlZ29yeUZpbHRlcjogTHJKU09ORmlsdGVyLFxuICAkY29udGVudEZpbHRlcjogTHJKU09ORmlsdGVyLFxuICAkYXR0YWNobWVudHNGaWx0ZXI6IExySlNPTkZpbHRlcixcbikge1xuICByZWNvcmQ6IGRpcmVjdG9yeShpZDogJGlkKSB7XG4gICAgaWRcbiAgICBrZXlJZFxuICAgIGFyY2hpdmVkXG4gICAgcGxhaW5NZXRhXG4gICAgY2lwaGVyTWV0YVxuICAgIGNyZWF0ZWRcbiAgICBtb2RpZmllZFxuICAgIGNvbmZpZGVudGlhbGl0eSB7XG4gICAgICBpc0NvbmZpZGVudGlhbFxuICAgICAgbWV0aG9kXG4gICAgfVxuICAgICR7cGFyZW50Q2F0ZWdvcmllc0ZpZWxkKGRlcHRoKX1cbiAgICBjb250ZW50OiBjaGlsZEZpbGVMaW5rcyhwbGFpbk1ldGE6ICRjb250ZW50RmlsdGVyKSB7XG4gICAgICBlZGdlcyB7XG4gICAgICAgIG5vZGUge1xuICAgICAgICAgIGNoaWxkRmlsZSB7XG4gICAgICAgICAgICBpZFxuICAgICAgICAgICAga2V5SWRcbiAgICAgICAgICAgIGFyY2hpdmVkXG4gICAgICAgICAgICBjdXJyZW50VmVyc2lvbiB7XG4gICAgICAgICAgICAgIHN0YXRlIHtcbiAgICAgICAgICAgICAgICBpZFxuICAgICAgICAgICAgICAgIGtleUlkXG4gICAgICAgICAgICAgICAgcGxhaW5NZXRhXG4gICAgICAgICAgICAgICAgY2lwaGVyTWV0YVxuICAgICAgICAgICAgICAgIGNyZWF0ZWRcbiAgICAgICAgICAgICAgICBtb2RpZmllZFxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB2ZXJzaW9ucyB7XG4gICAgICAgICAgICAgIGVkZ2VzIHtcbiAgICAgICAgICAgICAgICBub2RlIHtcbiAgICAgICAgICAgICAgICAgIG9wZXJhdGlvblxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgICBhdHRhY2htZW50czogY2hpbGRGaWxlTGlua3MocGxhaW5NZXRhOiAkYXR0YWNobWVudHNGaWx0ZXIpIHtcbiAgICAgIGVkZ2VzIHtcbiAgICAgICAgbm9kZSB7XG4gICAgICAgICAgY2hpbGRGaWxlIHtcbiAgICAgICAgICAgIGlkXG4gICAgICAgICAgICBrZXlJZFxuICAgICAgICAgICAgYXJjaGl2ZWRcbiAgICAgICAgICAgIGN1cnJlbnRWZXJzaW9uIHtcbiAgICAgICAgICAgICAgc3RhdGUge1xuICAgICAgICAgICAgICAgIGlkXG4gICAgICAgICAgICAgICAga2V5SWRcbiAgICAgICAgICAgICAgICBwbGFpbk1ldGFcbiAgICAgICAgICAgICAgICBjaXBoZXJNZXRhXG4gICAgICAgICAgICAgICAgY29udGVudFJlc291cmNlXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHZlcnNpb25zIHtcbiAgICAgICAgICAgICAgZWRnZXMge1xuICAgICAgICAgICAgICAgIG5vZGUge1xuICAgICAgICAgICAgICAgICAgb3BlcmF0aW9uXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGtleUdyYXBoKGNhY2hlZEtleUlkczogJGNhY2hlZEtleUlkcykge1xuICAgIC4uLktleUdyYXBoRnJhZ21lbnRcbiAgfVxufVxuJHtLZXlHcmFwaEZyYWdtZW50fVxuYDtcblxuZXhwb3J0IGNvbnN0IENyZWF0ZVJlY29yZENvbnRhaW5lck11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBDcmVhdGVSZWNvcmRDb250YWluZXIoXG4gICAgJHBsYWluTWV0YTogTHJKU09OU3RyaW5nXG4gICAgJGNpcGhlck1ldGE6IFN0cmluZ1xuICAgICRwYXJlbnREaXJlY3RvcmllczogW1BhcmVudERpcmVjdG9yeUlucHV0IV1cbiAgICAkcGFyZW50Um9vdERpcmVjdG9yeTogUGFyZW50Um9vdERpcmVjdG9yeUlucHV0XG4gICkge1xuICAgIG5ldzogY3JlYXRlRGlyZWN0b3J5KFxuICAgICAgaW5wdXQ6IHtcbiAgICAgICAgcGxhaW5NZXRhOiAkcGxhaW5NZXRhXG4gICAgICAgIGNpcGhlck1ldGE6ICRjaXBoZXJNZXRhXG4gICAgICAgIHBhcmVudERpcmVjdG9yaWVzOiAkcGFyZW50RGlyZWN0b3JpZXNcbiAgICAgICAgcGFyZW50Um9vdERpcmVjdG9yeTogJHBhcmVudFJvb3REaXJlY3RvcnlcbiAgICAgIH1cbiAgICApIHtcbiAgICAgIGNhdGVnb3J5OiBkaXJlY3Rvcnkge1xuICAgICAgICBpZFxuICAgICAgICBrZXlJZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IENyZWF0ZVJlY29yZE11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBDcmVhdGVGaWxlKCRpbnB1dDogQ3JlYXRlRmlsZUlucHV0ISkge1xuICAgIGNyZWF0ZUZpbGUoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgZmlsZSB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgVXBkYXRlUmVjb3JkQ29udGFpbmVyTXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIFVwZGF0ZVJlY29yZCgkaW5wdXQ6IFVwZGF0ZURpcmVjdG9yeUlucHV0ISkge1xuICAgIHVwZGF0ZURpcmVjdG9yeShpbnB1dDogJGlucHV0KSB7XG4gICAgICBkaXJlY3Rvcnkge1xuICAgICAgICBpZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFVwZGF0ZVJlY29yZE11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBVcGRhdGVGaWxlKCRpbnB1dDogVXBkYXRlRmlsZUlucHV0ISkge1xuICAgIHVwZGF0ZUZpbGUoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgZmlsZSB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRGVsZXRlUmVjb3JkTXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIERlbGV0ZVJlY29yZCgkcmVjb3JkSWQ6IExyUmVsYXlJZElucHV0ISkge1xuICAgIGRlbGV0ZURpcmVjdG9yeShpbnB1dDogeyBkaXJlY3RvcnlJZDogJHJlY29yZElkIH0pIHtcbiAgICAgIGlkXG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgQ3JlYXRlRmlsZU11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBDcmVhdGVGaWxlKCRpbnB1dDogQ3JlYXRlRmlsZUlucHV0ISkge1xuICAgIGNyZWF0ZUZpbGUoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgZmlsZSB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRGVsZXRlRmlsZU11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBEZWxldGVGaWxlKCRmaWxlSWQ6IExyUmVsYXlJZElucHV0ISkge1xuICAgIGRlbGV0ZUZpbGUoaW5wdXQ6IHsgZmlsZUlkOiAkZmlsZUlkIH0pIHtcbiAgICAgIGlkXG4gICAgfVxuICB9XG5gO1xuIl19
@@ -1,194 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- /* eslint-disable @typescript-eslint/no-explicit-any */
3
- import { Injectable } from '@angular/core';
4
- import { LrApolloService } from '../api/lr-apollo.service';
5
- import { CategoryFilter, DirectoryType } from '../category/category.gql';
6
- import { CategoryService } from '../category/category.service';
7
- import { KeyMetaService } from '../key/key-meta.service';
8
- import { RecordAttachmentService } from './record-attachment.service';
9
- import { CreateRecordContainerMutation, CreateRecordMutation, DeleteRecordMutation, FileType, GetRecordQuery, RecordAttachmentFilter, RecordContentFilter, UpdateRecordMutation, } from './record.gql';
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "../api/lr-apollo.service";
12
- import * as i2 from "../key/key-meta.service";
13
- import * as i3 from "../category/category.service";
14
- import * as i4 from "./record-attachment.service";
15
- export class RecordService {
16
- constructor(lrApollo, keyMetaService, categoryService, recordAttachmentService) {
17
- this.lrApollo = lrApollo;
18
- this.keyMetaService = keyMetaService;
19
- this.categoryService = categoryService;
20
- this.recordAttachmentService = recordAttachmentService;
21
- }
22
- getRecord(recordId) {
23
- var _a;
24
- return __awaiter(this, void 0, void 0, function* () {
25
- const { record } = yield this.lrApollo.query({
26
- query: GetRecordQuery(),
27
- variables: {
28
- id: recordId,
29
- categoryFilter: CategoryFilter,
30
- contentFilter: RecordContentFilter,
31
- attachmentsFilter: RecordAttachmentFilter,
32
- },
33
- });
34
- const contents = record.content.edges[0].node.childFile;
35
- const { name, recordType, fields } = (yield this.keyMetaService.decryptMeta(contents.currentVersion.state)) ||
36
- {};
37
- const categories = yield Promise.all(record.parentCategories.edges.map((x) => __awaiter(this, void 0, void 0, function* () {
38
- return [
39
- ...(yield this.categoryService.mapParentCategories(x.node.parentDirectory)),
40
- yield this.categoryService.mapCategory(x.node.parentDirectory),
41
- ];
42
- })));
43
- const attachments = yield this.mapAttachments(record.attachments.edges);
44
- return {
45
- id: record.id,
46
- keyId: record.keyId,
47
- updateKeyId: contents.keyId,
48
- updateId: contents.id,
49
- name,
50
- recordType,
51
- fields,
52
- categories,
53
- attachments,
54
- isArchived: !!record.archived,
55
- isConfidential: !!((_a = record.confidentiality) === null || _a === void 0 ? void 0 : _a.isConfidential),
56
- createdOn: record.created,
57
- lastModified: new Date(record.modified) >
58
- new Date(contents.currentVersion.state.modified)
59
- ? record.modified
60
- : contents.currentVersion.state.modified,
61
- };
62
- });
63
- }
64
- mapAttachments(attachments) {
65
- return __awaiter(this, void 0, void 0, function* () {
66
- return yield Promise.all(attachments
67
- .map((x) => x.node.childFile)
68
- .map((x) => __awaiter(this, void 0, void 0, function* () {
69
- const { name, fieldId, fileType, fileSize, lastModified } = (yield this.keyMetaService.decryptMeta(x.currentVersion.state)) ||
70
- {};
71
- return {
72
- fileId: x.id,
73
- keyId: x.currentVersion.state.keyId,
74
- contentId: x.currentVersion.state.id,
75
- fieldId,
76
- name,
77
- fileType,
78
- fileSize,
79
- lastModified,
80
- };
81
- })));
82
- });
83
- }
84
- createRecord(newRecord) {
85
- return __awaiter(this, void 0, void 0, function* () {
86
- // Create directory that holds the record
87
- const wrappedContent = yield this.keyMetaService.wrapContent(null, newRecord.categoryIds);
88
- const response = yield this.lrApollo.mutate({
89
- mutation: CreateRecordContainerMutation,
90
- variables: {
91
- plainMeta: JSON.stringify({
92
- directoryType: DirectoryType.Record,
93
- isHidden: false,
94
- }),
95
- parentDirectories: wrappedContent.wrappedKeys,
96
- parentRootDirectory: wrappedContent.rootKey,
97
- },
98
- });
99
- const recordId = response.new.category.id;
100
- const secureContent = {
101
- name: newRecord.name,
102
- recordType: newRecord.recordType,
103
- fields: newRecord.fields,
104
- };
105
- const doubleWrappedContent = yield this.keyMetaService.doubleWrapContent(secureContent, [recordId]);
106
- // Create the file that holds the record contents
107
- yield this.lrApollo.mutate({
108
- mutation: CreateRecordMutation,
109
- variables: {
110
- input: {
111
- plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),
112
- wrappedStateKey: doubleWrappedContent.doubleWrappedKey,
113
- cipherMeta: doubleWrappedContent.cipherMeta,
114
- parentDirectories: doubleWrappedContent.wrappedKeys.map((x) => ({
115
- directoryId: x.directoryId,
116
- wrappingKeyId: x.wrappingKeyId,
117
- wrappedFileKey: x.wrappedKey,
118
- })),
119
- },
120
- },
121
- });
122
- try {
123
- yield this.recordAttachmentService.uploadAttachments(recordId, newRecord.attachments);
124
- }
125
- catch (e) {
126
- console.error(e);
127
- return { recordId, attachmentError: e };
128
- }
129
- return { recordId };
130
- });
131
- }
132
- updateRecord(recordId, updateId, updateKeyId, updatedRecord) {
133
- return __awaiter(this, void 0, void 0, function* () {
134
- const secureContent = {
135
- name: updatedRecord.name,
136
- recordType: updatedRecord.recordType,
137
- fields: updatedRecord.fields,
138
- };
139
- const reWrappedContent = yield this.keyMetaService.reWrapContent(updateKeyId, secureContent);
140
- yield this.lrApollo.mutate({
141
- mutation: UpdateRecordMutation,
142
- variables: {
143
- input: {
144
- fileId: updateId,
145
- plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),
146
- wrappedStateKey: reWrappedContent.doubleWrappedKey,
147
- cipherMeta: reWrappedContent.cipherMeta,
148
- },
149
- },
150
- });
151
- try {
152
- yield this.recordAttachmentService.uploadAttachments(recordId, updatedRecord.attachments);
153
- }
154
- catch (e) {
155
- console.error(e);
156
- return { recordId, attachmentError: e };
157
- }
158
- return { recordId };
159
- });
160
- }
161
- archiveRecord(recordId) {
162
- return __awaiter(this, void 0, void 0, function* () {
163
- // All content of the record should also be archived, hence, recursive=true
164
- return this.categoryService.archiveDirectory(recordId, true);
165
- });
166
- }
167
- unarchiveRecord(recordId) {
168
- return __awaiter(this, void 0, void 0, function* () {
169
- // All content of the record should also be unarchived, hence, recursive=true
170
- return this.categoryService.unarchiveDirectory(recordId, true);
171
- });
172
- }
173
- deleteRecord(recordId) {
174
- return __awaiter(this, void 0, void 0, function* () {
175
- yield this.lrApollo.mutate({
176
- mutation: DeleteRecordMutation,
177
- variables: { recordId },
178
- });
179
- });
180
- }
181
- }
182
- RecordService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RecordService_Factory() { return new RecordService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyMetaService), i0.ɵɵinject(i3.CategoryService), i0.ɵɵinject(i4.RecordAttachmentService)); }, token: RecordService, providedIn: "root" });
183
- RecordService.decorators = [
184
- { type: Injectable, args: [{
185
- providedIn: 'root',
186
- },] }
187
- ];
188
- RecordService.ctorParameters = () => [
189
- { type: LrApolloService },
190
- { type: KeyMetaService },
191
- { type: CategoryService },
192
- { type: RecordAttachmentService }
193
- ];
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/record/record.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable } from '@angular/core';\nimport { LrApolloService } from '../api/lr-apollo.service';\nimport { CategoryFilter, DirectoryType } from '../category/category.gql';\nimport { CategoryService } from '../category/category.service';\nimport { Category } from '../category/category.types';\nimport { KeyMetaService } from '../key/key-meta.service';\nimport { RecordAttachmentService } from './record-attachment.service';\nimport {\n  CreateRecordContainerMutation,\n  CreateRecordMutation,\n  DeleteRecordMutation,\n  FileType,\n  GetRecordQuery,\n  RecordAttachmentFilter,\n  RecordContentFilter,\n  UpdateRecordMutation,\n} from './record.gql';\nimport {\n  LrRecord,\n  NewRecord,\n  RecordAttachment,\n  UpdatedRecord,\n} from './record.types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class RecordService {\n  constructor(\n    private lrApollo: LrApolloService,\n    private keyMetaService: KeyMetaService,\n    private categoryService: CategoryService,\n    private recordAttachmentService: RecordAttachmentService\n  ) {}\n\n  public async getRecord(recordId: string): Promise<LrRecord> {\n    const { record } = await this.lrApollo.query<any>({\n      query: GetRecordQuery(),\n      variables: {\n        id: recordId,\n        categoryFilter: CategoryFilter,\n        contentFilter: RecordContentFilter,\n        attachmentsFilter: RecordAttachmentFilter,\n      },\n    });\n    const contents = record.content.edges[0].node.childFile;\n    const { name, recordType, fields } =\n      (await this.keyMetaService.decryptMeta(contents.currentVersion.state)) ||\n      {};\n    const categories = await Promise.all<Category[]>(\n      record.parentCategories.edges.map(async (x: any) => [\n        ...(await this.categoryService.mapParentCategories(\n          x.node.parentDirectory\n        )),\n        await this.categoryService.mapCategory(x.node.parentDirectory),\n      ])\n    );\n    const attachments = await this.mapAttachments(record.attachments.edges);\n\n    return {\n      id: record.id,\n      keyId: record.keyId,\n      updateKeyId: contents.keyId,\n      updateId: contents.id,\n      name,\n      recordType,\n      fields,\n      categories,\n      attachments,\n      isArchived: !!record.archived,\n      isConfidential: !!record.confidentiality?.isConfidential,\n      createdOn: record.created,\n      lastModified:\n        new Date(record.modified) >\n        new Date(contents.currentVersion.state.modified)\n          ? record.modified\n          : contents.currentVersion.state.modified,\n    };\n  }\n\n  private async mapAttachments(\n    attachments: any[]\n  ): Promise<RecordAttachment[]> {\n    return await Promise.all<RecordAttachment>(\n      attachments\n        .map((x) => x.node.childFile)\n        .map(async (x: any) => {\n          const { name, fieldId, fileType, fileSize, lastModified } =\n            (await this.keyMetaService.decryptMeta(x.currentVersion.state)) ||\n            {};\n\n          return {\n            fileId: x.id,\n            keyId: x.currentVersion.state.keyId,\n            contentId: x.currentVersion.state.id,\n            fieldId,\n            name,\n            fileType,\n            fileSize,\n            lastModified,\n          };\n        })\n    );\n  }\n\n  public async createRecord(\n    newRecord: NewRecord\n  ): Promise<{ recordId: string; attachmentError?: Error }> {\n    // Create directory that holds the record\n    const wrappedContent = await this.keyMetaService.wrapContent(\n      null,\n      newRecord.categoryIds\n    );\n    const response = await this.lrApollo.mutate<any>({\n      mutation: CreateRecordContainerMutation,\n      variables: {\n        plainMeta: JSON.stringify({\n          directoryType: DirectoryType.Record,\n          isHidden: false,\n        }),\n        parentDirectories: wrappedContent.wrappedKeys,\n        parentRootDirectory: wrappedContent.rootKey,\n      },\n    });\n    const recordId = response.new.category.id;\n    const secureContent = {\n      name: newRecord.name,\n      recordType: newRecord.recordType,\n      fields: newRecord.fields,\n    };\n    const doubleWrappedContent = await this.keyMetaService.doubleWrapContent(\n      secureContent,\n      [recordId]\n    );\n\n    // Create the file that holds the record contents\n    await this.lrApollo.mutate({\n      mutation: CreateRecordMutation,\n      variables: {\n        input: {\n          plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),\n          wrappedStateKey: doubleWrappedContent.doubleWrappedKey,\n          cipherMeta: doubleWrappedContent.cipherMeta,\n          parentDirectories: doubleWrappedContent.wrappedKeys.map((x) => ({\n            directoryId: x.directoryId,\n            wrappingKeyId: x.wrappingKeyId,\n            wrappedFileKey: x.wrappedKey,\n          })),\n        },\n      },\n    });\n\n    try {\n      await this.recordAttachmentService.uploadAttachments(\n        recordId,\n        newRecord.attachments\n      );\n    } catch (e) {\n      console.error(e);\n      return { recordId, attachmentError: e };\n    }\n    return { recordId };\n  }\n\n  public async updateRecord(\n    recordId: string,\n    updateId: string,\n    updateKeyId: string,\n    updatedRecord: UpdatedRecord\n  ): Promise<{ recordId: string; attachmentError?: Error }> {\n    const secureContent = {\n      name: updatedRecord.name,\n      recordType: updatedRecord.recordType,\n      fields: updatedRecord.fields,\n    };\n    const reWrappedContent = await this.keyMetaService.reWrapContent(\n      updateKeyId,\n      secureContent\n    );\n\n    await this.lrApollo.mutate({\n      mutation: UpdateRecordMutation,\n      variables: {\n        input: {\n          fileId: updateId,\n          plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),\n          wrappedStateKey: reWrappedContent.doubleWrappedKey,\n          cipherMeta: reWrappedContent.cipherMeta,\n        },\n      },\n    });\n\n    try {\n      await this.recordAttachmentService.uploadAttachments(\n        recordId,\n        updatedRecord.attachments\n      );\n    } catch (e) {\n      console.error(e);\n      return { recordId, attachmentError: e };\n    }\n    return { recordId };\n  }\n\n  public async archiveRecord(recordId: string): Promise<void> {\n    // All content of the record should also be archived, hence, recursive=true\n    return this.categoryService.archiveDirectory(recordId, true);\n  }\n\n  public async unarchiveRecord(recordId: string): Promise<void> {\n    // All content of the record should also be unarchived, hence, recursive=true\n    return this.categoryService.unarchiveDirectory(recordId, true);\n  }\n\n  public async deleteRecord(recordId: string): Promise<void> {\n    await this.lrApollo.mutate({\n      mutation: DeleteRecordMutation,\n      variables: { recordId },\n    });\n  }\n}\n"]}
@@ -1,15 +0,0 @@
1
- export class RecordField {
2
- }
3
- export class RecordAttachment {
4
- }
5
- export class LrRecord {
6
- }
7
- export class NewAttachment {
8
- }
9
- export class NewRecord {
10
- }
11
- export class NewOrUpdatedAttachment extends NewAttachment {
12
- }
13
- export class UpdatedRecord {
14
- }
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL3JlY29yZC9yZWNvcmQudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY0EsTUFBTSxPQUFPLFdBQVc7Q0FNdkI7QUFFRCxNQUFNLE9BQU8sZ0JBQWdCO0NBVTVCO0FBRUQsTUFBTSxPQUFPLFFBQVE7Q0FrQnBCO0FBRUQsTUFBTSxPQUFPLGFBQWE7Q0FJekI7QUFFRCxNQUFNLE9BQU8sU0FBUztDQU9yQjtBQUVELE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxhQUFhO0NBR3hEO0FBRUQsTUFBTSxPQUFPLGFBQWE7Q0FNekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDYXRlZ29yeSB9IGZyb20gJy4uL2NhdGVnb3J5L2NhdGVnb3J5LnR5cGVzJztcbmltcG9ydCB7XG4gIFJlY29yZEZpZWxkVHlwZSxcbiAgUmVjb3JkVHlwZUZpZWxkT3B0aW9uLFxuICBSZWNvcmRUeXBlU3VtbWFyeSxcbn0gZnJvbSAnLi4vcmVjb3JkLXR5cGUvcmVjb3JkLXR5cGUudHlwZXMnO1xuXG5leHBvcnQgdHlwZSBSZWNvcmRGaWVsZFZhbHVlID1cbiAgfCBzdHJpbmdcbiAgfCBzdHJpbmdbXVxuICB8IFJlY29yZFR5cGVGaWVsZE9wdGlvblxuICB8IFJlY29yZFR5cGVGaWVsZE9wdGlvbltdXG4gIHwgUmVjb3JkRmllbGRbXTtcblxuZXhwb3J0IGNsYXNzIFJlY29yZEZpZWxkIHtcbiAgaWQ/OiBzdHJpbmc7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHR5cGU6IFJlY29yZEZpZWxkVHlwZTtcblxuICB2YWx1ZT86IFJlY29yZEZpZWxkVmFsdWU7XG59XG5cbmV4cG9ydCBjbGFzcyBSZWNvcmRBdHRhY2htZW50IHtcbiAgZmlsZUlkOiBzdHJpbmc7XG4gIGtleUlkOiBzdHJpbmc7XG4gIGZpZWxkSWQ/OiBzdHJpbmc7XG4gIGNvbnRlbnRJZDogc3RyaW5nO1xuXG4gIG5hbWU6IHN0cmluZztcbiAgZmlsZVR5cGU6IHN0cmluZztcbiAgZmlsZVNpemU6IG51bWJlcjtcbiAgbGFzdE1vZGlmaWVkOiBudW1iZXIgfCBEYXRlO1xufVxuXG5leHBvcnQgY2xhc3MgTHJSZWNvcmQge1xuICBpZDogc3RyaW5nO1xuICAvLyBUaGlzIGlzIHRoZSBrZXkgb2YgdGhlIGRpcmVjdG9yeSB0aGF0IHJlcHJlc2VudHMgdGhlIHJlY29yZFxuICBrZXlJZDogc3RyaW5nO1xuICAvLyBUaGlzIGlzIHRoZSBrZXkgb2YgdGhlIGZpbGUgY29udGFpbmVkIGluIHNpZGUgdGhlIHJlY29yZCB0aGF0IGhvbGRzIHRoZSByZWNvcmQncyBmaWVsZHMuXG4gIHVwZGF0ZUtleUlkOiBzdHJpbmc7XG4gIHVwZGF0ZUlkOiBzdHJpbmc7XG5cbiAgbmFtZTogc3RyaW5nO1xuICBjYXRlZ29yaWVzPzogQ2F0ZWdvcnlbXVtdO1xuICBmaWVsZHM/OiBSZWNvcmRGaWVsZFtdO1xuICBhdHRhY2htZW50cz86IFJlY29yZEF0dGFjaG1lbnRbXTtcblxuICByZWNvcmRUeXBlOiBSZWNvcmRUeXBlU3VtbWFyeTtcbiAgY3JlYXRlZE9uOiBzdHJpbmcgfCBEYXRlO1xuICBsYXN0TW9kaWZpZWQ6IHN0cmluZyB8IERhdGU7XG4gIGlzQXJjaGl2ZWQ6IGJvb2xlYW47XG4gIGlzQ29uZmlkZW50aWFsOiBib29sZWFuO1xufVxuXG5leHBvcnQgY2xhc3MgTmV3QXR0YWNobWVudCB7XG4gIGZpZWxkSWQ/OiBzdHJpbmc7XG4gIG5hbWU6IHN0cmluZztcbiAgZmlsZT86IEZpbGU7XG59XG5cbmV4cG9ydCBjbGFzcyBOZXdSZWNvcmQge1xuICBuYW1lOiBzdHJpbmc7XG4gIHJlY29yZFR5cGU6IFJlY29yZFR5cGVTdW1tYXJ5O1xuICBjYXRlZ29yeUlkczogc3RyaW5nW107XG5cbiAgZmllbGRzPzogUmVjb3JkRmllbGRbXTtcbiAgYXR0YWNobWVudHM/OiBOZXdBdHRhY2htZW50W107XG59XG5cbmV4cG9ydCBjbGFzcyBOZXdPclVwZGF0ZWRBdHRhY2htZW50IGV4dGVuZHMgTmV3QXR0YWNobWVudCB7XG4gIGZpbGVJZD86IHN0cmluZztcbiAgaXNEZWxldGVkPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNsYXNzIFVwZGF0ZWRSZWNvcmQge1xuICBuYW1lOiBzdHJpbmc7XG4gIHJlY29yZFR5cGU6IFJlY29yZFR5cGVTdW1tYXJ5O1xuXG4gIGZpZWxkcz86IFJlY29yZEZpZWxkW107XG4gIGF0dGFjaG1lbnRzPzogTmV3T3JVcGRhdGVkQXR0YWNobWVudFtdO1xufVxuIl19
@@ -1,75 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- import { HttpClient } from '@angular/common/http';
3
- import { Injectable } from '@angular/core';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/common/http";
6
- const arraysEqual = (a, b) => {
7
- if (a === b)
8
- return true;
9
- if (a == null || b == null)
10
- return false;
11
- if (a.length !== b.length)
12
- return false;
13
- for (let i = 0; i < a.length; ++i) {
14
- if (a[i] !== b[i])
15
- return false;
16
- }
17
- return true;
18
- };
19
- const ɵ0 = arraysEqual;
20
- export class RecordTypeService {
21
- constructor(http) {
22
- this.http = http;
23
- }
24
- getRecordTypes() {
25
- return __awaiter(this, void 0, void 0, function* () {
26
- if (!this.recordTypes) {
27
- this.recordTypes = yield this.http
28
- .get('/assets/meta/record-types.json')
29
- .toPromise();
30
- }
31
- if (!this.categories) {
32
- this.categories = yield this.http
33
- .get('/assets/meta/categories.json')
34
- .toPromise();
35
- }
36
- const subCategories = this.categories
37
- .map((cat) => cat.subCategories)
38
- .reduce((acc, next) => [...acc, ...next], []);
39
- const recordTypesWithCategories = this.recordTypes.map((recordType) => (Object.assign(Object.assign({}, recordType), { categoryNames: recordType.categories.map((cat) => {
40
- return cat.map((categoryCode) => {
41
- const subCat = subCategories.find((c) => c.code === categoryCode);
42
- if (subCat) {
43
- return subCat.name;
44
- }
45
- else {
46
- return this.categories.find((c) => c.code === categoryCode).name;
47
- }
48
- });
49
- }) })));
50
- return Promise.resolve(recordTypesWithCategories);
51
- });
52
- }
53
- getRecordType(recordTypeId) {
54
- return __awaiter(this, void 0, void 0, function* () {
55
- return (yield this.getRecordTypes()).find((x) => x.id === recordTypeId);
56
- });
57
- }
58
- getRecordTypesForCategory(categoryTree) {
59
- return __awaiter(this, void 0, void 0, function* () {
60
- const recordTypes = yield this.getRecordTypes();
61
- return recordTypes.filter((x) => x.categories.some((y) => arraysEqual(y, categoryTree)));
62
- });
63
- }
64
- }
65
- RecordTypeService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RecordTypeService_Factory() { return new RecordTypeService(i0.ɵɵinject(i1.HttpClient)); }, token: RecordTypeService, providedIn: "root" });
66
- RecordTypeService.decorators = [
67
- { type: Injectable, args: [{
68
- providedIn: 'root',
69
- },] }
70
- ];
71
- RecordTypeService.ctorParameters = () => [
72
- { type: HttpClient }
73
- ];
74
- export { ɵ0 };
75
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLXR5cGUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9yZWNvcmQtdHlwZS9yZWNvcmQtdHlwZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBSTNDLE1BQU0sV0FBVyxHQUFHLENBQUMsQ0FBVyxFQUFFLENBQVcsRUFBRSxFQUFFO0lBQy9DLElBQUksQ0FBQyxLQUFLLENBQUM7UUFBRSxPQUFPLElBQUksQ0FBQztJQUN6QixJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLElBQUk7UUFBRSxPQUFPLEtBQUssQ0FBQztJQUN6QyxJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLE1BQU07UUFBRSxPQUFPLEtBQUssQ0FBQztJQUV4QyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsRUFBRTtRQUNqQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQUUsT0FBTyxLQUFLLENBQUM7S0FDakM7SUFDRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUMsQ0FBQzs7QUFLRixNQUFNLE9BQU8saUJBQWlCO0lBSTVCLFlBQW9CLElBQWdCO1FBQWhCLFNBQUksR0FBSixJQUFJLENBQVk7SUFBRyxDQUFDO0lBRTNCLGNBQWM7O1lBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO2dCQUNyQixJQUFJLENBQUMsV0FBVyxHQUFHLE1BQU0sSUFBSSxDQUFDLElBQUk7cUJBQy9CLEdBQUcsQ0FBZSxnQ0FBZ0MsQ0FBQztxQkFDbkQsU0FBUyxFQUFFLENBQUM7YUFDaEI7WUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRTtnQkFDcEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxNQUFNLElBQUksQ0FBQyxJQUFJO3FCQUM5QixHQUFHLENBQW9CLDhCQUE4QixDQUFDO3FCQUN0RCxTQUFTLEVBQUUsQ0FBQzthQUNoQjtZQUVELE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxVQUFVO2lCQUNsQyxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUM7aUJBQy9CLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUVoRCxNQUFNLHlCQUF5QixHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQyxpQ0FDbEUsVUFBVSxLQUNiLGFBQWEsRUFBRSxVQUFVLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO29CQUMvQyxPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxZQUFZLEVBQUUsRUFBRTt3QkFDOUIsTUFBTSxNQUFNLEdBQUcsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxZQUFZLENBQUMsQ0FBQzt3QkFDbEUsSUFBSSxNQUFNLEVBQUU7NEJBQ1YsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDO3lCQUNwQjs2QkFBTTs0QkFDTCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQzt5QkFDbEU7b0JBQ0gsQ0FBQyxDQUFDLENBQUM7Z0JBQ0wsQ0FBQyxDQUFDLElBQ0YsQ0FBQyxDQUFDO1lBQ0osT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFDcEQsQ0FBQztLQUFBO0lBRVksYUFBYSxDQUFDLFlBQW9COztZQUM3QyxPQUFPLENBQUMsTUFBTSxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssWUFBWSxDQUFDLENBQUM7UUFDMUUsQ0FBQztLQUFBO0lBRVkseUJBQXlCLENBQ3BDLFlBQXNCOztZQUV0QixNQUFNLFdBQVcsR0FBRyxNQUFNLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUVoRCxPQUFPLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUM5QixDQUFDLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsRUFBRSxZQUFZLENBQUMsQ0FBQyxDQUN2RCxDQUFDO1FBQ0osQ0FBQztLQUFBOzs7O1lBckRGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBbEJRLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGVmYXVsdENhdGVnb3J5IH0gZnJvbSAnLi4vY2F0ZWdvcnkvY2F0ZWdvcnkudHlwZXMnO1xuaW1wb3J0IHsgUmVjb3JkVHlwZSB9IGZyb20gJy4vcmVjb3JkLXR5cGUudHlwZXMnO1xuXG5jb25zdCBhcnJheXNFcXVhbCA9IChhOiBzdHJpbmdbXSwgYjogc3RyaW5nW10pID0+IHtcbiAgaWYgKGEgPT09IGIpIHJldHVybiB0cnVlO1xuICBpZiAoYSA9PSBudWxsIHx8IGIgPT0gbnVsbCkgcmV0dXJuIGZhbHNlO1xuICBpZiAoYS5sZW5ndGggIT09IGIubGVuZ3RoKSByZXR1cm4gZmFsc2U7XG5cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgKytpKSB7XG4gICAgaWYgKGFbaV0gIT09IGJbaV0pIHJldHVybiBmYWxzZTtcbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn07XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBSZWNvcmRUeXBlU2VydmljZSB7XG4gIHByaXZhdGUgcmVjb3JkVHlwZXM6IFJlY29yZFR5cGVbXTtcbiAgcHJpdmF0ZSBjYXRlZ29yaWVzOiBEZWZhdWx0Q2F0ZWdvcnlbXTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQpIHt9XG5cbiAgcHVibGljIGFzeW5jIGdldFJlY29yZFR5cGVzKCk6IFByb21pc2U8UmVjb3JkVHlwZVtdPiB7XG4gICAgaWYgKCF0aGlzLnJlY29yZFR5cGVzKSB7XG4gICAgICB0aGlzLnJlY29yZFR5cGVzID0gYXdhaXQgdGhpcy5odHRwXG4gICAgICAgIC5nZXQ8UmVjb3JkVHlwZVtdPignL2Fzc2V0cy9tZXRhL3JlY29yZC10eXBlcy5qc29uJylcbiAgICAgICAgLnRvUHJvbWlzZSgpO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuY2F0ZWdvcmllcykge1xuICAgICAgdGhpcy5jYXRlZ29yaWVzID0gYXdhaXQgdGhpcy5odHRwXG4gICAgICAgIC5nZXQ8RGVmYXVsdENhdGVnb3J5W10+KCcvYXNzZXRzL21ldGEvY2F0ZWdvcmllcy5qc29uJylcbiAgICAgICAgLnRvUHJvbWlzZSgpO1xuICAgIH1cblxuICAgIGNvbnN0IHN1YkNhdGVnb3JpZXMgPSB0aGlzLmNhdGVnb3JpZXNcbiAgICAgIC5tYXAoKGNhdCkgPT4gY2F0LnN1YkNhdGVnb3JpZXMpXG4gICAgICAucmVkdWNlKChhY2MsIG5leHQpID0+IFsuLi5hY2MsIC4uLm5leHRdLCBbXSk7XG5cbiAgICBjb25zdCByZWNvcmRUeXBlc1dpdGhDYXRlZ29yaWVzID0gdGhpcy5yZWNvcmRUeXBlcy5tYXAoKHJlY29yZFR5cGUpID0+ICh7XG4gICAgICAuLi5yZWNvcmRUeXBlLFxuICAgICAgY2F0ZWdvcnlOYW1lczogcmVjb3JkVHlwZS5jYXRlZ29yaWVzLm1hcCgoY2F0KSA9PiB7XG4gICAgICAgIHJldHVybiBjYXQubWFwKChjYXRlZ29yeUNvZGUpID0+IHtcbiAgICAgICAgICBjb25zdCBzdWJDYXQgPSBzdWJDYXRlZ29yaWVzLmZpbmQoKGMpID0+IGMuY29kZSA9PT0gY2F0ZWdvcnlDb2RlKTtcbiAgICAgICAgICBpZiAoc3ViQ2F0KSB7XG4gICAgICAgICAgICByZXR1cm4gc3ViQ2F0Lm5hbWU7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLmNhdGVnb3JpZXMuZmluZCgoYykgPT4gYy5jb2RlID09PSBjYXRlZ29yeUNvZGUpLm5hbWU7XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgIH0pLFxuICAgIH0pKTtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKHJlY29yZFR5cGVzV2l0aENhdGVnb3JpZXMpO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGdldFJlY29yZFR5cGUocmVjb3JkVHlwZUlkOiBzdHJpbmcpOiBQcm9taXNlPFJlY29yZFR5cGU+IHtcbiAgICByZXR1cm4gKGF3YWl0IHRoaXMuZ2V0UmVjb3JkVHlwZXMoKSkuZmluZCgoeCkgPT4geC5pZCA9PT0gcmVjb3JkVHlwZUlkKTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBnZXRSZWNvcmRUeXBlc0ZvckNhdGVnb3J5KFxuICAgIGNhdGVnb3J5VHJlZTogc3RyaW5nW11cbiAgKTogUHJvbWlzZTxSZWNvcmRUeXBlW10+IHtcbiAgICBjb25zdCByZWNvcmRUeXBlcyA9IGF3YWl0IHRoaXMuZ2V0UmVjb3JkVHlwZXMoKTtcblxuICAgIHJldHVybiByZWNvcmRUeXBlcy5maWx0ZXIoKHgpID0+XG4gICAgICB4LmNhdGVnb3JpZXMuc29tZSgoeSkgPT4gYXJyYXlzRXF1YWwoeSwgY2F0ZWdvcnlUcmVlKSlcbiAgICApO1xuICB9XG59XG4iXX0=
@@ -1,28 +0,0 @@
1
- export var RecordFieldType;
2
- (function (RecordFieldType) {
3
- RecordFieldType["Text"] = "text";
4
- RecordFieldType["Email"] = "email";
5
- RecordFieldType["Url"] = "url";
6
- RecordFieldType["Phone"] = "phone";
7
- RecordFieldType["Date"] = "date";
8
- RecordFieldType["Password"] = "password";
9
- RecordFieldType["TextArea"] = "textArea";
10
- RecordFieldType["Select"] = "select";
11
- RecordFieldType["SingleChoice"] = "singleChoice";
12
- RecordFieldType["MultiChoice"] = "multiChoice";
13
- RecordFieldType["File"] = "file";
14
- RecordFieldType["MultiFile"] = "multiFile";
15
- RecordFieldType["Record"] = "record";
16
- RecordFieldType["MultiRecord"] = "multiRecord";
17
- RecordFieldType["Group"] = "group";
18
- RecordFieldType["Custom"] = "custom";
19
- })(RecordFieldType || (RecordFieldType = {}));
20
- export class RecordType {
21
- }
22
- export class RecordTypeFieldOption {
23
- }
24
- export class RecordTypeField {
25
- }
26
- export class RecordTypeSummary {
27
- }
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLXR5cGUudHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvcmVjb3JkLXR5cGUvcmVjb3JkLXR5cGUudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksZUFpQlg7QUFqQkQsV0FBWSxlQUFlO0lBQ3pCLGdDQUFhLENBQUE7SUFDYixrQ0FBZSxDQUFBO0lBQ2YsOEJBQVcsQ0FBQTtJQUNYLGtDQUFlLENBQUE7SUFDZixnQ0FBYSxDQUFBO0lBQ2Isd0NBQXFCLENBQUE7SUFDckIsd0NBQXFCLENBQUE7SUFDckIsb0NBQWlCLENBQUE7SUFDakIsZ0RBQTZCLENBQUE7SUFDN0IsOENBQTJCLENBQUE7SUFDM0IsZ0NBQWEsQ0FBQTtJQUNiLDBDQUF1QixDQUFBO0lBQ3ZCLG9DQUFpQixDQUFBO0lBQ2pCLDhDQUEyQixDQUFBO0lBQzNCLGtDQUFlLENBQUE7SUFDZixvQ0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBakJXLGVBQWUsS0FBZixlQUFlLFFBaUIxQjtBQUVELE1BQU0sT0FBTyxVQUFVO0NBWXRCO0FBRUQsTUFBTSxPQUFPLHFCQUFxQjtDQUlqQztBQUVELE1BQU0sT0FBTyxlQUFlO0NBWTNCO0FBRUQsTUFBTSxPQUFPLGlCQUFpQjtDQUk3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFJlY29yZEZpZWxkVHlwZSB7XG4gIFRleHQgPSAndGV4dCcsXG4gIEVtYWlsID0gJ2VtYWlsJyxcbiAgVXJsID0gJ3VybCcsXG4gIFBob25lID0gJ3Bob25lJyxcbiAgRGF0ZSA9ICdkYXRlJyxcbiAgUGFzc3dvcmQgPSAncGFzc3dvcmQnLFxuICBUZXh0QXJlYSA9ICd0ZXh0QXJlYScsXG4gIFNlbGVjdCA9ICdzZWxlY3QnLFxuICBTaW5nbGVDaG9pY2UgPSAnc2luZ2xlQ2hvaWNlJyxcbiAgTXVsdGlDaG9pY2UgPSAnbXVsdGlDaG9pY2UnLFxuICBGaWxlID0gJ2ZpbGUnLFxuICBNdWx0aUZpbGUgPSAnbXVsdGlGaWxlJyxcbiAgUmVjb3JkID0gJ3JlY29yZCcsXG4gIE11bHRpUmVjb3JkID0gJ211bHRpUmVjb3JkJyxcbiAgR3JvdXAgPSAnZ3JvdXAnLFxuICBDdXN0b20gPSAnY3VzdG9tJyxcbn1cblxuZXhwb3J0IGNsYXNzIFJlY29yZFR5cGUge1xuICBpZDogc3RyaW5nO1xuICB2ZXJzaW9uOiBudW1iZXI7XG4gIG5hbWU6IHN0cmluZztcbiAgdGFnczogc3RyaW5nW107XG5cbiAgYWxsb3dBdHRhY2htZW50czogYm9vbGVhbjtcbiAgYWxsb3dDdXN0b21GaWVsZHM6IGJvb2xlYW47XG5cbiAgZmllbGRzOiBSZWNvcmRUeXBlRmllbGRbXTtcbiAgY2F0ZWdvcmllczogc3RyaW5nW11bXTtcbiAgY2F0ZWdvcnlOYW1lczogc3RyaW5nW11bXTtcbn1cblxuZXhwb3J0IGNsYXNzIFJlY29yZFR5cGVGaWVsZE9wdGlvbiB7XG4gIG5hbWU6IHN0cmluZztcblxuICBjYXRlZ29yaWVzPzogc3RyaW5nW11bXTtcbn1cblxuZXhwb3J0IGNsYXNzIFJlY29yZFR5cGVGaWVsZCB7XG4gIGlkOiBzdHJpbmc7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHR5cGU6IFJlY29yZEZpZWxkVHlwZTtcbiAgcGxhY2Vob2xkZXI/OiBzdHJpbmc7XG4gIGhpbnQ/OiBzdHJpbmc7XG4gIGlzTWFuZGF0b3J5PzogYm9vbGVhbjtcblxuICBvcHRpb25zPzogUmVjb3JkVHlwZUZpZWxkT3B0aW9uW107XG4gIGV4dGVuc2lvbnM/OiBzdHJpbmc7XG4gIHJlY29yZFR5cGVJZHM/OiBzdHJpbmdbXTtcbiAgZmllbGRzPzogUmVjb3JkVHlwZUZpZWxkW107XG59XG5cbmV4cG9ydCBjbGFzcyBSZWNvcmRUeXBlU3VtbWFyeSB7XG4gIGlkOiBzdHJpbmc7XG4gIHZlcnNpb246IG51bWJlcjtcbiAgbmFtZTogc3RyaW5nO1xufVxuIl19