/**
* File Auto-Generated by the RICADO Gen 4 PHP API Project
*
* Do Not Edit this File Manually!
*/
import RequestHelper from '../../../RequestHelper';
import ReemoonSizerModel from '../../../Models/Packhouse/Site/ReemoonSizerModel';
/**
* Controller Class for Reemoon Sizers
*
* @class
*/
class ReemoonSizerController
{
/**
* Retrieve a Reemoon Sizer [GET /packhouse/sites/{siteId}/reemoon-sizers/{id}]
*
* @static
* @public
* @param {number} siteId The Site ID
* @param {string} id The Reemoon Sizer ID
* @return {Promise<ReemoonSizerModel>}
*/
static getOne(siteId, id)
{
return new Promise((resolve, reject) => {
RequestHelper.getRequest(`/packhouse/sites/${siteId}/reemoon-sizers/${id}`)
.then((result) => {
let resolveValue = (function(){
return ReemoonSizerModel.fromJSON(result, siteId);
}());
resolve(resolveValue);
})
.catch(error => reject(error));
});
}
/**
* Update a Reemoon Sizer [PATCH /packhouse/sites/{siteId}/reemoon-sizers/{id}]
*
* @static
* @public
* @param {number} siteId The Site ID
* @param {string} id The Reemoon Sizer ID
* @param {ReemoonSizerController.UpdateData} updateData The Reemoon Sizer Update Data
* @return {Promise<ReemoonSizerModel>}
*/
static update(siteId, id, updateData)
{
return new Promise((resolve, reject) => {
RequestHelper.patchRequest(`/packhouse/sites/${siteId}/reemoon-sizers/${id}`, updateData)
.then((result) => {
let resolveValue = (function(){
return ReemoonSizerModel.fromJSON(result, siteId);
}());
resolve(resolveValue);
})
.catch(error => reject(error));
});
}
/**
* Delete a Reemoon Sizer [DELETE /packhouse/sites/{siteId}/reemoon-sizers/{id}]
*
* @static
* @public
* @param {number} siteId The Site ID
* @param {string} id The Reemoon Sizer ID
* @return {Promise<boolean>}
*/
static delete(siteId, id)
{
return new Promise((resolve, reject) => {
RequestHelper.deleteRequest(`/packhouse/sites/${siteId}/reemoon-sizers/${id}`)
.then((result) => {
resolve(result ?? true);
})
.catch(error => reject(error));
});
}
/**
* List all Reemoon Sizers [GET /packhouse/sites/{siteId}/reemoon-sizers]
*
* @static
* @public
* @param {number} siteId The Site ID
* @param {ReemoonSizerController.GetAllQueryParameters} [queryParameters] The Optional Query Parameters
* @return {Promise<ReemoonSizerModel[]>}
*/
static getAll(siteId, queryParameters = {})
{
return new Promise((resolve, reject) => {
RequestHelper.getRequest(`/packhouse/sites/${siteId}/reemoon-sizers`, queryParameters)
.then((result) => {
let resolveValue = (function(){
if(Array.isArray(result) !== true)
{
return [];
}
return result.map((resultItem) => {
return (function(){
return ReemoonSizerModel.fromJSON(resultItem, siteId);
}());
});
}());
resolve(resolveValue);
})
.catch(error => reject(error));
});
}
/**
* Create a Reemoon Sizer [POST /packhouse/sites/{siteId}/reemoon-sizers]
*
* @static
* @public
* @param {number} siteId The Site ID
* @param {ReemoonSizerController.CreateData} createData The Reemoon Sizer Create Data
* @return {Promise<ReemoonSizerModel>}
*/
static create(siteId, createData)
{
return new Promise((resolve, reject) => {
RequestHelper.postRequest(`/packhouse/sites/${siteId}/reemoon-sizers`, createData)
.then((result) => {
let resolveValue = (function(){
return ReemoonSizerModel.fromJSON(result, siteId);
}());
resolve(resolveValue);
})
.catch(error => reject(error));
});
}
}
export default ReemoonSizerController;
/**
* The Optional Query Parameters for the getAll Function
*
* @typedef {Object} ReemoonSizerController.GetAllQueryParameters
* @property {?number} [rtuId] The RTU this Reemoon Sizer belongs to
* @property {string} [name] The Reemoon Sizer Name
* @property {string} [packingLineId] The Packing Line ID that manages this Reemoon Sizer
* @property {string} [sizerType] The Sizer Type
* @memberof Controllers.Packhouse.Site
*/
/**
* The Create Data for a Reemoon Sizer
*
* @typedef {Object} ReemoonSizerController.CreateData
* @property {?number} [rtuId] The RTU this Reemoon Sizer belongs to
* @property {string} name The Reemoon Sizer Name
* @property {string} packingLineId The Packing Line ID that manages this Reemoon Sizer
* @property {string} sizerType The Sizer Type
* @property {number} [autoCreateBatchDelay] The Auto Create Batch Delay in Seconds for this Reemoon Sizer
* @property {{currentBatchId: number, currentBatchName: number, currentBatchVarietyCode: number, currentBatchStartTimestamp: number, currentBatchPackrunId: number, currentBatchPackrunName: number, machineAverageFruitWeight: number, machineAverageFruitSize: number, machineCupFill: number, machineIncomingFruitPerMinute: number, machineRecycledFruitPerMinute: number, machineTraysPerHour: number, machineTonnesPerHour: number, machineRodsPerMinute: number, machineIncomingFruitPerMinuteBySize: ?number, machineRecycledFruitPerMinuteBySize: ?number, machineLanesFruitPerMinuteBySize: ?number, createNewBatchRequest: number, createBatchOnPackrunChange: number, createBatchOnTimeBatchChange: number, outletGroupSummaries: number, products: number, packTypeOutletUtilizationTargets: number, class1TraysPerHour: ?number}} points The Points used by this Reemoon Sizer
* @property {Array<ReemoonSizerController.ReemoonSizerLane>} [lanes] The Lanes defined for this Reemoon Sizer
* @property {Array<ReemoonSizerController.ReemoonSizerOutlet>} [outlets] The Outlets defined for this Reemoon Sizer
* @property {Array<ReemoonSizerController.ReemoonSizerFruitSize>} [fruitSizes] The Fruit Sizes defined and handled by this Reemoon Sizer
* @property {?ReemoonSizerController.FreshPackReemoonSizerIntegration} [freshPackIntegration] The FreshPack Integration Configuration for this Reemoon Sizer
* @property {ReemoonSizerController.ReemoonSizerIntegration} reemoonIntegration The Reemoon Integration Configuration for this Reemoon Sizer
* @property {Array<ReemoonSizerController.RiserSource|ReemoonSizerController.SizerSource>} [sources] An Array of Sources that deliver Fruit to this Reemoon Sizer
* @property {Array<ReemoonSizerController.ProductClassType>} [productClassTypes] An Array of Product to Class Type Maps for this Reemoon Sizer
* @memberof Controllers.Packhouse.Site
*/
/**
* The Update Data for a Reemoon Sizer
*
* @typedef {Object} ReemoonSizerController.UpdateData
* @property {string} [name] The Reemoon Sizer Name
* @property {string} [packingLineId] The Packing Line ID that manages this Reemoon Sizer
* @property {string} [sizerType] The Sizer Type
* @property {number} [autoCreateBatchDelay] The Auto Create Batch Delay in Seconds for this Reemoon Sizer
* @property {{currentBatchId: number, currentBatchName: number, currentBatchVarietyCode: number, currentBatchStartTimestamp: number, currentBatchPackrunId: number, currentBatchPackrunName: number, machineAverageFruitWeight: number, machineAverageFruitSize: number, machineCupFill: number, machineIncomingFruitPerMinute: number, machineRecycledFruitPerMinute: number, machineTraysPerHour: number, machineTonnesPerHour: number, machineRodsPerMinute: number, machineIncomingFruitPerMinuteBySize: ?number, machineRecycledFruitPerMinuteBySize: ?number, machineLanesFruitPerMinuteBySize: ?number, createNewBatchRequest: number, createBatchOnPackrunChange: number, createBatchOnTimeBatchChange: number, outletGroupSummaries: number, products: number, packTypeOutletUtilizationTargets: number, class1TraysPerHour: ?number}} [points] The Points used by this Reemoon Sizer
* @property {Array<ReemoonSizerController.ReemoonSizerLane>} [lanes] The Lanes defined for this Reemoon Sizer
* @property {Array<ReemoonSizerController.ReemoonSizerOutlet>} [outlets] The Outlets defined for this Reemoon Sizer
* @property {Array<ReemoonSizerController.ReemoonSizerFruitSize>} [fruitSizes] The Fruit Sizes defined and handled by this Reemoon Sizer
* @property {?ReemoonSizerController.FreshPackReemoonSizerIntegration} [freshPackIntegration] The FreshPack Integration Configuration for this Reemoon Sizer
* @property {ReemoonSizerController.ReemoonSizerIntegration} [reemoonIntegration] The Reemoon Integration Configuration for this Reemoon Sizer
* @property {Array<ReemoonSizerController.RiserSource|ReemoonSizerController.SizerSource>} [sources] An Array of Sources that deliver Fruit to this Reemoon Sizer
* @property {Array<ReemoonSizerController.ProductClassType>} [productClassTypes] An Array of Product to Class Type Maps for this Reemoon Sizer
* @memberof Controllers.Packhouse.Site
*/
/**
* A **ReemoonSizerLane** Type
*
* @typedef {Object} ReemoonSizerController.ReemoonSizerLane
* @property {string} id Unique ID of this Lane
* @property {number} number The Lane Number
* @property {{cupFill: number}} points The Points used by this Lane
* @memberof Controllers.Packhouse.Site
*/
/**
* A **ReemoonSizerOutlet** Type
*
* @typedef {Object} ReemoonSizerController.ReemoonSizerOutlet
* @property {string} id Unique ID of this Outlet
* @property {number} number The Outlet Number
* @property {string} type The Outlet Type
* @property {{name: number, fruitPerMinute: number, packsPerMinute: number, utilization: number, status: number, productId: number, productName: number}} points The Points used by this Outlet
* @memberof Controllers.Packhouse.Site
*/
/**
* A **ReemoonSizerFruitSize** Type
*
* @typedef {Object} ReemoonSizerController.ReemoonSizerFruitSize
* @property {string} fruitSize The Fruit Size
* @property {{incomingFruitPerMinute: number, recycledFruitPerMinute: number, allocatedFruitPerMinute: number}} points The Points used by this Fruit Size Configuration
* @memberof Controllers.Packhouse.Site
*/
/**
* A **FreshPackReemoonSizerIntegration** Type
*
* @typedef {Object} ReemoonSizerController.FreshPackReemoonSizerIntegration
* @property {Object} points The Points used by this FreshPack Sizer Integration
* @property {boolean} enabled Whether this FreshPack Sizer Integration is Enabled
* @property {number} materialGroupId The FreshPack Material Group ID to be used for Multi-Grower Bins from this Sizer
* @property {number} binTypeId The FreshPack Bin Type ID to be used for Multi-Grower Bins from this Sizer
* @property {string[]} bulkWeightClassTypes An Array of Class Types that should be Sent to FreshPack as Bulk Weights in Multi-Grower Bins
* @memberof Controllers.Packhouse.Site
*/
/**
* A **ReemoonSizerIntegration** Type
*
* @typedef {Object} ReemoonSizerController.ReemoonSizerIntegration
* @property {{apiCommunicationStatus: number, machineId: number, machineName: number, machineLaneCount: number, machineOutletCount: number, machineOutletDetails: number}} points The Points used by this Reemoon Sizer Integration
* @property {boolean} enabled Whether this Reemoon Sizer Integration is Enabled
* @property {string} username Username for Authenticating with the Reemoon Sizer API
* @property {string} password Password for Authenticating with the Reemoon Sizer API
* @property {string} apiBaseUrl Base URL of the Reemoon Sizer API
* @memberof Controllers.Packhouse.Site
*/
/**
* A **RiserSource** Type
*
* @typedef {Object} ReemoonSizerController.RiserSource
* @property {string} type The Source Type
* @property {string} riserId ID of the Riser Object
* @memberof Controllers.Packhouse.Site
*/
/**
* A **SizerSource** Type
*
* @typedef {Object} ReemoonSizerController.SizerSource
* @property {string} type The Source Type
* @property {string} sizerId ID of the Sizer Object
* @property {number[]} outletNumbers An Array of Outlet Numbers on the Source Sizer that supply this Reemoon Sizer
* @memberof Controllers.Packhouse.Site
*/
/**
* A **ProductClassType** Type
*
* @typedef {Object} ReemoonSizerController.ProductClassType
* @property {string} productName Name of the Reemoon Sizer Product
* @property {string} classType The Class Type for this Reemoon Sizer Product
* @property {string} matchType The Match Type used when Evaluating the Product Name
* @memberof Controllers.Packhouse.Site
*/
source