@things-factory/warehouse-base 5.0.14 → 6.0.0-alpha.3

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 (142) hide show
  1. package/dist-server/controllers/ecommerce/ecommerce-controller.js +1 -1
  2. package/dist-server/controllers/ecommerce/ecommerce-controller.js.map +1 -1
  3. package/dist-server/controllers/ecommerce/sellercraft-controller.js +64 -60
  4. package/dist-server/controllers/ecommerce/sellercraft-controller.js.map +1 -1
  5. package/dist-server/controllers/warehouse-controller.js +7 -5
  6. package/dist-server/controllers/warehouse-controller.js.map +1 -1
  7. package/dist-server/service/inventory/inventory-mutation.js +6 -6
  8. package/dist-server/service/inventory/inventory-mutation.js.map +1 -1
  9. package/dist-server/service/inventory/inventory-query.js +217 -195
  10. package/dist-server/service/inventory/inventory-query.js.map +1 -1
  11. package/dist-server/service/inventory/inventory-types.js +14 -15
  12. package/dist-server/service/inventory/inventory-types.js.map +1 -1
  13. package/dist-server/service/inventory/inventory.js +62 -42
  14. package/dist-server/service/inventory/inventory.js.map +1 -1
  15. package/dist-server/service/inventory-change/inventory-change-mutation.js +252 -216
  16. package/dist-server/service/inventory-change/inventory-change-mutation.js.map +1 -1
  17. package/dist-server/service/inventory-change/inventory-change-query.js +6 -7
  18. package/dist-server/service/inventory-change/inventory-change-query.js.map +1 -1
  19. package/dist-server/service/inventory-change/inventory-change.js +7 -7
  20. package/dist-server/service/inventory-change/inventory-change.js.map +1 -1
  21. package/dist-server/service/inventory-history/inventory-history-mutation.js +1 -1
  22. package/dist-server/service/inventory-history/inventory-history-mutation.js.map +1 -1
  23. package/dist-server/service/inventory-history/inventory-history-query.js +89 -99
  24. package/dist-server/service/inventory-history/inventory-history-query.js.map +1 -1
  25. package/dist-server/service/inventory-history/inventory-history-types.js +3 -3
  26. package/dist-server/service/inventory-history/inventory-history-types.js.map +1 -1
  27. package/dist-server/service/inventory-history/inventory-history.js +7 -7
  28. package/dist-server/service/inventory-history/inventory-history.js.map +1 -1
  29. package/dist-server/service/inventory-item/inventory-item-mutation.js +10 -10
  30. package/dist-server/service/inventory-item/inventory-item-mutation.js.map +1 -1
  31. package/dist-server/service/inventory-item/inventory-item-query.js +18 -17
  32. package/dist-server/service/inventory-item/inventory-item-query.js.map +1 -1
  33. package/dist-server/service/inventory-item/inventory-item-type.js +4 -5
  34. package/dist-server/service/inventory-item/inventory-item-type.js.map +1 -1
  35. package/dist-server/service/inventory-item/inventory-item.js +5 -5
  36. package/dist-server/service/inventory-item/inventory-item.js.map +1 -1
  37. package/dist-server/service/inventory-item-change/inventory-item-change-mutation.js +4 -4
  38. package/dist-server/service/inventory-item-change/inventory-item-change-mutation.js.map +1 -1
  39. package/dist-server/service/inventory-item-change/inventory-item-change-query.js +7 -9
  40. package/dist-server/service/inventory-item-change/inventory-item-change-query.js.map +1 -1
  41. package/dist-server/service/inventory-item-change/inventory-item-change-type.js +6 -7
  42. package/dist-server/service/inventory-item-change/inventory-item-change-type.js.map +1 -1
  43. package/dist-server/service/inventory-item-change/inventory-item-change.js +3 -4
  44. package/dist-server/service/inventory-item-change/inventory-item-change.js.map +1 -1
  45. package/dist-server/service/inventory-product/inventory-product-mutation.js +4 -4
  46. package/dist-server/service/inventory-product/inventory-product-mutation.js.map +1 -1
  47. package/dist-server/service/inventory-product/inventory-product-query.js +7 -9
  48. package/dist-server/service/inventory-product/inventory-product-query.js.map +1 -1
  49. package/dist-server/service/inventory-product/inventory-product-type.js +1 -2
  50. package/dist-server/service/inventory-product/inventory-product-type.js.map +1 -1
  51. package/dist-server/service/inventory-product/inventory-product.js +5 -5
  52. package/dist-server/service/inventory-product/inventory-product.js.map +1 -1
  53. package/dist-server/service/location/location-mutation.js +5 -5
  54. package/dist-server/service/location/location-mutation.js.map +1 -1
  55. package/dist-server/service/location/location-query.js +17 -19
  56. package/dist-server/service/location/location-query.js.map +1 -1
  57. package/dist-server/service/location/location-types.js +3 -3
  58. package/dist-server/service/location/location-types.js.map +1 -1
  59. package/dist-server/service/location/location.js +14 -14
  60. package/dist-server/service/location/location.js.map +1 -1
  61. package/dist-server/service/movement/movement-mutation.js +6 -5
  62. package/dist-server/service/movement/movement-mutation.js.map +1 -1
  63. package/dist-server/service/movement/movement-query.js +15 -15
  64. package/dist-server/service/movement/movement-query.js.map +1 -1
  65. package/dist-server/service/movement/movement-types.js +4 -5
  66. package/dist-server/service/movement/movement-types.js.map +1 -1
  67. package/dist-server/service/movement/movement.js +5 -5
  68. package/dist-server/service/movement/movement.js.map +1 -1
  69. package/dist-server/service/pallet/pallet-mutation.js +5 -5
  70. package/dist-server/service/pallet/pallet-mutation.js.map +1 -1
  71. package/dist-server/service/pallet/pallet-query.js +9 -11
  72. package/dist-server/service/pallet/pallet-query.js.map +1 -1
  73. package/dist-server/service/pallet/pallet-types.js +5 -6
  74. package/dist-server/service/pallet/pallet-types.js.map +1 -1
  75. package/dist-server/service/pallet/pallet.js +6 -6
  76. package/dist-server/service/pallet/pallet.js.map +1 -1
  77. package/dist-server/service/pallet-count/pallet-count-mutation.js +1 -1
  78. package/dist-server/service/pallet-count/pallet-count-mutation.js.map +1 -1
  79. package/dist-server/service/pallet-count/pallet-count-query.js +6 -8
  80. package/dist-server/service/pallet-count/pallet-count-query.js.map +1 -1
  81. package/dist-server/service/pallet-count/pallet-count.js +3 -4
  82. package/dist-server/service/pallet-count/pallet-count.js.map +1 -1
  83. package/dist-server/service/pallet-history/pallet-history-mutation.js +1 -1
  84. package/dist-server/service/pallet-history/pallet-history-mutation.js.map +1 -1
  85. package/dist-server/service/pallet-history/pallet-history-query.js +6 -8
  86. package/dist-server/service/pallet-history/pallet-history-query.js.map +1 -1
  87. package/dist-server/service/pallet-history/pallet-history.js +6 -6
  88. package/dist-server/service/pallet-history/pallet-history.js.map +1 -1
  89. package/dist-server/service/reduced-inventory-history/reduced-inventory-history.js +1 -1
  90. package/dist-server/service/reduced-inventory-history/reduced-inventory-history.js.map +1 -1
  91. package/dist-server/service/tote/tote-mutation.js +4 -4
  92. package/dist-server/service/tote/tote-mutation.js.map +1 -1
  93. package/dist-server/service/tote/tote-query.js +12 -13
  94. package/dist-server/service/tote/tote-query.js.map +1 -1
  95. package/dist-server/service/tote/tote-types.js +2 -3
  96. package/dist-server/service/tote/tote-types.js.map +1 -1
  97. package/dist-server/service/tote/tote.js +5 -5
  98. package/dist-server/service/tote/tote.js.map +1 -1
  99. package/dist-server/service/warehouse/warehouse-mutation.js +1 -1
  100. package/dist-server/service/warehouse/warehouse-mutation.js.map +1 -1
  101. package/dist-server/service/warehouse/warehouse-query.js +9 -10
  102. package/dist-server/service/warehouse/warehouse-query.js.map +1 -1
  103. package/dist-server/service/warehouse/warehouse.js +12 -12
  104. package/dist-server/service/warehouse/warehouse.js.map +1 -1
  105. package/dist-server/tsconfig.tsbuildinfo +1 -1
  106. package/dist-server/utils/inventory-util.js +16 -16
  107. package/dist-server/utils/inventory-util.js.map +1 -1
  108. package/package.json +8 -8
  109. package/server/controllers/ecommerce/ecommerce-controller.ts +1 -1
  110. package/server/controllers/ecommerce/sellercraft-controller.ts +75 -65
  111. package/server/controllers/warehouse-controller.ts +9 -4
  112. package/server/service/inventory/inventory-mutation.ts +28 -24
  113. package/server/service/inventory/inventory-query.ts +269 -304
  114. package/server/service/inventory/inventory.ts +50 -35
  115. package/server/service/inventory-change/inventory-change-mutation.ts +305 -256
  116. package/server/service/inventory-change/inventory-change-query.ts +9 -9
  117. package/server/service/inventory-history/inventory-history-mutation.ts +12 -15
  118. package/server/service/inventory-history/inventory-history-query.ts +158 -133
  119. package/server/service/inventory-item/inventory-item-mutation.ts +20 -17
  120. package/server/service/inventory-item/inventory-item-query.ts +28 -18
  121. package/server/service/inventory-item-change/inventory-item-change-mutation.ts +12 -9
  122. package/server/service/inventory-item-change/inventory-item-change-query.ts +10 -8
  123. package/server/service/inventory-product/inventory-product-mutation.ts +16 -12
  124. package/server/service/inventory-product/inventory-product-query.ts +7 -8
  125. package/server/service/location/location-mutation.ts +24 -24
  126. package/server/service/location/location-query.ts +27 -23
  127. package/server/service/location/location.ts +11 -10
  128. package/server/service/movement/movement-mutation.ts +7 -8
  129. package/server/service/movement/movement-query.ts +18 -16
  130. package/server/service/pallet/pallet-mutation.ts +18 -20
  131. package/server/service/pallet/pallet-query.ts +13 -14
  132. package/server/service/pallet-count/pallet-count-mutation.ts +20 -17
  133. package/server/service/pallet-count/pallet-count-query.ts +6 -7
  134. package/server/service/pallet-history/pallet-history-mutation.ts +15 -15
  135. package/server/service/pallet-history/pallet-history-query.ts +7 -8
  136. package/server/service/reduced-inventory-history/reduced-inventory-history.ts +1 -1
  137. package/server/service/tote/tote-mutation.ts +23 -22
  138. package/server/service/tote/tote-query.ts +18 -14
  139. package/server/service/warehouse/warehouse-mutation.ts +21 -18
  140. package/server/service/warehouse/warehouse-query.ts +11 -11
  141. package/server/service/warehouse/warehouse.ts +7 -7
  142. package/server/utils/inventory-util.ts +10 -10
@@ -1 +1 @@
1
- {"version":3,"file":"inventory-product.js","sourceRoot":"","sources":["../../../server/service/inventory-product/inventory-product.ts"],"names":[],"mappings":"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","sourcesContent":["import { Field, ID, ObjectType } from 'type-graphql'\nimport {\n Column,\n CreateDateColumn,\n Entity,\n Index,\n ManyToOne,\n PrimaryGeneratedColumn,\n RelationId,\n UpdateDateColumn\n} from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Product } from '@things-factory/product-base'\nimport { Domain } from '@things-factory/shell'\n\n@Entity()\n@Index(\n 'ix_inventory_product_0',\n (inventoryProduct: InventoryProduct) => [inventoryProduct.domain, inventoryProduct.name],\n { unique: true }\n)\n@ObjectType({ description: 'Entity for InventoryProduct' })\nexport class InventoryProduct {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field({ nullable: true })\n domain?: Domain\n\n @RelationId((inventoryProduct: InventoryProduct) => inventoryProduct.domain)\n domainId?: string\n\n @Column()\n @Field()\n name: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n serialNumber?: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n status?: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n arrivalNoticeId: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n releaseGoodId: string\n\n @ManyToOne(type => Product)\n @Field({ nullable: true })\n product?: Product\n\n @RelationId((inventoryProduct: InventoryProduct) => inventoryProduct.product)\n productId?: string\n\n @CreateDateColumn()\n @Field({ nullable: true })\n createdAt?: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true })\n updatedAt?: Date\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n creator?: User\n\n @RelationId((inventoryProduct: InventoryProduct) => inventoryProduct.creator)\n creatorId?: string\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n updater?: User\n\n @RelationId((inventoryProduct: InventoryProduct) => inventoryProduct.creator)\n updaterId?: string\n}\n"]}
1
+ {"version":3,"file":"inventory-product.js","sourceRoot":"","sources":["../../../server/service/inventory-product/inventory-product.ts"],"names":[],"mappings":"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","sourcesContent":["import { Field, ID, ObjectType } from 'type-graphql'\nimport {\n Column,\n CreateDateColumn,\n Entity,\n Index,\n ManyToOne,\n PrimaryGeneratedColumn,\n RelationId,\n UpdateDateColumn\n} from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Product } from '@things-factory/product-base'\nimport { Domain } from '@things-factory/shell'\n\n@Entity()\n@Index(\n 'ix_inventory_product_0',\n (inventoryProduct: InventoryProduct) => [inventoryProduct.domain, inventoryProduct.name],\n { unique: true }\n)\n@ObjectType({ description: 'Entity for InventoryProduct' })\nexport class InventoryProduct {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field({ nullable: true })\n domain?: Domain\n\n @RelationId((inventoryProduct: InventoryProduct) => inventoryProduct.domain)\n domainId?: string\n\n @Column()\n @Field()\n name: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n serialNumber?: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n status?: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n arrivalNoticeId: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n releaseGoodId: string\n\n @ManyToOne(type => Product)\n @Field({ nullable: true })\n product?: Product\n\n @RelationId((inventoryProduct: InventoryProduct) => inventoryProduct.product)\n productId?: string\n\n @CreateDateColumn()\n @Field({ nullable: true })\n createdAt?: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true })\n updatedAt?: Date\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n creator?: User\n\n @RelationId((inventoryProduct: InventoryProduct) => inventoryProduct.creator)\n creatorId?: string\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n updater?: User\n\n @RelationId((inventoryProduct: InventoryProduct) => inventoryProduct.creator)\n updaterId?: string\n}\n"]}
@@ -11,7 +11,7 @@ let LocationMutation = class LocationMutation {
11
11
  return await createLocation(location, context);
12
12
  }
13
13
  async updateLocation(id, patch, context) {
14
- return await updateLocation(id, patch, context.state.user);
14
+ return await updateLocation(id, patch, context);
15
15
  }
16
16
  async updateMultipleLocation(patches, context) {
17
17
  let results = [];
@@ -42,7 +42,7 @@ let LocationMutation = class LocationMutation {
42
42
  async deleteAllLocations(warehouseId, context) {
43
43
  const { tx } = context.state;
44
44
  await tx.getRepository(location_1.Location).delete({
45
- warehouse: await tx.getRepository(warehouse_1.Warehouse).findOne(warehouseId)
45
+ warehouse: { id: warehouseId }
46
46
  });
47
47
  }
48
48
  };
@@ -115,16 +115,16 @@ async function createLocation(location, context) {
115
115
  const { domain, user, tx } = context.state;
116
116
  const locationRepository = tx.getRepository(location_1.Location);
117
117
  const warehouseRepository = tx.getRepository(warehouse_1.Warehouse);
118
- return await locationRepository.save(Object.assign(Object.assign({}, location), { warehouse: await warehouseRepository.findOne(location.warehouse.id), domain, creator: user, updater: user }));
118
+ return await locationRepository.save(Object.assign(Object.assign({}, location), { warehouse: await warehouseRepository.findOneBy({ id: location.warehouse.id }), domain, creator: user, updater: user }));
119
119
  }
120
120
  exports.createLocation = createLocation;
121
121
  async function updateLocation(id, patch, context) {
122
122
  const { user, tx } = context.state;
123
123
  const locationRepository = tx.getRepository(location_1.Location);
124
124
  const warehouseRepository = tx.getRepository(warehouse_1.Warehouse);
125
- const location = await locationRepository.findOne(id);
125
+ const location = await locationRepository.findOneBy({ id });
126
126
  if (patch.warehouse && patch.warehouse.id) {
127
- patch.warehouse = await warehouseRepository.findOne(patch.warehouse.id);
127
+ patch.warehouse = await warehouseRepository.findOneBy({ id: patch.warehouse.id });
128
128
  }
129
129
  return await locationRepository.save(Object.assign(Object.assign(Object.assign({}, location), patch), { updater: user }));
130
130
  }
@@ -1 +1 @@
1
- {"version":3,"file":"location-mutation.js","sourceRoot":"","sources":["../../../server/service/location/location-mutation.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Ctx, Directive, Mutation, Resolver } from 'type-graphql'\nimport { EntityManager, Repository } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain } from '@things-factory/shell'\n\nimport { Location } from '../location/location'\nimport { Warehouse } from '../warehouse/warehouse'\nimport { LocationPatch, NewLocation } from './location-types'\n\n@Resolver(Location)\nexport class LocationMutation {\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Location)\n async createLocation(@Arg('location') location: NewLocation, @Ctx() context: any): Promise<Location> {\n return await createLocation(location, context)\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Location)\n async updateLocation(\n @Arg('id') id: string,\n @Arg('patch') patch: LocationPatch,\n @Ctx() context: any\n ): Promise<Location> {\n return await updateLocation(id, patch, context.state.user)\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => [Location])\n async updateMultipleLocation(\n @Arg('patches', type => [LocationPatch]) patches: LocationPatch[],\n @Ctx() context: any\n ): Promise<Location[]> {\n let results = []\n const _createRecords = patches.filter((patch: any) => patch.cuFlag === '+')\n const _updateRecords = patches.filter((patch: any) => patch.cuFlag.toUpperCase() === 'M')\n\n if (_createRecords.length > 0) {\n for (let i = 0; i < _createRecords.length; i++) {\n const patch = _createRecords[i]\n const result = await createLocation(patch as NewLocation, context)\n results.push({ ...result, cuFlag: '+' })\n }\n }\n\n if (_updateRecords.length > 0) {\n for (let i = 0; i < _updateRecords.length; i++) {\n const patch: LocationPatch = _updateRecords[i]\n const result = await updateLocation(patch.id, patch, context)\n results.push({ ...result, cuFlag: 'M' })\n }\n }\n\n return results\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Boolean)\n async deleteLocation(@Arg('id') id: string, @Ctx() context: any): Promise<Boolean> {\n return await deleteLocation(id, context)\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Boolean)\n async deleteLocations(@Arg('ids', type => [String]) ids: string[], @Ctx() context: any): Promise<Boolean> {\n return await deleteLocations(ids, context)\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Boolean)\n async deleteAllLocations(@Arg('warehouseId') warehouseId: string, @Ctx() context: any) {\n const { tx }: { tx: EntityManager } = context.state\n\n await tx.getRepository(Location).delete({\n warehouse: await tx.getRepository(Warehouse).findOne(warehouseId)\n })\n }\n}\n\nexport async function createLocation(location: NewLocation, context: any) {\n const { domain, user, tx }: { domain: Domain; user: User; tx: EntityManager } = context.state\n\n const locationRepository: Repository<Location> = tx.getRepository(Location)\n const warehouseRepository: Repository<Warehouse> = tx.getRepository(Warehouse)\n\n return await locationRepository.save({\n ...location,\n warehouse: await warehouseRepository.findOne(location.warehouse.id),\n domain,\n creator: user,\n updater: user\n })\n}\n\nexport async function updateLocation(id: string, patch: LocationPatch, context: any) {\n const { user, tx }: { user: User; tx: EntityManager } = context.state\n\n const locationRepository: Repository<Location> = tx.getRepository(Location)\n const warehouseRepository: Repository<Warehouse> = tx.getRepository(Warehouse)\n const location: Location = await locationRepository.findOne(id)\n\n if (patch.warehouse && patch.warehouse.id) {\n patch.warehouse = await warehouseRepository.findOne(patch.warehouse.id)\n }\n\n return await locationRepository.save({\n ...location,\n ...patch,\n updater: user\n })\n}\n\nexport async function deleteLocation(id: string, context: any) {\n const { tx }: { tx: EntityManager } = context.state\n\n const repository: Repository<Location> = tx.getRepository(Location)\n await repository.delete(id)\n return true\n}\n\nexport async function deleteLocations(ids: string[], context: any) {\n const { tx }: { tx: EntityManager } = context.state\n\n const repository: Repository<Location> = tx.getRepository(Location)\n await repository.delete(ids)\n return true\n}\n"]}
1
+ {"version":3,"file":"location-mutation.js","sourceRoot":"","sources":["../../../server/service/location/location-mutation.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Ctx, Directive, Mutation, Resolver } from 'type-graphql'\nimport { Repository } from 'typeorm'\n\nimport { Location } from '../location/location'\nimport { Warehouse } from '../warehouse/warehouse'\nimport { LocationPatch, NewLocation } from './location-types'\n\n@Resolver(Location)\nexport class LocationMutation {\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Location)\n async createLocation(@Arg('location') location: NewLocation, @Ctx() context: ResolverContext): Promise<Location> {\n return await createLocation(location, context)\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Location)\n async updateLocation(\n @Arg('id') id: string,\n @Arg('patch') patch: LocationPatch,\n @Ctx() context: ResolverContext\n ): Promise<Location> {\n return await updateLocation(id, patch, context)\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => [Location])\n async updateMultipleLocation(\n @Arg('patches', type => [LocationPatch]) patches: LocationPatch[],\n @Ctx() context: ResolverContext\n ): Promise<Location[]> {\n let results = []\n const _createRecords = patches.filter((patch: any) => patch.cuFlag === '+')\n const _updateRecords = patches.filter((patch: any) => patch.cuFlag.toUpperCase() === 'M')\n\n if (_createRecords.length > 0) {\n for (let i = 0; i < _createRecords.length; i++) {\n const patch = _createRecords[i]\n const result = await createLocation(patch as NewLocation, context)\n results.push({ ...result, cuFlag: '+' })\n }\n }\n\n if (_updateRecords.length > 0) {\n for (let i = 0; i < _updateRecords.length; i++) {\n const patch: LocationPatch = _updateRecords[i]\n const result = await updateLocation(patch.id, patch, context)\n results.push({ ...result, cuFlag: 'M' })\n }\n }\n\n return results\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Boolean)\n async deleteLocation(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<Boolean> {\n return await deleteLocation(id, context)\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Boolean)\n async deleteLocations(\n @Arg('ids', type => [String]) ids: string[],\n @Ctx() context: ResolverContext\n ): Promise<Boolean> {\n return await deleteLocations(ids, context)\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Boolean)\n async deleteAllLocations(@Arg('warehouseId') warehouseId: string, @Ctx() context: ResolverContext) {\n const { tx } = context.state\n\n await tx.getRepository(Location).delete({\n warehouse: { id: warehouseId }\n })\n }\n}\n\nexport async function createLocation(location: NewLocation, context: ResolverContext) {\n const { domain, user, tx } = context.state\n\n const locationRepository: Repository<Location> = tx.getRepository(Location)\n const warehouseRepository: Repository<Warehouse> = tx.getRepository(Warehouse)\n\n return await locationRepository.save({\n ...location,\n warehouse: await warehouseRepository.findOneBy({ id: location.warehouse.id }),\n domain,\n creator: user,\n updater: user\n })\n}\n\nexport async function updateLocation(id: string, patch: LocationPatch, context: ResolverContext) {\n const { user, tx } = context.state\n\n const locationRepository: Repository<Location> = tx.getRepository(Location)\n const warehouseRepository: Repository<Warehouse> = tx.getRepository(Warehouse)\n const location: Location = await locationRepository.findOneBy({ id })\n\n if (patch.warehouse && patch.warehouse.id) {\n patch.warehouse = await warehouseRepository.findOneBy({ id: patch.warehouse.id })\n }\n\n return await locationRepository.save({\n ...location,\n ...patch,\n updater: user\n })\n}\n\nexport async function deleteLocation(id: string, context: ResolverContext) {\n const { tx } = context.state\n\n const repository: Repository<Location> = tx.getRepository(Location)\n await repository.delete(id)\n return true\n}\n\nexport async function deleteLocations(ids: string[], context: ResolverContext) {\n const { tx } = context.state\n\n const repository: Repository<Location> = tx.getRepository(Location)\n await repository.delete(ids)\n return true\n}\n"]}
@@ -1,10 +1,8 @@
1
1
  "use strict";
2
- var _a, _b, _c, _d;
3
2
  Object.defineProperty(exports, "__esModule", { value: true });
4
3
  exports.LocationQuery = void 0;
5
4
  const tslib_1 = require("tslib");
6
5
  const type_graphql_1 = require("type-graphql");
7
- const typeorm_1 = require("typeorm");
8
6
  const auth_base_1 = require("@things-factory/auth-base");
9
7
  const biz_base_1 = require("@things-factory/biz-base");
10
8
  const shell_1 = require("@things-factory/shell");
@@ -14,7 +12,7 @@ const location_1 = require("./location");
14
12
  const location_types_1 = require("./location-types");
15
13
  let LocationQuery = class LocationQuery {
16
14
  async locations(params, context) {
17
- const queryBuilder = (0, typeorm_1.getRepository)(location_1.Location).createQueryBuilder();
15
+ const queryBuilder = (0, shell_1.getRepository)(location_1.Location).createQueryBuilder();
18
16
  (0, shell_1.buildQuery)(queryBuilder, params, context);
19
17
  const [items, total] = await queryBuilder.getManyAndCount();
20
18
  return { items, total };
@@ -26,7 +24,7 @@ let LocationQuery = class LocationQuery {
26
24
  * ORM lagging issue (converting to object extremely withdraws the performance)
27
25
  * */
28
26
  async pureLocations(params, context) {
29
- const queryBuilder = (0, typeorm_1.getRepository)(location_1.Location).createQueryBuilder();
27
+ const queryBuilder = (0, shell_1.getRepository)(location_1.Location).createQueryBuilder('location');
30
28
  (0, shell_1.buildQuery)(queryBuilder, params, context);
31
29
  const items = await queryBuilder.getRawMany();
32
30
  const total = await queryBuilder.getCount();
@@ -35,9 +33,9 @@ let LocationQuery = class LocationQuery {
35
33
  async locationOccupancies(warehouse, types, context) {
36
34
  var _a, _b;
37
35
  const { domain } = context.state;
38
- const foundWarehouse = await (0, typeorm_1.getRepository)(warehouse_1.Warehouse).findOne({
36
+ const foundWarehouse = await (0, shell_1.getRepository)(warehouse_1.Warehouse).findOne({
39
37
  where: {
40
- domain,
38
+ domain: { id: domain.id },
41
39
  name: warehouse
42
40
  },
43
41
  relations: ['locations']
@@ -54,7 +52,7 @@ let LocationQuery = class LocationQuery {
54
52
  return { total, occupied, empty, percentage };
55
53
  }
56
54
  async location(name, context) {
57
- const foundLocation = await (0, typeorm_1.getRepository)(location_1.Location).findOne({
55
+ const foundLocation = await (0, shell_1.getRepository)(location_1.Location).findOne({
58
56
  where: { name },
59
57
  relations: ['domain', 'warehouse', 'creator', 'updater']
60
58
  });
@@ -64,7 +62,7 @@ let LocationQuery = class LocationQuery {
64
62
  }
65
63
  async locationByName(name, context) {
66
64
  const { domain } = context.state;
67
- return await (0, typeorm_1.getRepository)(location_1.Location).findOne({
65
+ return await (0, shell_1.getRepository)(location_1.Location).findOne({
68
66
  where: {
69
67
  domain: domain,
70
68
  name
@@ -77,13 +75,13 @@ let LocationQuery = class LocationQuery {
77
75
  const warehouseIdParam = params.filters.find(param => (param.name = 'warehouse_id'));
78
76
  if (!warehouseIdParam.value)
79
77
  throw new Error(`invalid warehouse ID`);
80
- const items = await (0, typeorm_1.getRepository)(location_1.Location).query(`
78
+ const items = await (0, shell_1.getRepository)(location_1.Location).query(`
81
79
  SELECT CONCAT("zone",'-',"row",'-',"column") as name, "zone", "row", "column"
82
80
  FROM locations WHERE domain_id = '${domain.id}'
83
81
  AND warehouse_id = '${warehouseIdParam.value}'
84
82
  GROUP BY "zone", "row", "column"
85
83
  `);
86
- let [{ total }] = await (0, typeorm_1.getRepository)(location_1.Location).query(`
84
+ let [{ total }] = await (0, shell_1.getRepository)(location_1.Location).query(`
87
85
  SELECT COUNT(DISTINCT("zone", "row", "column")) as total
88
86
  FROM locations WHERE domain_id = '${domain.id}'
89
87
  AND warehouse_id = '${warehouseIdParam.value}'
@@ -95,7 +93,7 @@ let LocationQuery = class LocationQuery {
95
93
  var _a, _b;
96
94
  const { domain, user } = context.state;
97
95
  const bizplaceIds = await (0, biz_base_1.getPermittedBizplaceIds)(domain, user);
98
- const queryBuilder = (0, typeorm_1.getRepository)(location_1.Location).createQueryBuilder();
96
+ const queryBuilder = (0, shell_1.getRepository)(location_1.Location).createQueryBuilder();
99
97
  const warehouseNames = (_a = params.filters.find(x => x.name === 'warehouseNames' && x.operator.toLowerCase() === 'in')) === null || _a === void 0 ? void 0 : _a.value;
100
98
  const locationTypes = (_b = params.filters.find(x => x.name === 'locationTypes' && x.operator.toLowerCase() === 'in')) === null || _b === void 0 ? void 0 : _b.value;
101
99
  params.filters = [];
@@ -159,17 +157,17 @@ let LocationQuery = class LocationQuery {
159
157
  }
160
158
  async domain(location) {
161
159
  var _a;
162
- return await (0, typeorm_1.getRepository)(shell_1.Domain).findOne((_a = location.domain) === null || _a === void 0 ? void 0 : _a.id);
160
+ return await (0, shell_1.getRepository)(shell_1.Domain).findOneBy({ id: (_a = location.domain) === null || _a === void 0 ? void 0 : _a.id });
163
161
  }
164
162
  async updater(location) {
165
- return await (0, typeorm_1.getRepository)(auth_base_1.User).findOne(location.updaterId);
163
+ return await (0, shell_1.getRepository)(auth_base_1.User).findOneBy({ id: location.updaterId });
166
164
  }
167
165
  async creator(location) {
168
- return await (0, typeorm_1.getRepository)(auth_base_1.User).findOne(location.creatorId);
166
+ return await (0, shell_1.getRepository)(auth_base_1.User).findOneBy({ id: location.creatorId });
169
167
  }
170
168
  async warehouse(location) {
171
169
  var _a;
172
- return await (0, typeorm_1.getRepository)(warehouse_1.Warehouse).findOne((_a = location.warehouse) === null || _a === void 0 ? void 0 : _a.id);
170
+ return await (0, shell_1.getRepository)(warehouse_1.Warehouse).findOneBy({ id: (_a = location.warehouse) === null || _a === void 0 ? void 0 : _a.id });
173
171
  }
174
172
  };
175
173
  tslib_1.__decorate([
@@ -178,7 +176,7 @@ tslib_1.__decorate([
178
176
  tslib_1.__param(0, (0, type_graphql_1.Args)()),
179
177
  tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
180
178
  tslib_1.__metadata("design:type", Function),
181
- tslib_1.__metadata("design:paramtypes", [typeof (_a = typeof shell_1.ListParam !== "undefined" && shell_1.ListParam) === "function" ? _a : Object, Object]),
179
+ tslib_1.__metadata("design:paramtypes", [shell_1.ListParam, Object]),
182
180
  tslib_1.__metadata("design:returntype", Promise)
183
181
  ], LocationQuery.prototype, "locations", null);
184
182
  tslib_1.__decorate([
@@ -187,7 +185,7 @@ tslib_1.__decorate([
187
185
  tslib_1.__param(0, (0, type_graphql_1.Args)()),
188
186
  tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
189
187
  tslib_1.__metadata("design:type", Function),
190
- tslib_1.__metadata("design:paramtypes", [typeof (_b = typeof shell_1.ListParam !== "undefined" && shell_1.ListParam) === "function" ? _b : Object, Object]),
188
+ tslib_1.__metadata("design:paramtypes", [shell_1.ListParam, Object]),
191
189
  tslib_1.__metadata("design:returntype", Promise)
192
190
  ], LocationQuery.prototype, "pureLocations", null);
193
191
  tslib_1.__decorate([
@@ -224,7 +222,7 @@ tslib_1.__decorate([
224
222
  tslib_1.__param(0, (0, type_graphql_1.Args)()),
225
223
  tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
226
224
  tslib_1.__metadata("design:type", Function),
227
- tslib_1.__metadata("design:paramtypes", [typeof (_c = typeof shell_1.ListParam !== "undefined" && shell_1.ListParam) === "function" ? _c : Object, Object]),
225
+ tslib_1.__metadata("design:paramtypes", [shell_1.ListParam, Object]),
228
226
  tslib_1.__metadata("design:returntype", Promise)
229
227
  ], LocationQuery.prototype, "locationsByGroup", null);
230
228
  tslib_1.__decorate([
@@ -233,7 +231,7 @@ tslib_1.__decorate([
233
231
  tslib_1.__param(0, (0, type_graphql_1.Args)()),
234
232
  tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
235
233
  tslib_1.__metadata("design:type", Function),
236
- tslib_1.__metadata("design:paramtypes", [typeof (_d = typeof shell_1.ListParam !== "undefined" && shell_1.ListParam) === "function" ? _d : Object, Object]),
234
+ tslib_1.__metadata("design:paramtypes", [shell_1.ListParam, Object]),
237
235
  tslib_1.__metadata("design:returntype", Promise)
238
236
  ], LocationQuery.prototype, "locationWithInventories", null);
239
237
  tslib_1.__decorate([
@@ -1 +1 @@
1
- {"version":3,"file":"location-query.js","sourceRoot":"","sources":["../../../server/service/location/location-query.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Args, Ctx, Directive, FieldResolver, Query, Resolver, Root } from 'type-graphql'\nimport { getRepository } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { getPermittedBizplaceIds } from '@things-factory/biz-base'\nimport { buildQuery, Domain, ListParam } from '@things-factory/shell'\n\nimport { INVENTORY_STATUS } from '../../constants/inventory'\nimport { Warehouse } from '../warehouse/warehouse'\nimport { Location } from './location'\nimport { LocationInventories, LocationList, LocationOccupancy } from './location-types'\n\n@Resolver(Location)\nexport class LocationQuery {\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => LocationList)\n async locations(@Args() params: ListParam, @Ctx() context: any): Promise<LocationList> {\n const queryBuilder = getRepository(Location).createQueryBuilder()\n buildQuery(queryBuilder, params, context)\n const [items, total] = await queryBuilder.getManyAndCount()\n\n return { items, total }\n }\n\n /**\n * @description this resolver was specially made to return huge locations data\n * without dropping off performance due to typegraphql limitations\n * @returns pure location data only. there will be no other table joined to avoid\n * ORM lagging issue (converting to object extremely withdraws the performance)\n * */\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => LocationList)\n async pureLocations(@Args() params: ListParam, @Ctx() context: any): Promise<LocationList> {\n const queryBuilder = getRepository(Location).createQueryBuilder()\n buildQuery(queryBuilder, params, context)\n const items = await queryBuilder.getRawMany()\n const total = await queryBuilder.getCount()\n\n return { items: items.map(item => new Location(item)), total }\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => LocationOccupancy)\n async locationOccupancies(\n @Arg('warehouse') warehouse: string,\n @Arg('types', type => [String], { nullable: true }) types: string[],\n @Ctx() context: any\n ): Promise<LocationOccupancy> {\n const { domain }: { domain: Domain } = context.state\n\n const foundWarehouse: Warehouse = await getRepository(Warehouse).findOne({\n where: {\n domain,\n name: warehouse\n },\n relations: ['locations']\n })\n\n if (!foundWarehouse) throw new Error(`${warehouse} was not found!`)\n\n const locations: Location[] =\n types && types.length\n ? foundWarehouse?.locations?.filter((location: Location) => types.indexOf(location.type) !== -1)\n : foundWarehouse?.locations\n\n const total: number = locations.length\n const occupied: number = locations.filter((location: Location) => location.status === 'OCCUPIED')?.length || 0\n const empty: number = total - occupied\n const percentage: number = occupied > 0 ? Math.round((occupied / total) * 100) : 0\n\n return { total, occupied, empty, percentage }\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => Location)\n async location(@Arg('name') name: string, @Ctx() context: any): Promise<Location> {\n const foundLocation: Location | null = await getRepository(Location).findOne({\n where: { name },\n relations: ['domain', 'warehouse', 'creator', 'updater']\n })\n if (!foundLocation) throw new Error(context.t('error.no_location_found'))\n\n return foundLocation\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => Location)\n async locationByName(@Arg('name') name: string, @Ctx() context: any): Promise<Location> {\n const { domain }: { domain: Domain } = context.state\n\n return await getRepository(Location).findOne({\n where: {\n domain: domain,\n name\n },\n relations: ['domain', 'warehouse', 'creator', 'updater']\n })\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => LocationList)\n async locationsByGroup(@Args() params: ListParam, @Ctx() context: any): Promise<LocationList> {\n const { domain }: { domain: Domain } = context.state\n const warehouseIdParam = params.filters.find(param => (param.name = 'warehouse_id'))\n\n if (!warehouseIdParam.value) throw new Error(`invalid warehouse ID`)\n\n const items = await getRepository(Location).query(`\n SELECT CONCAT(\"zone\",'-',\"row\",'-',\"column\") as name, \"zone\", \"row\", \"column\"\n FROM locations WHERE domain_id = '${domain.id}'\n AND warehouse_id = '${warehouseIdParam.value}'\n GROUP BY \"zone\", \"row\", \"column\"\n `)\n\n let [{ total }] = await getRepository(Location).query(`\n SELECT COUNT(DISTINCT(\"zone\", \"row\", \"column\")) as total\n FROM locations WHERE domain_id = '${domain.id}'\n AND warehouse_id = '${warehouseIdParam.value}'\n `)\n\n total = parseInt(total)\n\n return { items, total }\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => LocationInventories)\n async locationWithInventories(@Args() params: ListParam, @Ctx() context: any): Promise<LocationInventories> {\n const { domain, user }: { domain: Domain; user: User } = context.state\n const bizplaceIds = await getPermittedBizplaceIds(domain, user)\n const queryBuilder = getRepository(Location).createQueryBuilder()\n\n const warehouseNames = params.filters.find(x => x.name === 'warehouseNames' && x.operator.toLowerCase() === 'in')\n ?.value\n\n const locationTypes = params.filters.find(x => x.name === 'locationTypes' && x.operator.toLowerCase() === 'in')\n ?.value\n\n params.filters = []\n buildQuery(queryBuilder, params, context)\n\n queryBuilder\n .leftJoinAndSelect('Location.warehouse', 'Warehouse')\n .leftJoinAndSelect(\n 'inventories',\n 'Inventory',\n 'Location.id = Inventory.location_id AND Inventory.status = :InvStatus',\n {\n InvStatus: INVENTORY_STATUS.STORED\n }\n )\n .leftJoinAndSelect('Inventory.product', 'Product')\n .leftJoinAndSelect('Inventory.bizplace', 'Bizplace', 'Bizplace.id IN (:...bizplaceIds)', {\n bizplaceIds: [...new Set(bizplaceIds)]\n })\n .leftJoinAndSelect('Inventory.creator', 'Creator')\n .leftJoinAndSelect('Inventory.updater', 'Updater')\n .addSelect('SUM(\"Inventory\".\"qty\") OVER(PARTITION BY \"Location\".\"id\")', 'accumulate_qty')\n .where('Location.domain_id = :domainId', { domainId: domain.id })\n\n if (warehouseNames) {\n queryBuilder.andWhere('Warehouse.name IN (:...warehouseNames)', { warehouseNames: [...new Set(warehouseNames)] })\n }\n\n if (locationTypes) {\n queryBuilder.andWhere('Location.type ILIKE ANY (ARRAY[:...locationTypes])', {\n locationTypes: [...new Set(locationTypes)]\n })\n }\n\n let items = await queryBuilder.getRawMany()\n const total = await queryBuilder.getCount()\n\n items = items.map(item => {\n return {\n id: item.Location_id,\n name: item.Location_name,\n bizplace: {\n name: item.Bizplace_name || '',\n description: item.Bizplace_description || ''\n },\n product: {\n name: item.Product_name || '',\n sku: item.Product_sku || '',\n description: item.Product_description || ''\n },\n palletId: item.Inventory_pallet_id || '',\n batchId: item.Inventory_batch_id || '',\n qty: item.Inventory_qty || 0,\n accumulatedQty: item.accumulate_qty || 0,\n uomValue: item.Inventory_uom_value || 0.0,\n uom: item.Inventory_uom || '',\n packingType: item.Inventory_packing_type || '',\n packingSize: item.Inventory_packing_size || 0.0,\n expirationDate: item.Inventory_expiration_date\n ? new Date(item.Inventory_expiration_date).toISOString().split('T')[0].split('-').reverse().join('-')\n : '',\n warehouse: {\n name: item.Warehouse_name,\n description: item.Warehouse_description,\n type: item.Warehouse_type\n },\n zone: item.Location_zone\n }\n })\n\n return { items, total }\n }\n\n @FieldResolver(type => Domain)\n async domain(@Root() location: Location) {\n return await getRepository(Domain).findOne(location.domain?.id)\n }\n\n @FieldResolver(type => User)\n async updater(@Root() location: Location) {\n return await getRepository(User).findOne(location.updaterId)\n }\n\n @FieldResolver(type => User)\n async creator(@Root() location: Location) {\n return await getRepository(User).findOne(location.creatorId)\n }\n\n @FieldResolver(type => Warehouse)\n async warehouse(@Root() location: Location): Promise<Warehouse> {\n return await getRepository(Warehouse).findOne(location.warehouse?.id)\n }\n}\n"]}
1
+ {"version":3,"file":"location-query.js","sourceRoot":"","sources":["../../../server/service/location/location-query.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Args, Ctx, Directive, FieldResolver, Query, Resolver, Root } from 'type-graphql'\n\nimport { User } from '@things-factory/auth-base'\nimport { getPermittedBizplaceIds } from '@things-factory/biz-base'\nimport { buildQuery, Domain, getRepository, ListParam } from '@things-factory/shell'\n\nimport { INVENTORY_STATUS } from '../../constants/inventory'\nimport { Warehouse } from '../warehouse/warehouse'\nimport { Location } from './location'\nimport { LocationInventories, LocationList, LocationOccupancy } from './location-types'\n\n@Resolver(Location)\nexport class LocationQuery {\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => LocationList)\n async locations(@Args() params: ListParam, @Ctx() context: ResolverContext): Promise<LocationList> {\n const queryBuilder = getRepository(Location).createQueryBuilder()\n buildQuery(queryBuilder, params, context)\n const [items, total] = await queryBuilder.getManyAndCount()\n\n return { items, total }\n }\n\n /**\n * @description this resolver was specially made to return huge locations data\n * without dropping off performance due to typegraphql limitations\n * @returns pure location data only. there will be no other table joined to avoid\n * ORM lagging issue (converting to object extremely withdraws the performance)\n * */\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => LocationList)\n async pureLocations(@Args() params: ListParam, @Ctx() context: ResolverContext): Promise<LocationList> {\n const queryBuilder = getRepository(Location).createQueryBuilder('location')\n buildQuery(queryBuilder, params, context)\n const items = await queryBuilder.getRawMany()\n const total = await queryBuilder.getCount()\n\n return { items: items.map(item => new Location(item)), total }\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => LocationOccupancy)\n async locationOccupancies(\n @Arg('warehouse') warehouse: string,\n @Arg('types', type => [String], { nullable: true }) types: string[],\n @Ctx() context: ResolverContext\n ): Promise<LocationOccupancy> {\n const { domain } = context.state\n\n const foundWarehouse: Warehouse = await getRepository(Warehouse).findOne({\n where: {\n domain: { id: domain.id },\n name: warehouse\n },\n relations: ['locations']\n })\n\n if (!foundWarehouse) throw new Error(`${warehouse} was not found!`)\n\n const locations: Location[] =\n types && types.length\n ? foundWarehouse?.locations?.filter((location: Location) => types.indexOf(location.type) !== -1)\n : foundWarehouse?.locations\n\n const total: number = locations.length\n const occupied: number = locations.filter((location: Location) => location.status === 'OCCUPIED')?.length || 0\n const empty: number = total - occupied\n const percentage: number = occupied > 0 ? Math.round((occupied / total) * 100) : 0\n\n return { total, occupied, empty, percentage }\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => Location)\n async location(@Arg('name') name: string, @Ctx() context: ResolverContext): Promise<Location> {\n const foundLocation: Location | null = await getRepository(Location).findOne({\n where: { name },\n relations: ['domain', 'warehouse', 'creator', 'updater']\n })\n if (!foundLocation) throw new Error(context.t('error.no_location_found'))\n\n return foundLocation\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => Location)\n async locationByName(@Arg('name') name: string, @Ctx() context: ResolverContext): Promise<Location> {\n const { domain } = context.state\n\n return await getRepository(Location).findOne({\n where: {\n domain: domain,\n name\n },\n relations: ['domain', 'warehouse', 'creator', 'updater']\n })\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => LocationList)\n async locationsByGroup(@Args() params: ListParam, @Ctx() context: ResolverContext): Promise<LocationList> {\n const { domain } = context.state\n const warehouseIdParam = params.filters.find(param => (param.name = 'warehouse_id'))\n\n if (!warehouseIdParam.value) throw new Error(`invalid warehouse ID`)\n\n const items = await getRepository(Location).query(`\n SELECT CONCAT(\"zone\",'-',\"row\",'-',\"column\") as name, \"zone\", \"row\", \"column\"\n FROM locations WHERE domain_id = '${domain.id}'\n AND warehouse_id = '${warehouseIdParam.value}'\n GROUP BY \"zone\", \"row\", \"column\"\n `)\n\n let [{ total }] = await getRepository(Location).query(`\n SELECT COUNT(DISTINCT(\"zone\", \"row\", \"column\")) as total\n FROM locations WHERE domain_id = '${domain.id}'\n AND warehouse_id = '${warehouseIdParam.value}'\n `)\n\n total = parseInt(total)\n\n return { items, total }\n }\n\n @Directive('@privilege(category: \"warehouse\", privilege: \"query\")')\n @Query(returns => LocationInventories)\n async locationWithInventories(\n @Args() params: ListParam,\n @Ctx() context: ResolverContext\n ): Promise<LocationInventories> {\n const { domain, user } = context.state\n const bizplaceIds = await getPermittedBizplaceIds(domain, user)\n const queryBuilder = getRepository(Location).createQueryBuilder()\n\n const warehouseNames = params.filters.find(\n x => x.name === 'warehouseNames' && x.operator.toLowerCase() === 'in'\n )?.value\n\n const locationTypes = params.filters.find(\n x => x.name === 'locationTypes' && x.operator.toLowerCase() === 'in'\n )?.value\n\n params.filters = []\n buildQuery(queryBuilder, params, context)\n\n queryBuilder\n .leftJoinAndSelect('Location.warehouse', 'Warehouse')\n .leftJoinAndSelect(\n 'inventories',\n 'Inventory',\n 'Location.id = Inventory.location_id AND Inventory.status = :InvStatus',\n {\n InvStatus: INVENTORY_STATUS.STORED\n }\n )\n .leftJoinAndSelect('Inventory.product', 'Product')\n .leftJoinAndSelect('Inventory.bizplace', 'Bizplace', 'Bizplace.id IN (:...bizplaceIds)', {\n bizplaceIds: [...new Set(bizplaceIds)]\n })\n .leftJoinAndSelect('Inventory.creator', 'Creator')\n .leftJoinAndSelect('Inventory.updater', 'Updater')\n .addSelect('SUM(\"Inventory\".\"qty\") OVER(PARTITION BY \"Location\".\"id\")', 'accumulate_qty')\n .where('Location.domain_id = :domainId', { domainId: domain.id })\n\n if (warehouseNames) {\n queryBuilder.andWhere('Warehouse.name IN (:...warehouseNames)', { warehouseNames: [...new Set(warehouseNames)] })\n }\n\n if (locationTypes) {\n queryBuilder.andWhere('Location.type ILIKE ANY (ARRAY[:...locationTypes])', {\n locationTypes: [...new Set(locationTypes)]\n })\n }\n\n let items = await queryBuilder.getRawMany()\n const total = await queryBuilder.getCount()\n\n items = items.map(item => {\n return {\n id: item.Location_id,\n name: item.Location_name,\n bizplace: {\n name: item.Bizplace_name || '',\n description: item.Bizplace_description || ''\n },\n product: {\n name: item.Product_name || '',\n sku: item.Product_sku || '',\n description: item.Product_description || ''\n },\n palletId: item.Inventory_pallet_id || '',\n batchId: item.Inventory_batch_id || '',\n qty: item.Inventory_qty || 0,\n accumulatedQty: item.accumulate_qty || 0,\n uomValue: item.Inventory_uom_value || 0.0,\n uom: item.Inventory_uom || '',\n packingType: item.Inventory_packing_type || '',\n packingSize: item.Inventory_packing_size || 0.0,\n expirationDate: item.Inventory_expiration_date\n ? new Date(item.Inventory_expiration_date).toISOString().split('T')[0].split('-').reverse().join('-')\n : '',\n warehouse: {\n name: item.Warehouse_name,\n description: item.Warehouse_description,\n type: item.Warehouse_type\n },\n zone: item.Location_zone\n }\n })\n\n return { items, total }\n }\n\n @FieldResolver(type => Domain)\n async domain(@Root() location: Location) {\n return await getRepository(Domain).findOneBy({ id: location.domain?.id })\n }\n\n @FieldResolver(type => User)\n async updater(@Root() location: Location) {\n return await getRepository(User).findOneBy({ id: location.updaterId })\n }\n\n @FieldResolver(type => User)\n async creator(@Root() location: Location) {\n return await getRepository(User).findOneBy({ id: location.creatorId })\n }\n\n @FieldResolver(type => Warehouse)\n async warehouse(@Root() location: Location): Promise<Warehouse> {\n return await getRepository(Warehouse).findOneBy({ id: location.warehouse?.id })\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- var _a, _b, _c, _d;
2
+ var _a, _b;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  exports.NewLocation = exports.LocationPatch = exports.LocationOccupancy = exports.LocationList = exports.LocationInventories = exports.LocationInventory = void 0;
5
5
  const tslib_1 = require("tslib");
@@ -133,7 +133,7 @@ tslib_1.__decorate([
133
133
  ], LocationPatch.prototype, "id", void 0);
134
134
  tslib_1.__decorate([
135
135
  (0, type_graphql_1.Field)(type => shell_1.ObjectRef, { nullable: true }),
136
- tslib_1.__metadata("design:type", typeof (_c = typeof shell_1.ObjectRef !== "undefined" && shell_1.ObjectRef) === "function" ? _c : Object)
136
+ tslib_1.__metadata("design:type", shell_1.ObjectRef)
137
137
  ], LocationPatch.prototype, "warehouse", void 0);
138
138
  tslib_1.__decorate([
139
139
  (0, type_graphql_1.Field)({ nullable: true }),
@@ -191,7 +191,7 @@ let NewLocation = class NewLocation {
191
191
  };
192
192
  tslib_1.__decorate([
193
193
  (0, type_graphql_1.Field)(type => shell_1.ObjectRef, { nullable: true }),
194
- tslib_1.__metadata("design:type", typeof (_d = typeof shell_1.ObjectRef !== "undefined" && shell_1.ObjectRef) === "function" ? _d : Object)
194
+ tslib_1.__metadata("design:type", shell_1.ObjectRef)
195
195
  ], NewLocation.prototype, "warehouse", void 0);
196
196
  tslib_1.__decorate([
197
197
  (0, type_graphql_1.Field)(),
@@ -1 +1 @@
1
- {"version":3,"file":"location-types.js","sourceRoot":"","sources":["../../../server/service/location/location-types.ts"],"names":[],"mappings":"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","sourcesContent":["import { Field, Float, InputType, Int, ObjectType } from 'type-graphql'\n\nimport { Bizplace } from '@things-factory/biz-base'\nimport { Product } from '@things-factory/product-base'\nimport { ObjectRef } from '@things-factory/shell'\n\nimport { Warehouse } from '../warehouse/warehouse'\nimport { Location } from './location'\n\n@ObjectType()\nexport class LocationInventory {\n @Field({ nullable: true })\n id?: string\n\n @Field({ nullable: true })\n name?: string\n\n @Field(type => Bizplace, { nullable: true })\n bizplace?: Bizplace\n\n @Field({ nullable: true })\n palletId?: string\n\n @Field({ nullable: true })\n batchId?: string\n\n @Field(type => Int, { nullable: true })\n qty?: number\n\n @Field(type => Int, { nullable: true })\n accumulatedQty?: number\n\n @Field(type => Float, { nullable: true })\n uomValue?: number\n\n @Field({ nullable: true })\n uom?: string\n\n @Field({ nullable: true })\n packingType?: string\n\n @Field(type => Float, { nullable: true })\n packingSize?: number\n\n @Field({ nullable: true })\n expirationDate?: string\n\n @Field(type => Warehouse, { nullable: true })\n warehouse?: Warehouse\n\n @Field(type => Product, { nullable: true })\n product?: Product\n\n @Field({ nullable: true })\n zone?: string\n}\n\n@ObjectType()\nexport class LocationInventories {\n @Field(type => [LocationInventory], { nullable: true })\n items?: LocationInventory[]\n\n @Field(type => Int, { nullable: true })\n total?: number\n}\n\n@ObjectType()\nexport class LocationList {\n @Field(type => [Location], { nullable: true })\n items?: Location[]\n\n @Field(type => Int, { nullable: true })\n total?: number\n}\n\n@ObjectType()\nexport class LocationOccupancy {\n @Field(type => Int, { nullable: true })\n total?: number\n\n @Field(type => Int, { nullable: true })\n occupied?: number\n\n @Field(type => Int, { nullable: true })\n empty?: number\n\n @Field(type => Int, { nullable: true })\n percentage?: number\n}\n\n@InputType()\nexport class LocationPatch {\n @Field({ nullable: true })\n id?: string\n\n @Field(type => ObjectRef, { nullable: true })\n warehouse?: ObjectRef\n\n @Field({ nullable: true })\n name?: string\n\n @Field({ nullable: true })\n description?: string\n\n @Field({ nullable: true })\n type?: string\n\n @Field({ nullable: true })\n zone?: string\n\n @Field({ nullable: true })\n firstDelimiter?: string\n\n @Field({ nullable: true })\n secondDelimiter?: string\n\n @Field({ nullable: true })\n thirdDelimiter?: string\n\n @Field({ nullable: true })\n row?: string\n\n @Field({ nullable: true })\n column?: string\n\n @Field({ nullable: true })\n shelf?: string\n\n @Field({ nullable: true })\n status?: string\n\n @Field({ nullable: true })\n cuFlag?: string\n}\n\n@InputType()\nexport class NewLocation {\n @Field(type => ObjectRef, { nullable: true })\n warehouse?: ObjectRef\n\n @Field()\n name: string\n\n @Field({ nullable: true })\n description?: string\n\n @Field({ nullable: true })\n type?: string\n\n @Field()\n zone: string\n\n @Field({ nullable: true })\n firstDelimiter?: string\n\n @Field({ nullable: true })\n secondDelimiter?: string\n\n @Field({ nullable: true })\n thirdDelimiter?: string\n\n @Field()\n row: string\n\n @Field()\n column: string\n\n @Field()\n shelf: string\n\n @Field()\n status: string\n}\n"]}
1
+ {"version":3,"file":"location-types.js","sourceRoot":"","sources":["../../../server/service/location/location-types.ts"],"names":[],"mappings":"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","sourcesContent":["import { Field, Float, InputType, Int, ObjectType } from 'type-graphql'\n\nimport { Bizplace } from '@things-factory/biz-base'\nimport { Product } from '@things-factory/product-base'\nimport { ObjectRef } from '@things-factory/shell'\n\nimport { Warehouse } from '../warehouse/warehouse'\nimport { Location } from './location'\n\n@ObjectType()\nexport class LocationInventory {\n @Field({ nullable: true })\n id?: string\n\n @Field({ nullable: true })\n name?: string\n\n @Field(type => Bizplace, { nullable: true })\n bizplace?: Bizplace\n\n @Field({ nullable: true })\n palletId?: string\n\n @Field({ nullable: true })\n batchId?: string\n\n @Field(type => Int, { nullable: true })\n qty?: number\n\n @Field(type => Int, { nullable: true })\n accumulatedQty?: number\n\n @Field(type => Float, { nullable: true })\n uomValue?: number\n\n @Field({ nullable: true })\n uom?: string\n\n @Field({ nullable: true })\n packingType?: string\n\n @Field(type => Float, { nullable: true })\n packingSize?: number\n\n @Field({ nullable: true })\n expirationDate?: string\n\n @Field(type => Warehouse, { nullable: true })\n warehouse?: Warehouse\n\n @Field(type => Product, { nullable: true })\n product?: Product\n\n @Field({ nullable: true })\n zone?: string\n}\n\n@ObjectType()\nexport class LocationInventories {\n @Field(type => [LocationInventory], { nullable: true })\n items?: LocationInventory[]\n\n @Field(type => Int, { nullable: true })\n total?: number\n}\n\n@ObjectType()\nexport class LocationList {\n @Field(type => [Location], { nullable: true })\n items?: Location[]\n\n @Field(type => Int, { nullable: true })\n total?: number\n}\n\n@ObjectType()\nexport class LocationOccupancy {\n @Field(type => Int, { nullable: true })\n total?: number\n\n @Field(type => Int, { nullable: true })\n occupied?: number\n\n @Field(type => Int, { nullable: true })\n empty?: number\n\n @Field(type => Int, { nullable: true })\n percentage?: number\n}\n\n@InputType()\nexport class LocationPatch {\n @Field({ nullable: true })\n id?: string\n\n @Field(type => ObjectRef, { nullable: true })\n warehouse?: ObjectRef\n\n @Field({ nullable: true })\n name?: string\n\n @Field({ nullable: true })\n description?: string\n\n @Field({ nullable: true })\n type?: string\n\n @Field({ nullable: true })\n zone?: string\n\n @Field({ nullable: true })\n firstDelimiter?: string\n\n @Field({ nullable: true })\n secondDelimiter?: string\n\n @Field({ nullable: true })\n thirdDelimiter?: string\n\n @Field({ nullable: true })\n row?: string\n\n @Field({ nullable: true })\n column?: string\n\n @Field({ nullable: true })\n shelf?: string\n\n @Field({ nullable: true })\n status?: string\n\n @Field({ nullable: true })\n cuFlag?: string\n}\n\n@InputType()\nexport class NewLocation {\n @Field(type => ObjectRef, { nullable: true })\n warehouse?: ObjectRef\n\n @Field()\n name: string\n\n @Field({ nullable: true })\n description?: string\n\n @Field({ nullable: true })\n type?: string\n\n @Field()\n zone: string\n\n @Field({ nullable: true })\n firstDelimiter?: string\n\n @Field({ nullable: true })\n secondDelimiter?: string\n\n @Field({ nullable: true })\n thirdDelimiter?: string\n\n @Field()\n row: string\n\n @Field()\n column: string\n\n @Field()\n shelf: string\n\n @Field()\n status: string\n}\n"]}
@@ -1,5 +1,4 @@
1
1
  "use strict";
2
- var _a, _b, _c;
3
2
  Object.defineProperty(exports, "__esModule", { value: true });
4
3
  exports.Location = void 0;
5
4
  const tslib_1 = require("tslib");
@@ -11,16 +10,16 @@ const warehouse_1 = require("../warehouse/warehouse");
11
10
  let Location = class Location {
12
11
  constructor(obj) {
13
12
  if (obj) {
14
- this.id = obj.Location_id;
15
- this.name = obj.Location_name;
16
- this.description = obj.Location_description;
17
- this.type = obj.Location_type;
18
- this.zone = obj.Location_zone;
19
- this.row = obj.Location_row;
20
- this.column = obj.Location_column;
21
- this.shelf = obj.Location_shelf;
22
- this.status = obj.Location_status;
23
- this.updatedAt = obj.Location_updated_at;
13
+ this.id = obj.location_id;
14
+ this.name = obj.location_name;
15
+ this.description = obj.location_description;
16
+ this.type = obj.location_type;
17
+ this.zone = obj.location_zone;
18
+ this.row = obj.location_row;
19
+ this.column = obj.location_column;
20
+ this.shelf = obj.location_shelf;
21
+ this.status = obj.location_status;
22
+ this.updatedAt = obj.location_updated_at;
24
23
  }
25
24
  }
26
25
  };
@@ -32,7 +31,7 @@ tslib_1.__decorate([
32
31
  tslib_1.__decorate([
33
32
  (0, typeorm_1.ManyToOne)(type => shell_1.Domain),
34
33
  (0, type_graphql_1.Field)(),
35
- tslib_1.__metadata("design:type", typeof (_a = typeof shell_1.Domain !== "undefined" && shell_1.Domain) === "function" ? _a : Object)
34
+ tslib_1.__metadata("design:type", shell_1.Domain)
36
35
  ], Location.prototype, "domain", void 0);
37
36
  tslib_1.__decorate([
38
37
  (0, typeorm_1.RelationId)((location) => location.domain),
@@ -98,7 +97,7 @@ tslib_1.__decorate([
98
97
  nullable: true
99
98
  }),
100
99
  (0, type_graphql_1.Field)({ nullable: true }),
101
- tslib_1.__metadata("design:type", typeof (_b = typeof auth_base_1.User !== "undefined" && auth_base_1.User) === "function" ? _b : Object)
100
+ tslib_1.__metadata("design:type", auth_base_1.User)
102
101
  ], Location.prototype, "creator", void 0);
103
102
  tslib_1.__decorate([
104
103
  (0, typeorm_1.RelationId)((location) => location.creator),
@@ -109,7 +108,7 @@ tslib_1.__decorate([
109
108
  nullable: true
110
109
  }),
111
110
  (0, type_graphql_1.Field)({ nullable: true }),
112
- tslib_1.__metadata("design:type", typeof (_c = typeof auth_base_1.User !== "undefined" && auth_base_1.User) === "function" ? _c : Object)
111
+ tslib_1.__metadata("design:type", auth_base_1.User)
113
112
  ], Location.prototype, "updater", void 0);
114
113
  tslib_1.__decorate([
115
114
  (0, typeorm_1.RelationId)((location) => location.updater),
@@ -130,6 +129,7 @@ Location = tslib_1.__decorate([
130
129
  (0, typeorm_1.Index)('ix_location_0', (location) => [location.domain, location.name], { unique: true }),
131
130
  (0, typeorm_1.Index)('ix_location_1', (location) => [location.id], { unique: true }),
132
131
  (0, typeorm_1.Index)('ix_location_2', (location) => [location.domain]),
132
+ (0, typeorm_1.Index)('ix_location_3', (location) => [location.domain, location.name, location.type]),
133
133
  (0, type_graphql_1.ObjectType)(),
134
134
  tslib_1.__metadata("design:paramtypes", [Object])
135
135
  ], Location);
@@ -1 +1 @@
1
- {"version":3,"file":"location.js","sourceRoot":"","sources":["../../../server/service/location/location.ts"],"names":[],"mappings":"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","sourcesContent":["import { Field, ID, ObjectType } from 'type-graphql'\nimport {\n Column,\n CreateDateColumn,\n Entity,\n Index,\n ManyToOne,\n PrimaryGeneratedColumn,\n RelationId,\n UpdateDateColumn\n} from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain } from '@things-factory/shell'\n\nimport { Warehouse } from '../warehouse/warehouse'\n\n@Entity()\n@Index('ix_location_0', (location: Location) => [location.domain, location.name], { unique: true })\n@Index('ix_location_1', (location: Location) => [location.id], { unique: true })\n@Index('ix_location_2', (location: Location) => [location.domain])\n@ObjectType()\nexport class Location {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field()\n domain: Domain\n\n @RelationId((location: Location) => location.domain)\n domainId: string\n\n @ManyToOne(type => Warehouse, warehouse => warehouse.locations, {\n nullable: false\n })\n @Field(type => Warehouse, { nullable: true })\n warehouse: Warehouse\n\n @RelationId((location: Location) => location.warehouse)\n warehouseId: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n name: string\n\n @Column({\n nullable: true\n })\n @Field({ nullable: true })\n description: string\n\n @Column({\n nullable: true\n })\n @Field({ nullable: true })\n type: string\n\n @Column()\n @Field()\n zone: string\n\n @Column()\n @Field()\n row: string\n\n @Column()\n @Field()\n column: string\n\n @Column()\n @Field()\n shelf: string\n\n @Column({ type: 'text', comment: 'occupied, hold, empty' })\n @Field()\n status: string\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n creator: User\n\n @RelationId((location: Location) => location.creator)\n creatorId: string\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n updater: User\n\n @RelationId((location: Location) => location.updater)\n updaterId: string\n\n @CreateDateColumn()\n @Field({ nullable: true })\n createdAt: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true })\n updatedAt: Date\n\n constructor(obj?) {\n if (obj) {\n this.id = obj.Location_id\n this.name = obj.Location_name\n this.description = obj.Location_description\n this.type = obj.Location_type\n this.zone = obj.Location_zone\n this.row = obj.Location_row\n this.column = obj.Location_column\n this.shelf = obj.Location_shelf\n this.status = obj.Location_status\n this.updatedAt = obj.Location_updated_at\n }\n }\n}\n"]}
1
+ {"version":3,"file":"location.js","sourceRoot":"","sources":["../../../server/service/location/location.ts"],"names":[],"mappings":"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","sourcesContent":["import { Field, ID, ObjectType } from 'type-graphql'\nimport {\n Column,\n CreateDateColumn,\n Entity,\n Index,\n ManyToOne,\n PrimaryGeneratedColumn,\n RelationId,\n UpdateDateColumn\n} from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain } from '@things-factory/shell'\n\nimport { Warehouse } from '../warehouse/warehouse'\n\n@Entity()\n@Index('ix_location_0', (location: Location) => [location.domain, location.name], { unique: true })\n@Index('ix_location_1', (location: Location) => [location.id], { unique: true })\n@Index('ix_location_2', (location: Location) => [location.domain])\n@Index('ix_location_3', (location: Location) => [location.domain, location.name, location.type])\n@ObjectType()\nexport class Location {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field()\n domain: Domain\n\n @RelationId((location: Location) => location.domain)\n domainId: string\n\n @ManyToOne(type => Warehouse, warehouse => warehouse.locations, {\n nullable: false\n })\n @Field(type => Warehouse, { nullable: true })\n warehouse: Warehouse\n\n @RelationId((location: Location) => location.warehouse)\n warehouseId: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n name: string\n\n @Column({\n nullable: true\n })\n @Field({ nullable: true })\n description: string\n\n @Column({\n nullable: true\n })\n @Field({ nullable: true })\n type: string\n\n @Column()\n @Field()\n zone: string\n\n @Column()\n @Field()\n row: string\n\n @Column()\n @Field()\n column: string\n\n @Column()\n @Field()\n shelf: string\n\n @Column({ type: 'text', comment: 'occupied, hold, empty' })\n @Field()\n status: string\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n creator: User\n\n @RelationId((location: Location) => location.creator)\n creatorId: string\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n updater: User\n\n @RelationId((location: Location) => location.updater)\n updaterId: string\n\n @CreateDateColumn()\n @Field({ nullable: true })\n createdAt: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true })\n updatedAt: Date\n\n constructor(obj?) {\n if (obj) {\n this.id = obj.location_id\n this.name = obj.location_name\n this.description = obj.location_description\n this.type = obj.location_type\n this.zone = obj.location_zone\n this.row = obj.location_row\n this.column = obj.location_column\n this.shelf = obj.location_shelf\n this.status = obj.location_status\n this.updatedAt = obj.location_updated_at\n }\n }\n}\n"]}
@@ -5,16 +5,17 @@ const tslib_1 = require("tslib");
5
5
  const type_graphql_1 = require("type-graphql");
6
6
  const typeorm_1 = require("typeorm");
7
7
  const biz_base_1 = require("@things-factory/biz-base");
8
+ const shell_1 = require("@things-factory/shell");
8
9
  const inventory_1 = require("../inventory/inventory");
9
10
  const movement_1 = require("./movement");
10
11
  const movement_types_1 = require("./movement-types");
11
12
  let MovementMutation = class MovementMutation {
12
13
  async createMovement(movement, context) {
13
14
  const { domain, user } = context.state;
14
- return await (0, typeorm_1.getRepository)(movement_1.Movement).save(Object.assign(Object.assign({}, movement), { domain, creator: user, updater: user }));
15
+ return await (0, shell_1.getRepository)(movement_1.Movement).save(Object.assign(Object.assign({}, movement), { domain, creator: user, updater: user }));
15
16
  }
16
17
  async updateMovement(id, patch, context) {
17
- const movement = await (0, typeorm_1.getRepository)(movement_1.Movement).findOne({
18
+ const movement = await (0, shell_1.getRepository)(movement_1.Movement).findOne({
18
19
  where: {
19
20
  domain: context.state.domain,
20
21
  id,
@@ -22,12 +23,12 @@ let MovementMutation = class MovementMutation {
22
23
  }
23
24
  });
24
25
  if (patch.inventory && patch.inventory.id) {
25
- patch.inventory = await (0, typeorm_1.getRepository)(inventory_1.Inventory).findOne(patch.inventory.id);
26
+ patch.inventory = await (0, shell_1.getRepository)(inventory_1.Inventory).findOneBy({ id: patch.inventory.id });
26
27
  }
27
- return await (0, typeorm_1.getRepository)(movement_1.Movement).save(Object.assign(Object.assign(Object.assign({}, movement), patch), { updater: context.state.user }));
28
+ return await (0, shell_1.getRepository)(movement_1.Movement).save(Object.assign(Object.assign(Object.assign({}, movement), patch), { updater: context.state.user }));
28
29
  }
29
30
  async deleteMovement(name, context) {
30
- await (0, typeorm_1.getRepository)(movement_1.Movement).delete(name);
31
+ await (0, shell_1.getRepository)(movement_1.Movement).delete(name);
31
32
  return true;
32
33
  }
33
34
  };
@@ -1 +1 @@
1
- {"version":3,"file":"movement-mutation.js","sourceRoot":"","sources":["../../../server/service/movement/movement-mutation.ts"],"names":[],"mappings":";;;;AAAA,+CAAsE;AACtE,qCAA2C;AAG3C,uDAAkE;AAGlE,sDAAkD;AAClD,yCAAqC;AACrC,qDAA6D;AAG7D,IAAa,gBAAgB,GAA7B,MAAa,gBAAgB;IAI3B,KAAK,CAAC,cAAc,CAAkB,QAAqB,EAAS,OAAY;QAC9E,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAmC,OAAO,CAAC,KAAK,CAAA;QACtE,OAAO,MAAM,IAAA,uBAAa,EAAC,mBAAQ,CAAC,CAAC,IAAI,iCACpC,QAAQ,KACX,MAAM,EACN,OAAO,EAAE,IAAI,EACb,OAAO,EAAE,IAAI,IACb,CAAA;IACJ,CAAC;IAKD,KAAK,CAAC,cAAc,CACP,EAAU,EACP,KAAoB,EAC3B,OAAY;QAEnB,MAAM,QAAQ,GAAG,MAAM,IAAA,uBAAa,EAAC,mBAAQ,CAAC,CAAC,OAAO,CAAC;YACrD,KAAK,EAAE;gBACL,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM;gBAC5B,EAAE;gBACF,QAAQ,EAAE,IAAA,YAAE,EAAC,MAAM,IAAA,kCAAuB,EAAC,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;aACtF;SACF,CAAC,CAAA;QAEF,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,SAAS,CAAC,EAAE,EAAE;YACzC,KAAK,CAAC,SAAS,GAAG,MAAM,IAAA,uBAAa,EAAC,qBAAS,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;SAC7E;QAED,OAAO,MAAM,IAAA,uBAAa,EAAC,mBAAQ,CAAC,CAAC,IAAI,+CACpC,QAAQ,GACR,KAAK,KACR,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,IAC3B,CAAA;IACJ,CAAC;IAKD,KAAK,CAAC,cAAc,CAAc,IAAY,EAAS,OAAY;QACjE,MAAM,IAAA,uBAAa,EAAC,mBAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QAC1C,OAAO,IAAI,CAAA;IACb,CAAC;CACF,CAAA;AA5CC;IAHC,IAAA,wBAAS,EAAC,yDAAyD,CAAC;IACpE,IAAA,wBAAS,EAAC,cAAc,CAAC;IACzB,IAAA,uBAAQ,EAAC,OAAO,CAAC,EAAE,CAAC,mBAAQ,CAAC;IACR,mBAAA,IAAA,kBAAG,EAAC,UAAU,CAAC,CAAA;IAAyB,mBAAA,IAAA,kBAAG,GAAE,CAAA;;6CAAnB,4BAAW;;sDAQ1D;AAKD;IAHC,IAAA,wBAAS,EAAC,yDAAyD,CAAC;IACpE,IAAA,wBAAS,EAAC,cAAc,CAAC;IACzB,IAAA,uBAAQ,EAAC,OAAO,CAAC,EAAE,CAAC,mBAAQ,CAAC;IAE3B,mBAAA,IAAA,kBAAG,EAAC,IAAI,CAAC,CAAA;IACT,mBAAA,IAAA,kBAAG,EAAC,OAAO,CAAC,CAAA;IACZ,mBAAA,IAAA,kBAAG,GAAE,CAAA;;qDADe,8BAAa;;sDAoBnC;AAKD;IAHC,IAAA,wBAAS,EAAC,yDAAyD,CAAC;IACpE,IAAA,wBAAS,EAAC,cAAc,CAAC;IACzB,IAAA,uBAAQ,EAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC;IACP,mBAAA,IAAA,kBAAG,EAAC,MAAM,CAAC,CAAA;IAAgB,mBAAA,IAAA,kBAAG,GAAE,CAAA;;;;sDAGrD;AA/CU,gBAAgB;IAD5B,IAAA,uBAAQ,EAAC,mBAAQ,CAAC;GACN,gBAAgB,CAgD5B;AAhDY,4CAAgB","sourcesContent":["import { Arg, Ctx, Directive, Mutation, Resolver } from 'type-graphql'\nimport { getRepository, In } from 'typeorm'\n\nimport { User } from '@things-factory/auth-base'\nimport { getPermittedBizplaceIds } from '@things-factory/biz-base'\nimport { Domain } from '@things-factory/shell'\n\nimport { Inventory } from '../inventory/inventory'\nimport { Movement } from './movement'\nimport { MovementPatch, NewMovement } from './movement-types'\n\n@Resolver(Movement)\nexport class MovementMutation {\n @Directive('@privilege(category: \"movement\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Movement)\n async createMovement(@Arg('movement') movement: NewMovement, @Ctx() context: any): Promise<Movement> {\n const { domain, user }: { domain: Domain; user: User } = context.state\n return await getRepository(Movement).save({\n ...movement,\n domain,\n creator: user,\n updater: user\n })\n }\n\n @Directive('@privilege(category: \"movement\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Movement)\n async updateMovement(\n @Arg('id') id: string,\n @Arg('patch') patch: MovementPatch,\n @Ctx() context: any\n ): Promise<Movement> {\n const movement = await getRepository(Movement).findOne({\n where: {\n domain: context.state.domain,\n id,\n bizplace: In(await getPermittedBizplaceIds(context.state.domain, context.state.user))\n }\n })\n\n if (patch.inventory && patch.inventory.id) {\n patch.inventory = await getRepository(Inventory).findOne(patch.inventory.id)\n }\n\n return await getRepository(Movement).save({\n ...movement,\n ...patch,\n updater: context.state.user\n })\n }\n\n @Directive('@privilege(category: \"movement\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Boolean)\n async deleteMovement(@Arg('name') name: string, @Ctx() context: any): Promise<Boolean> {\n await getRepository(Movement).delete(name)\n return true\n }\n}\n"]}
1
+ {"version":3,"file":"movement-mutation.js","sourceRoot":"","sources":["../../../server/service/movement/movement-mutation.ts"],"names":[],"mappings":";;;;AAAA,+CAAsE;AACtE,qCAA4B;AAE5B,uDAAkE;AAClE,iDAAqD;AAErD,sDAAkD;AAClD,yCAAqC;AACrC,qDAA6D;AAG7D,IAAa,gBAAgB,GAA7B,MAAa,gBAAgB;IAI3B,KAAK,CAAC,cAAc,CAAkB,QAAqB,EAAS,OAAwB;QAC1F,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QACtC,OAAO,MAAM,IAAA,qBAAa,EAAC,mBAAQ,CAAC,CAAC,IAAI,iCACpC,QAAQ,KACX,MAAM,EACN,OAAO,EAAE,IAAI,EACb,OAAO,EAAE,IAAI,IACb,CAAA;IACJ,CAAC;IAKD,KAAK,CAAC,cAAc,CACP,EAAU,EACP,KAAoB,EAC3B,OAAwB;QAE/B,MAAM,QAAQ,GAAG,MAAM,IAAA,qBAAa,EAAC,mBAAQ,CAAC,CAAC,OAAO,CAAC;YACrD,KAAK,EAAE;gBACL,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM;gBAC5B,EAAE;gBACF,QAAQ,EAAE,IAAA,YAAE,EAAC,MAAM,IAAA,kCAAuB,EAAC,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;aACtF;SACF,CAAC,CAAA;QAEF,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,SAAS,CAAC,EAAE,EAAE;YACzC,KAAK,CAAC,SAAS,GAAG,MAAM,IAAA,qBAAa,EAAC,qBAAS,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC,CAAA;SACvF;QAED,OAAO,MAAM,IAAA,qBAAa,EAAC,mBAAQ,CAAC,CAAC,IAAI,+CACpC,QAAQ,GACR,KAAK,KACR,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,IAC3B,CAAA;IACJ,CAAC;IAKD,KAAK,CAAC,cAAc,CAAc,IAAY,EAAS,OAAwB;QAC7E,MAAM,IAAA,qBAAa,EAAC,mBAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QAC1C,OAAO,IAAI,CAAA;IACb,CAAC;CACF,CAAA;AA5CC;IAHC,IAAA,wBAAS,EAAC,yDAAyD,CAAC;IACpE,IAAA,wBAAS,EAAC,cAAc,CAAC;IACzB,IAAA,uBAAQ,EAAC,OAAO,CAAC,EAAE,CAAC,mBAAQ,CAAC;IACR,mBAAA,IAAA,kBAAG,EAAC,UAAU,CAAC,CAAA;IAAyB,mBAAA,IAAA,kBAAG,GAAE,CAAA;;6CAAnB,4BAAW;;sDAQ1D;AAKD;IAHC,IAAA,wBAAS,EAAC,yDAAyD,CAAC;IACpE,IAAA,wBAAS,EAAC,cAAc,CAAC;IACzB,IAAA,uBAAQ,EAAC,OAAO,CAAC,EAAE,CAAC,mBAAQ,CAAC;IAE3B,mBAAA,IAAA,kBAAG,EAAC,IAAI,CAAC,CAAA;IACT,mBAAA,IAAA,kBAAG,EAAC,OAAO,CAAC,CAAA;IACZ,mBAAA,IAAA,kBAAG,GAAE,CAAA;;qDADe,8BAAa;;sDAoBnC;AAKD;IAHC,IAAA,wBAAS,EAAC,yDAAyD,CAAC;IACpE,IAAA,wBAAS,EAAC,cAAc,CAAC;IACzB,IAAA,uBAAQ,EAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC;IACP,mBAAA,IAAA,kBAAG,EAAC,MAAM,CAAC,CAAA;IAAgB,mBAAA,IAAA,kBAAG,GAAE,CAAA;;;;sDAGrD;AA/CU,gBAAgB;IAD5B,IAAA,uBAAQ,EAAC,mBAAQ,CAAC;GACN,gBAAgB,CAgD5B;AAhDY,4CAAgB","sourcesContent":["import { Arg, Ctx, Directive, Mutation, Resolver } from 'type-graphql'\nimport { In } from 'typeorm'\n\nimport { getPermittedBizplaceIds } from '@things-factory/biz-base'\nimport { getRepository } from '@things-factory/shell'\n\nimport { Inventory } from '../inventory/inventory'\nimport { Movement } from './movement'\nimport { MovementPatch, NewMovement } from './movement-types'\n\n@Resolver(Movement)\nexport class MovementMutation {\n @Directive('@privilege(category: \"movement\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Movement)\n async createMovement(@Arg('movement') movement: NewMovement, @Ctx() context: ResolverContext): Promise<Movement> {\n const { domain, user } = context.state\n return await getRepository(Movement).save({\n ...movement,\n domain,\n creator: user,\n updater: user\n })\n }\n\n @Directive('@privilege(category: \"movement\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Movement)\n async updateMovement(\n @Arg('id') id: string,\n @Arg('patch') patch: MovementPatch,\n @Ctx() context: ResolverContext\n ): Promise<Movement> {\n const movement = await getRepository(Movement).findOne({\n where: {\n domain: context.state.domain,\n id,\n bizplace: In(await getPermittedBizplaceIds(context.state.domain, context.state.user))\n }\n })\n\n if (patch.inventory && patch.inventory.id) {\n patch.inventory = await getRepository(Inventory).findOneBy({ id: patch.inventory.id })\n }\n\n return await getRepository(Movement).save({\n ...movement,\n ...patch,\n updater: context.state.user\n })\n }\n\n @Directive('@privilege(category: \"movement\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Boolean)\n async deleteMovement(@Arg('name') name: string, @Ctx() context: ResolverContext): Promise<Boolean> {\n await getRepository(Movement).delete(name)\n return true\n }\n}\n"]}