@things-factory/dataset 6.0.66 → 6.0.69

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 (56) hide show
  1. package/client/pages/data-set/data-set-list-page.ts +1 -1
  2. package/client/pages/data-summary/data-summary-list-page.ts +390 -0
  3. package/client/pages/data-summary/data-summary-search-page.ts +417 -0
  4. package/client/pages/data-summary/data-summary-view.ts +119 -0
  5. package/client/route.ts +12 -0
  6. package/dist-client/pages/data-set/data-set-list-page.js +1 -1
  7. package/dist-client/pages/data-set/data-set-list-page.js.map +1 -1
  8. package/dist-client/pages/data-summary/data-summary-importer.d.ts +22 -0
  9. package/dist-client/pages/data-summary/data-summary-importer.js +100 -0
  10. package/dist-client/pages/data-summary/data-summary-importer.js.map +1 -0
  11. package/dist-client/pages/data-summary/data-summary-list-page.d.ts +57 -0
  12. package/dist-client/pages/data-summary/data-summary-list-page.js +389 -0
  13. package/dist-client/pages/data-summary/data-summary-list-page.js.map +1 -0
  14. package/dist-client/pages/data-summary/data-summary-search-page.d.ts +63 -0
  15. package/dist-client/pages/data-summary/data-summary-search-page.js +407 -0
  16. package/dist-client/pages/data-summary/data-summary-search-page.js.map +1 -0
  17. package/dist-client/pages/data-summary/data-summary-view.d.ts +1 -0
  18. package/dist-client/pages/data-summary/data-summary-view.js +100 -0
  19. package/dist-client/pages/data-summary/data-summary-view.js.map +1 -0
  20. package/dist-client/route.js +9 -0
  21. package/dist-client/route.js.map +1 -1
  22. package/dist-client/tsconfig.tsbuildinfo +1 -1
  23. package/dist-server/controllers/create-data-sample.js +1 -1
  24. package/dist-server/controllers/create-data-sample.js.map +1 -1
  25. package/dist-server/controllers/generate-data-summary.js +94 -0
  26. package/dist-server/controllers/generate-data-summary.js.map +1 -0
  27. package/dist-server/controllers/generate-summary-data.js +88 -0
  28. package/dist-server/controllers/generate-summary-data.js.map +1 -0
  29. package/dist-server/service/data-summary/data-summary-mutation.js +28 -0
  30. package/dist-server/service/data-summary/data-summary-mutation.js.map +1 -0
  31. package/dist-server/service/data-summary/data-summary-query.js +136 -0
  32. package/dist-server/service/data-summary/data-summary-query.js.map +1 -0
  33. package/dist-server/service/data-summary/data-summary-type.js +57 -0
  34. package/dist-server/service/data-summary/data-summary-type.js.map +1 -0
  35. package/dist-server/service/data-summary/data-summary.js +188 -0
  36. package/dist-server/service/data-summary/data-summary.js.map +1 -0
  37. package/dist-server/service/data-summary/index.js +10 -0
  38. package/dist-server/service/data-summary/index.js.map +1 -0
  39. package/dist-server/service/index.js +4 -0
  40. package/dist-server/service/index.js.map +1 -1
  41. package/dist-server/tsconfig.tsbuildinfo +1 -1
  42. package/helps/dataset/data-summary.md +160 -0
  43. package/package.json +10 -10
  44. package/server/controllers/create-data-sample.ts +1 -1
  45. package/server/controllers/generate-data-summary.ts +124 -0
  46. package/server/service/data-summary/data-summary-mutation.ts +19 -0
  47. package/server/service/data-summary/data-summary-query.ts +96 -0
  48. package/server/service/data-summary/data-summary-type.ts +40 -0
  49. package/server/service/data-summary/data-summary.ts +165 -0
  50. package/server/service/data-summary/index.ts +7 -0
  51. package/server/service/index.ts +4 -0
  52. package/things-factory.config.js +10 -1
  53. package/translations/en.json +8 -0
  54. package/translations/ko.json +8 -0
  55. package/translations/ms.json +8 -0
  56. package/translations/zh.json +8 -0
@@ -0,0 +1,160 @@
1
+ # DataSummary
2
+
3
+ Paragraphs are separated by a blank line.
4
+
5
+ 2nd paragraph. _Italic_, **bold**, and `monospace`. Itemized lists
6
+ look like:
7
+
8
+ - this one
9
+ - that one
10
+ - the other one
11
+
12
+ Note that --- not considering the asterisk --- the actual text
13
+ content starts at 4-columns in.
14
+
15
+ > Block quotes are
16
+ > written like so.
17
+ >
18
+ > They can span multiple paragraphs,
19
+ > if you like.
20
+
21
+ Use 3 dashes for an em-dash. Use 2 dashes for ranges (ex., "it's all
22
+ in chapters 12--14"). Three dots ... will be converted to an ellipsis.
23
+ Unicode is supported. ☺
24
+
25
+ ## An h2 header
26
+
27
+ Here's a numbered list:
28
+
29
+ 1. first item
30
+ 2. second item
31
+ 3. third item
32
+
33
+ Note again how the actual text starts at 4 columns in (4 characters
34
+ from the left side). Here's a code sample:
35
+
36
+ # Let me re-iterate ...
37
+
38
+ for i in 1 .. 10 { do-something(i) }
39
+
40
+ As you probably guessed, indented 4 spaces. By the way, instead of
41
+ indenting the block, you can use delimited blocks, if you like:
42
+
43
+ ```
44
+ define foobar() {
45
+ print "Welcome to flavor country!";
46
+ }
47
+ ```
48
+
49
+ (which makes copying & pasting easier). You can optionally mark the
50
+ delimited block for Pandoc to syntax highlight it:
51
+
52
+ ```python
53
+ import time
54
+ # Quick, count to ten!
55
+ for i in range(10):
56
+ # (but not *too* quick)
57
+ time.sleep(0.5)
58
+ print(i)
59
+ ```
60
+
61
+ ### An h3 header
62
+
63
+ Now a nested list:
64
+
65
+ 1. First, get these ingredients:
66
+
67
+ - carrots
68
+ - celery
69
+ - lentils
70
+
71
+ 2. Boil some water.
72
+
73
+ 3. Dump everything in the pot and follow
74
+ this algorithm:
75
+
76
+ find wooden spoon
77
+ uncover pot
78
+ stir
79
+ cover pot
80
+ balance wooden spoon precariously on pot handle
81
+ wait 10 minutes
82
+ goto first step (or shut off burner when done)
83
+
84
+ Do not bump wooden spoon or it will fall.
85
+
86
+ Notice again how text always lines up on 4-space indents (including
87
+ that last line which continues item 3 above).
88
+
89
+ Here's a link to [a website](http://foo.bar), to a [local
90
+ doc](local-doc.html), and to a [section heading in the current
91
+ doc](#an-h2-header). Here's a footnote [^1].
92
+
93
+ [^1]: Some footnote text.
94
+
95
+ Tables can look like this:
96
+
97
+ Name Size Material Color
98
+
99
+ ---
100
+
101
+ All Business 9 leather brown
102
+ Roundabout 10 hemp canvas natural
103
+ Cinderella 11 glass transparent
104
+
105
+ Table: Shoes sizes, materials, and colors.
106
+
107
+ (The above is the caption for the table.) Pandoc also supports
108
+ multi-line tables:
109
+
110
+ ---
111
+
112
+ Keyword Text
113
+
114
+ ---
115
+
116
+ red Sunsets, apples, and
117
+ other red or reddish
118
+ things.
119
+
120
+ green Leaves, grass, frogs
121
+ and other things it's
122
+ not easy being.
123
+
124
+ ---
125
+
126
+ A horizontal rule follows.
127
+
128
+ ---
129
+
130
+ Here's a definition list:
131
+
132
+ apples
133
+ : Good for making applesauce.
134
+
135
+ oranges
136
+ : Citrus!
137
+
138
+ tomatoes
139
+ : There's no "e" in tomatoe.
140
+
141
+ Again, text is indented 4 spaces. (Put a blank line between each
142
+ term and its definition to spread things out more.)
143
+
144
+ Here's a "line block" (note how whitespace is honored):
145
+
146
+ | Line one
147
+ | Line too
148
+ | Line tree
149
+
150
+ and images can be specified like so:
151
+
152
+ ![example image](example-image.jpg 'An exemplary image')
153
+
154
+ Inline math equation: $\omega = d\phi / dt$. Display
155
+ math should get its own line like so:
156
+
157
+ $$I = \int \rho R^{2} dV$$
158
+
159
+ And note that you can backslash-escape any punctuation characters
160
+ which you wish to be displayed literally, ex.: \`foo\`, \*bar\*, etc.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@things-factory/dataset",
3
- "version": "6.0.66",
3
+ "version": "6.0.69",
4
4
  "main": "dist-server/index.js",
5
5
  "browser": "dist-client/index.js",
6
6
  "things-factory": true,
@@ -35,17 +35,17 @@
35
35
  "@operato/shell": "^1.0.1",
36
36
  "@operato/styles": "^1.0.0",
37
37
  "@operato/utils": "^1.0.1",
38
- "@things-factory/auth-base": "^6.0.60",
39
- "@things-factory/aws-base": "^6.0.60",
40
- "@things-factory/board-service": "^6.0.60",
38
+ "@things-factory/auth-base": "^6.0.67",
39
+ "@things-factory/aws-base": "^6.0.67",
40
+ "@things-factory/board-service": "^6.0.69",
41
41
  "@things-factory/env": "^6.0.49",
42
- "@things-factory/organization": "^6.0.60",
43
- "@things-factory/scheduler-client": "^6.0.60",
44
- "@things-factory/shell": "^6.0.60",
45
- "@things-factory/work-shift": "^6.0.60",
46
- "@things-factory/worklist": "^6.0.60",
42
+ "@things-factory/organization": "^6.0.67",
43
+ "@things-factory/scheduler-client": "^6.0.67",
44
+ "@things-factory/shell": "^6.0.67",
45
+ "@things-factory/work-shift": "^6.0.67",
46
+ "@things-factory/worklist": "^6.0.69",
47
47
  "cron-parser": "^4.3.0",
48
48
  "moment-timezone": "^0.5.40"
49
49
  },
50
- "gitHead": "be8f5c22cde7454f21d5bfabc0eb092ef59c0701"
50
+ "gitHead": "d0198bba193b275f29fffd8c3963f556db4dda92"
51
51
  }
@@ -57,7 +57,7 @@ export async function createDataSample(dataSample: NewDataSample, context: Resol
57
57
  const { domain, user, tx } = context.state
58
58
 
59
59
  const dataSet = await tx.getRepository(DataSet).findOne({
60
- where: { id: dataSample.dataSet.id },
60
+ where: { domain: { id: domain.id }, id: dataSample.dataSet.id },
61
61
  relations: ['dataKeySet']
62
62
  })
63
63
 
@@ -0,0 +1,124 @@
1
+ import { Sorting, getQueryBuilderFromListParams } from '@things-factory/shell'
2
+ import { logger } from '@things-factory/env'
3
+
4
+ import { DataSample } from '../service/data-sample/data-sample'
5
+ import { DataSet } from '../service/data-set/data-set'
6
+
7
+ import { DataSummary } from '../service/data-summary/data-summary'
8
+ import { DataKeyItem } from '../service/data-key-set/data-key-item-type'
9
+
10
+ const compareKeys = (dataKeyItems: DataKeyItem[], summary: Partial<DataSummary>, sample: DataSample): boolean => {
11
+ return dataKeyItems.every((item, index) => {
12
+ const prop = `key0${index + 1}`
13
+ return sample[prop] === summary[prop]
14
+ })
15
+ }
16
+
17
+ const buildKeysFromSample = (dataKeyItems: DataKeyItem[], sample: DataSample): Partial<DataSummary> => {
18
+ return dataKeyItems.reduce((sum, item, index) => {
19
+ const prop = `key0${index + 1}`
20
+ sum[prop] = sample[prop]
21
+
22
+ return sum
23
+ }, {} as Partial<DataSummary>)
24
+ }
25
+
26
+ const buildKeySortingList = (dataKeyItems: DataKeyItem[]): Sorting[] => {
27
+ return dataKeyItems.reduce((sum, item, index) => {
28
+ const name = `key0${index + 1}`
29
+ sum.push({ name, desc: true })
30
+ return sum
31
+ }, [])
32
+ }
33
+
34
+ export async function generateDataSummary(
35
+ dataSetId: string,
36
+ workDate: string,
37
+ workShift: string = 'NA',
38
+ context: ResolverContext
39
+ ): Promise<boolean> {
40
+ const { domain, user, tx } = context.state
41
+
42
+ try {
43
+ const dataSet = await tx.getRepository(DataSet).findOne({
44
+ where: { domain: { id: domain.id }, id: dataSetId },
45
+ relations: ['dataKeySet']
46
+ })
47
+
48
+ const dataKeyItems = dataSet.dataKeySet?.dataKeyItems || []
49
+
50
+ const limit = 100
51
+ var page = 1
52
+
53
+ var summaries: Partial<DataSummary>[] = []
54
+ var summary: Partial<DataSummary>
55
+
56
+ do {
57
+ const samples = await getQueryBuilderFromListParams({
58
+ repository: tx.getRepository(DataSample),
59
+ params: {
60
+ filters: [
61
+ { name: 'dataSetId', operator: 'eq', value: dataSetId },
62
+ { name: 'workDate', operator: 'eq', value: workDate },
63
+ { name: 'workShift', operator: 'eq', value: workShift }
64
+ ],
65
+ pagination: { page, limit },
66
+ sortings: [...buildKeySortingList(dataKeyItems), { name: 'collectedAt', desc: true }]
67
+ },
68
+ domain
69
+ }).getMany()
70
+
71
+ for (const sample of samples) {
72
+ if (!summary || !compareKeys(dataKeyItems, summary, sample)) {
73
+ if (summary) {
74
+ summaries.push(summary)
75
+ }
76
+
77
+ summary = {
78
+ domain,
79
+ name: dataSet.name,
80
+ description: dataSet.description,
81
+ workDate,
82
+ workShift,
83
+ dataSet,
84
+ ...buildKeysFromSample(dataKeyItems, sample),
85
+ count: 0,
86
+ countOoc: 0,
87
+ countOos: 0,
88
+ updater: user,
89
+ creator: user
90
+ }
91
+ }
92
+
93
+ summary.count++
94
+ sample.ooc && summary.countOoc++
95
+ sample.oos && summary.countOos++
96
+ }
97
+
98
+ if (samples.length < limit) {
99
+ summary && summaries.push(summary)
100
+ break
101
+ }
102
+
103
+ page++
104
+ } while (true)
105
+
106
+ tx.getRepository(DataSummary).upsert(summaries, [
107
+ 'domain',
108
+ 'dataSet',
109
+ 'key01',
110
+ 'key02',
111
+ 'key03',
112
+ 'key04',
113
+ 'key05',
114
+ 'workDate',
115
+ 'workShift'
116
+ ])
117
+
118
+ return true
119
+ } catch (e) {
120
+ logger.error(e)
121
+ }
122
+
123
+ return false
124
+ }
@@ -0,0 +1,19 @@
1
+ import { Resolver, Mutation, Arg, Ctx, Directive } from 'type-graphql'
2
+
3
+ import { DataSummary } from './data-summary'
4
+
5
+ import { generateDataSummary } from '../../controllers/generate-data-summary'
6
+
7
+ @Resolver(DataSummary)
8
+ export class DataSummaryMutation {
9
+ @Directive('@transaction')
10
+ @Mutation(returns => Boolean, { description: 'To generate new Data Summaries' })
11
+ async generateDataSummaries(
12
+ @Arg('dataSetId') dataSetId: string,
13
+ @Arg('workDate') workDate: string,
14
+ @Arg('workShift') workShift: string,
15
+ @Ctx() context: ResolverContext
16
+ ): Promise<boolean> {
17
+ return await generateDataSummary(dataSetId, workDate, workShift, context)
18
+ }
19
+ }
@@ -0,0 +1,96 @@
1
+ import { Resolver, Query, FieldResolver, Root, Args, Arg, Ctx, Directive } from 'type-graphql'
2
+ import { Domain, getQueryBuilderFromListParams, getRepository, ListParam } from '@things-factory/shell'
3
+ import { User } from '@things-factory/auth-base'
4
+ import { DataKeySet } from '../data-key-set/data-key-set'
5
+ import { DataItem } from '../data-set/data-item-type'
6
+ import { DataSet } from '../data-set/data-set'
7
+ import { DataSetHistory } from '../data-set-history/data-set-history'
8
+ import { DataSummary } from './data-summary'
9
+ import { DataSummaryList } from './data-summary-type'
10
+
11
+ @Resolver(DataSummary)
12
+ export class DataSummaryQuery {
13
+ @Query(returns => DataSummary!, { nullable: true, description: 'To fetch a DataSummary' })
14
+ async dataSummary(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<DataSummary> {
15
+ const { domain } = context.state
16
+
17
+ return await getRepository(DataSummary).findOne({
18
+ where: { domain: { id: domain.id }, id }
19
+ })
20
+ }
21
+
22
+ @Query(returns => DataSummaryList, { description: 'To fetch multiple DataSummaries' })
23
+ async dataSummaries(@Args() params: ListParam, @Ctx() context: ResolverContext): Promise<DataSummaryList> {
24
+ const { domain } = context.state
25
+
26
+ const queryBuilder = getQueryBuilderFromListParams({
27
+ domain,
28
+ params,
29
+ repository: await getRepository(DataSummary),
30
+ searchables: ['name', 'description']
31
+ })
32
+
33
+ const [items, total] = await queryBuilder.getManyAndCount()
34
+
35
+ return { items, total }
36
+ }
37
+
38
+ @Directive('@privilege(category: "data-summary", privilege: "query", domainOwnerGranted: true)')
39
+ @Query(returns => DataSummaryList, { description: 'To fetch multiple data summaries by data key set' })
40
+ async dataSummariesByDataKeySet(
41
+ @Arg('dataKeySetId') dataKeySetId: string,
42
+ @Args() params: ListParam,
43
+ @Ctx() context: ResolverContext
44
+ ): Promise<DataSummaryList> {
45
+ const { domain } = context.state
46
+
47
+ const dataKeySet = await getRepository(DataKeySet).findOneBy({ id: dataKeySetId })
48
+ const dataKeyItems = dataKeySet?.dataKeyItems || []
49
+ const searchables = dataKeyItems.map((item, index) => `key0${index + 1}`)
50
+
51
+ const queryBuilder = getQueryBuilderFromListParams({
52
+ repository: getRepository(DataSummary),
53
+ params,
54
+ domain,
55
+ alias: 'dks',
56
+ searchables: ['name', 'description'].concat(searchables)
57
+ }).innerJoin('dks.dataSet', 'ds', 'ds.dataKeySet = :dataKeySetId', {
58
+ dataKeySetId
59
+ })
60
+
61
+ const [items, total] = await queryBuilder.getManyAndCount()
62
+
63
+ return { items, total }
64
+ }
65
+
66
+ @FieldResolver(type => [DataItem])
67
+ async dataItems(@Root() dataSummary: DataSummary): Promise<DataItem[]> {
68
+ const dataSetHistory: DataSetHistory = await getRepository(DataSetHistory).findOne({
69
+ where: {
70
+ originalId: dataSummary.dataSetId,
71
+ version: dataSummary.dataSetVersion
72
+ }
73
+ })
74
+ return dataSetHistory?.dataItems || []
75
+ }
76
+
77
+ @FieldResolver(type => DataSet)
78
+ async dataSet(@Root() dataSummary: DataSummary): Promise<DataSet> {
79
+ return await getRepository(DataSet).findOneBy({ id: dataSummary.dataSetId })
80
+ }
81
+
82
+ @FieldResolver(type => Domain)
83
+ async domain(@Root() dataSummary: DataSummary): Promise<Domain> {
84
+ return await getRepository(Domain).findOneBy({ id: dataSummary.domainId })
85
+ }
86
+
87
+ @FieldResolver(type => User)
88
+ async updater(@Root() dataSummary: DataSummary): Promise<User> {
89
+ return await getRepository(User).findOneBy({ id: dataSummary.updaterId })
90
+ }
91
+
92
+ @FieldResolver(type => User)
93
+ async creator(@Root() dataSummary: DataSummary): Promise<User> {
94
+ return await getRepository(User).findOneBy({ id: dataSummary.creatorId })
95
+ }
96
+ }
@@ -0,0 +1,40 @@
1
+ import type { FileUpload } from 'graphql-upload/GraphQLUpload.js'
2
+ import GraphQLUpload from 'graphql-upload/GraphQLUpload.js'
3
+ import { ObjectType, Field, InputType, Int, ID, registerEnumType } from 'type-graphql'
4
+
5
+ import { ObjectRef, ScalarObject } from '@things-factory/shell'
6
+
7
+ import { DataSummary, DataSummaryDurationType } from './data-summary'
8
+
9
+ @InputType()
10
+ export class NewDataSummary {
11
+ @Field()
12
+ name: string
13
+
14
+ @Field({ nullable: true })
15
+ description?: string
16
+ }
17
+
18
+ @InputType()
19
+ export class DataSummaryPatch {
20
+ @Field(type => ID, { nullable: true })
21
+ id?: string
22
+
23
+ @Field({ nullable: true })
24
+ name?: string
25
+
26
+ @Field({ nullable: true })
27
+ description?: string
28
+
29
+ @Field({ nullable: true })
30
+ cuFlag?: string
31
+ }
32
+
33
+ @ObjectType()
34
+ export class DataSummaryList {
35
+ @Field(type => [DataSummary])
36
+ items: DataSummary[]
37
+
38
+ @Field(type => Int)
39
+ total: number
40
+ }
@@ -0,0 +1,165 @@
1
+ import {
2
+ CreateDateColumn,
3
+ UpdateDateColumn,
4
+ Entity,
5
+ Index,
6
+ Column,
7
+ RelationId,
8
+ ManyToOne,
9
+ PrimaryGeneratedColumn
10
+ } from 'typeorm'
11
+ import { ObjectType, Field, Int, ID, registerEnumType } from 'type-graphql'
12
+
13
+ import { Domain, ScalarObject } from '@things-factory/shell'
14
+ import { User } from '@things-factory/auth-base'
15
+
16
+ import { DataItem } from '../data-set/data-item-type'
17
+ import { DataSet } from '../data-set/data-set'
18
+
19
+ export enum DataSummaryDurationType {
20
+ Shift = 'shift',
21
+ Daily = 'daily',
22
+ Weekly = 'weekly',
23
+ Monthly = 'monthly',
24
+ Quarterly = 'quarterly',
25
+ Yearly = 'yearly',
26
+ Custom = 'custom'
27
+ }
28
+
29
+ registerEnumType(DataSummaryDurationType, {
30
+ name: 'DataSummaryDurationType',
31
+ description: 'entry type enumeration for data-summary'
32
+ })
33
+
34
+ @Entity()
35
+ @Index(
36
+ 'ix_data_summary_0',
37
+ (dataSummary: DataSummary) => [
38
+ dataSummary.domain,
39
+ dataSummary.dataSet,
40
+ dataSummary.key01,
41
+ dataSummary.key02,
42
+ dataSummary.key03,
43
+ dataSummary.key05,
44
+ dataSummary.key04,
45
+ dataSummary.workDate,
46
+ dataSummary.workShift
47
+ ],
48
+ { unique: true }
49
+ )
50
+ @Index(
51
+ 'ix_data_summary_1',
52
+ (dataSummary: DataSummary) => [dataSummary.domain, dataSummary.dataSet, dataSummary.workDate, dataSummary.workShift],
53
+ { unique: false }
54
+ )
55
+ @ObjectType({ description: 'Entity for DataSummary' })
56
+ export class DataSummary {
57
+ @PrimaryGeneratedColumn('uuid')
58
+ @Field(type => ID)
59
+ readonly id: string
60
+
61
+ @ManyToOne(type => Domain)
62
+ @Field({ nullable: true })
63
+ domain?: Domain
64
+
65
+ @RelationId((dataSummary: DataSummary) => dataSummary.domain)
66
+ domainId?: string
67
+
68
+ @Column()
69
+ @Field({ nullable: true })
70
+ name?: string
71
+
72
+ @Column({ nullable: true })
73
+ @Field({ nullable: true })
74
+ description?: string
75
+
76
+ @Column({ nullable: true })
77
+ @Field({ nullable: true })
78
+ type?: DataSummaryDurationType
79
+
80
+ @Column({ nullable: true })
81
+ @Field({ nullable: true })
82
+ workDate?: string
83
+
84
+ @Column({ nullable: true, default: 'NA' })
85
+ @Field({ nullable: true })
86
+ workShift?: string = 'NA'
87
+
88
+ @ManyToOne(type => DataSet)
89
+ @Field(type => DataSet, { nullable: false })
90
+ dataSet?: DataSet
91
+
92
+ @RelationId((dataSample: DataSummary) => dataSample.dataSet)
93
+ dataSetId?: string
94
+
95
+ @Column({ nullable: true })
96
+ @Field({ nullable: true })
97
+ dataSetVersion?: number
98
+
99
+ @Field(type => [DataItem], { nullable: true })
100
+ dataItems?: DataItem[]
101
+
102
+ @Column('simple-json', { nullable: true })
103
+ @Field(type => ScalarObject, { nullable: true })
104
+ summary?: any
105
+
106
+ @Column({
107
+ nullable: true
108
+ })
109
+ @Field({ nullable: true })
110
+ count?: number
111
+
112
+ @Column({
113
+ nullable: true
114
+ })
115
+ @Field({ nullable: true })
116
+ countOoc?: number
117
+
118
+ @Column({
119
+ nullable: true
120
+ })
121
+ @Field({ nullable: true })
122
+ countOos?: number
123
+
124
+ @Column({ nullable: true, default: '' })
125
+ @Field({ nullable: true })
126
+ key01?: string = ''
127
+
128
+ @Column({ nullable: true, default: '' })
129
+ @Field({ nullable: true })
130
+ key02?: string = ''
131
+
132
+ @Column({ nullable: true, default: '' })
133
+ @Field({ nullable: true })
134
+ key03?: string = ''
135
+
136
+ @Column({ nullable: true, default: '' })
137
+ @Field({ nullable: true })
138
+ key04?: string = ''
139
+
140
+ @Column({ nullable: true, default: '' })
141
+ @Field({ nullable: true })
142
+ key05?: string = ''
143
+
144
+ @CreateDateColumn()
145
+ @Field({ nullable: true })
146
+ createdAt?: Date
147
+
148
+ @UpdateDateColumn()
149
+ @Field({ nullable: true })
150
+ updatedAt?: Date
151
+
152
+ @ManyToOne(type => User, { nullable: true })
153
+ @Field(type => User, { nullable: true })
154
+ creator?: User
155
+
156
+ @RelationId((dataSummary: DataSummary) => dataSummary.creator)
157
+ creatorId?: string
158
+
159
+ @ManyToOne(type => User, { nullable: true })
160
+ @Field(type => User, { nullable: true })
161
+ updater?: User
162
+
163
+ @RelationId((dataSummary: DataSummary) => dataSummary.updater)
164
+ updaterId?: string
165
+ }
@@ -0,0 +1,7 @@
1
+ import { DataSummary } from './data-summary'
2
+ import { DataSummaryQuery } from './data-summary-query'
3
+ import { DataSummaryMutation } from './data-summary-mutation'
4
+
5
+ export const entities = [DataSummary]
6
+ export const resolvers = [DataSummaryQuery, DataSummaryMutation]
7
+ export const subscribers = []
@@ -8,10 +8,12 @@ import {
8
8
  resolvers as DataSetHistoryResolvers,
9
9
  subscribers as DataSetHistorySubscribers
10
10
  } from './data-set-history'
11
+ import { entities as DataSummaryEntities, resolvers as DataSummaryResolvers } from './data-summary'
11
12
  import { entities as DataSpecEntities, resolvers as DataSpecResolvers } from './data-spec'
12
13
  import { entities as DataArchiveEntities, resolvers as DataArchiveResolvers } from './data-archive'
13
14
 
14
15
  /* EXPORT ENTITY TYPES */
16
+ export * from './data-summary/data-summary'
15
17
  export * from './data-key-set/data-key-set'
16
18
  export * from './data-ooc/data-ooc'
17
19
  export * from './data-sensor/data-sensor'
@@ -23,6 +25,7 @@ export * from './data-spec/data-spec'
23
25
 
24
26
  export const entities = [
25
27
  /* ENTITIES */
28
+ ...DataSummaryEntities,
26
29
  ...DataKeySetEntities,
27
30
  ...DataOocEntities,
28
31
  ...DataSensorEntities,
@@ -41,6 +44,7 @@ export const subscribers = [
41
44
  export const schema = {
42
45
  resolverClasses: [
43
46
  /* RESOLVER CLASSES */
47
+ ...DataSummaryResolvers,
44
48
  ...DataKeySetResolvers,
45
49
  ...DataOocResolvers,
46
50
  ...DataSensorResolvers,