/** *** Copyright (c) 2016-2019, Jaguar0625, gimre, BloodyRookie, Tech Bureau, Corp. *** Copyright (c) 2020-present, Jaguar0625, gimre, BloodyRookie. *** All rights reserved. *** *** This file is part of Catapult. *** *** Catapult is free software: you can redistribute it and/or modify *** it under the terms of the GNU Lesser General Public License as published by *** the Free Software Foundation, either version 3 of the License, or *** (at your option) any later version. *** *** Catapult is distributed in the hope that it will be useful, *** but WITHOUT ANY WARRANTY; without even the implied warranty of *** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *** GNU Lesser General Public License for more details. *** *** You should have received a copy of the GNU Lesser General Public License *** along with Catapult. If not, see . **/ import { GeneratorUtils } from './GeneratorUtils'; import { Serializer } from './Serializer'; /** A quantity of mosaics in [absolute units](/concepts/mosaic.html#divisibility). It can only be positive or zero. Negative quantities must be indicated by other means (See for example MosaicSupplyChangeTransaction and MosaicSupplyChangeAction).. */ export class AmountDto implements Serializer { /** A quantity of mosaics in [absolute units](/concepts/mosaic.html#divisibility). It can only be positive or zero. Negative quantities must be indicated by other means (See for example MosaicSupplyChangeTransaction and MosaicSupplyChangeAction).. */ readonly amount: number[]; /** * Constructor. * * @param amount A quantity of mosaics in [absolute units](/concepts/mosaic.html#divisibility). It can only be positive or zero. Negative quantities must be indicated by other means (See for example MosaicSupplyChangeTransaction and MosaicSupplyChangeAction).. */ constructor(amount: number[]) { this.amount = amount; } /** * Creates an instance of AmountDto from binary payload. * * @param payload Byte payload to use to serialize the object. * @return Instance of AmountDto. */ public static loadFromBinary(payload: Uint8Array): AmountDto { const amount = GeneratorUtils.bufferToUint64(Uint8Array.from(payload)); return new AmountDto(amount); } /** * Gets A quantity of mosaics in [absolute units](/concepts/mosaic.html#divisibility). It can only be positive or zero. Negative quantities must be indicated by other means (See for example MosaicSupplyChangeTransaction and MosaicSupplyChangeAction).. * * @return A quantity of mosaics in [absolute units](/concepts/mosaic.html#divisibility). It can only be positive or zero. Negative quantities must be indicated by other means (See for example MosaicSupplyChangeTransaction and MosaicSupplyChangeAction).. */ public getAmount(): number[] { return this.amount; } /** * Gets the size of the object. * * @return Size in bytes. */ public getSize(): number { return 8; } /** * Serializes an object to bytes. * * @return Serialized bytes. */ public serialize(): Uint8Array { return GeneratorUtils.uint64ToBuffer(this.getAmount()); } }