// Code generated by gotdgen, DO NOT EDIT.

package tg

import (
	
	
	
	
	

	

	
	
	
	
)

// No-op definition for keeping imports.
var (
	_ = bin.Buffer{}
	_ = context.Background()
	_ = fmt.Stringer(nil)
	_ = strings.Builder{}
	_ = errors.Is
	_ = multierr.AppendInto
	_ = sort.Ints
	_ = tdp.Format
	_ = tgerr.Error{}
	_ = tdjson.Encoder{}
)

// EmojiStatusEmpty represents TL type `emojiStatusEmpty#2de11aae`.
// No emoji status is set
//
// See https://core.telegram.org/constructor/emojiStatusEmpty for reference.
type EmojiStatusEmpty struct {
}

// EmojiStatusEmptyTypeID is TL type id of EmojiStatusEmpty.
const EmojiStatusEmptyTypeID = 0x2de11aae

// construct implements constructor of EmojiStatusClass.
func ( EmojiStatusEmpty) () EmojiStatusClass { return & }

// Ensuring interfaces in compile-time for EmojiStatusEmpty.
var (
	_ bin.Encoder     = &EmojiStatusEmpty{}
	_ bin.Decoder     = &EmojiStatusEmpty{}
	_ bin.BareEncoder = &EmojiStatusEmpty{}
	_ bin.BareDecoder = &EmojiStatusEmpty{}

	_ EmojiStatusClass = &EmojiStatusEmpty{}
)

func ( *EmojiStatusEmpty) () bool {
	if  == nil {
		return true
	}

	return true
}

// String implements fmt.Stringer.
func ( *EmojiStatusEmpty) () string {
	if  == nil {
		return "EmojiStatusEmpty(nil)"
	}
	type  EmojiStatusEmpty
	return fmt.Sprintf("EmojiStatusEmpty%+v", (*))
}

// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
func (*EmojiStatusEmpty) () uint32 {
	return EmojiStatusEmptyTypeID
}

// TypeName returns name of type in TL schema.
func (*EmojiStatusEmpty) () string {
	return "emojiStatusEmpty"
}

// TypeInfo returns info about TL type.
func ( *EmojiStatusEmpty) () tdp.Type {
	 := tdp.Type{
		Name: "emojiStatusEmpty",
		ID:   EmojiStatusEmptyTypeID,
	}
	if  == nil {
		.Null = true
		return 
	}
	.Fields = []tdp.Field{}
	return 
}

// Encode implements bin.Encoder.
func ( *EmojiStatusEmpty) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode emojiStatusEmpty#2de11aae as nil")
	}
	.PutID(EmojiStatusEmptyTypeID)
	return .EncodeBare()
}

// EncodeBare implements bin.BareEncoder.
func ( *EmojiStatusEmpty) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode emojiStatusEmpty#2de11aae as nil")
	}
	return nil
}

// Decode implements bin.Decoder.
func ( *EmojiStatusEmpty) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode emojiStatusEmpty#2de11aae to nil")
	}
	if  := .ConsumeID(EmojiStatusEmptyTypeID);  != nil {
		return fmt.Errorf("unable to decode emojiStatusEmpty#2de11aae: %w", )
	}
	return .DecodeBare()
}

// DecodeBare implements bin.BareDecoder.
func ( *EmojiStatusEmpty) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode emojiStatusEmpty#2de11aae to nil")
	}
	return nil
}

// EmojiStatus represents TL type `emojiStatus#929b619d`.
// An emoji status¹
//
// Links:
//  1. https://core.telegram.org/api/emoji-status
//
// See https://core.telegram.org/constructor/emojiStatus for reference.
type EmojiStatus struct {
	// Custom emoji document ID¹
	//
	// Links:
	//  1) https://core.telegram.org/api/custom-emoji
	DocumentID int64
}

// EmojiStatusTypeID is TL type id of EmojiStatus.
const EmojiStatusTypeID = 0x929b619d

// construct implements constructor of EmojiStatusClass.
func ( EmojiStatus) () EmojiStatusClass { return & }

// Ensuring interfaces in compile-time for EmojiStatus.
var (
	_ bin.Encoder     = &EmojiStatus{}
	_ bin.Decoder     = &EmojiStatus{}
	_ bin.BareEncoder = &EmojiStatus{}
	_ bin.BareDecoder = &EmojiStatus{}

	_ EmojiStatusClass = &EmojiStatus{}
)

func ( *EmojiStatus) () bool {
	if  == nil {
		return true
	}
	if !(.DocumentID == 0) {
		return false
	}

	return true
}

// String implements fmt.Stringer.
func ( *EmojiStatus) () string {
	if  == nil {
		return "EmojiStatus(nil)"
	}
	type  EmojiStatus
	return fmt.Sprintf("EmojiStatus%+v", (*))
}

// FillFrom fills EmojiStatus from given interface.
func ( *EmojiStatus) ( interface {
	() ( int64)
}) {
	.DocumentID = .()
}

// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
func (*EmojiStatus) () uint32 {
	return EmojiStatusTypeID
}

// TypeName returns name of type in TL schema.
func (*EmojiStatus) () string {
	return "emojiStatus"
}

// TypeInfo returns info about TL type.
func ( *EmojiStatus) () tdp.Type {
	 := tdp.Type{
		Name: "emojiStatus",
		ID:   EmojiStatusTypeID,
	}
	if  == nil {
		.Null = true
		return 
	}
	.Fields = []tdp.Field{
		{
			Name:       "DocumentID",
			SchemaName: "document_id",
		},
	}
	return 
}

// Encode implements bin.Encoder.
func ( *EmojiStatus) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode emojiStatus#929b619d as nil")
	}
	.PutID(EmojiStatusTypeID)
	return .EncodeBare()
}

// EncodeBare implements bin.BareEncoder.
func ( *EmojiStatus) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode emojiStatus#929b619d as nil")
	}
	.PutLong(.DocumentID)
	return nil
}

// Decode implements bin.Decoder.
func ( *EmojiStatus) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode emojiStatus#929b619d to nil")
	}
	if  := .ConsumeID(EmojiStatusTypeID);  != nil {
		return fmt.Errorf("unable to decode emojiStatus#929b619d: %w", )
	}
	return .DecodeBare()
}

// DecodeBare implements bin.BareDecoder.
func ( *EmojiStatus) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode emojiStatus#929b619d to nil")
	}
	{
		,  := .Long()
		if  != nil {
			return fmt.Errorf("unable to decode emojiStatus#929b619d: field document_id: %w", )
		}
		.DocumentID = 
	}
	return nil
}

// GetDocumentID returns value of DocumentID field.
func ( *EmojiStatus) () ( int64) {
	if  == nil {
		return
	}
	return .DocumentID
}

// EmojiStatusUntil represents TL type `emojiStatusUntil#fa30a8c7`.
// An emoji status¹ valid until the specified date
//
// Links:
//  1. https://core.telegram.org/api/emoji-status
//
// See https://core.telegram.org/constructor/emojiStatusUntil for reference.
type EmojiStatusUntil struct {
	// Custom emoji document ID¹
	//
	// Links:
	//  1) https://core.telegram.org/api/custom-emoji
	DocumentID int64
	// This status is valid until this date
	Until int
}

// EmojiStatusUntilTypeID is TL type id of EmojiStatusUntil.
const EmojiStatusUntilTypeID = 0xfa30a8c7

// construct implements constructor of EmojiStatusClass.
func ( EmojiStatusUntil) () EmojiStatusClass { return & }

// Ensuring interfaces in compile-time for EmojiStatusUntil.
var (
	_ bin.Encoder     = &EmojiStatusUntil{}
	_ bin.Decoder     = &EmojiStatusUntil{}
	_ bin.BareEncoder = &EmojiStatusUntil{}
	_ bin.BareDecoder = &EmojiStatusUntil{}

	_ EmojiStatusClass = &EmojiStatusUntil{}
)

func ( *EmojiStatusUntil) () bool {
	if  == nil {
		return true
	}
	if !(.DocumentID == 0) {
		return false
	}
	if !(.Until == 0) {
		return false
	}

	return true
}

// String implements fmt.Stringer.
func ( *EmojiStatusUntil) () string {
	if  == nil {
		return "EmojiStatusUntil(nil)"
	}
	type  EmojiStatusUntil
	return fmt.Sprintf("EmojiStatusUntil%+v", (*))
}

// FillFrom fills EmojiStatusUntil from given interface.
func ( *EmojiStatusUntil) ( interface {
	() ( int64)
	() ( int)
}) {
	.DocumentID = .()
	.Until = .()
}

// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
func (*EmojiStatusUntil) () uint32 {
	return EmojiStatusUntilTypeID
}

// TypeName returns name of type in TL schema.
func (*EmojiStatusUntil) () string {
	return "emojiStatusUntil"
}

// TypeInfo returns info about TL type.
func ( *EmojiStatusUntil) () tdp.Type {
	 := tdp.Type{
		Name: "emojiStatusUntil",
		ID:   EmojiStatusUntilTypeID,
	}
	if  == nil {
		.Null = true
		return 
	}
	.Fields = []tdp.Field{
		{
			Name:       "DocumentID",
			SchemaName: "document_id",
		},
		{
			Name:       "Until",
			SchemaName: "until",
		},
	}
	return 
}

// Encode implements bin.Encoder.
func ( *EmojiStatusUntil) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode emojiStatusUntil#fa30a8c7 as nil")
	}
	.PutID(EmojiStatusUntilTypeID)
	return .EncodeBare()
}

// EncodeBare implements bin.BareEncoder.
func ( *EmojiStatusUntil) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode emojiStatusUntil#fa30a8c7 as nil")
	}
	.PutLong(.DocumentID)
	.PutInt(.Until)
	return nil
}

// Decode implements bin.Decoder.
func ( *EmojiStatusUntil) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode emojiStatusUntil#fa30a8c7 to nil")
	}
	if  := .ConsumeID(EmojiStatusUntilTypeID);  != nil {
		return fmt.Errorf("unable to decode emojiStatusUntil#fa30a8c7: %w", )
	}
	return .DecodeBare()
}

// DecodeBare implements bin.BareDecoder.
func ( *EmojiStatusUntil) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode emojiStatusUntil#fa30a8c7 to nil")
	}
	{
		,  := .Long()
		if  != nil {
			return fmt.Errorf("unable to decode emojiStatusUntil#fa30a8c7: field document_id: %w", )
		}
		.DocumentID = 
	}
	{
		,  := .Int()
		if  != nil {
			return fmt.Errorf("unable to decode emojiStatusUntil#fa30a8c7: field until: %w", )
		}
		.Until = 
	}
	return nil
}

// GetDocumentID returns value of DocumentID field.
func ( *EmojiStatusUntil) () ( int64) {
	if  == nil {
		return
	}
	return .DocumentID
}

// GetUntil returns value of Until field.
func ( *EmojiStatusUntil) () ( int) {
	if  == nil {
		return
	}
	return .Until
}

// EmojiStatusClassName is schema name of EmojiStatusClass.
const EmojiStatusClassName = "EmojiStatus"

// EmojiStatusClass represents EmojiStatus generic type.
//
// See https://core.telegram.org/type/EmojiStatus for reference.
//
// Example:
//
//	g, err := tg.DecodeEmojiStatus(buf)
//	if err != nil {
//	    panic(err)
//	}
//	switch v := g.(type) {
//	case *tg.EmojiStatusEmpty: // emojiStatusEmpty#2de11aae
//	case *tg.EmojiStatus: // emojiStatus#929b619d
//	case *tg.EmojiStatusUntil: // emojiStatusUntil#fa30a8c7
//	default: panic(v)
//	}
type EmojiStatusClass interface {
	bin.Encoder
	bin.Decoder
	bin.BareEncoder
	bin.BareDecoder
	construct() EmojiStatusClass

	// TypeID returns type id in TL schema.
	//
	// See https://core.telegram.org/mtproto/TL-tl#remarks.
	TypeID() uint32
	// TypeName returns name of type in TL schema.
	TypeName() string
	// String implements fmt.Stringer.
	String() string
	// Zero returns true if current object has a zero value.
	Zero() bool

	// AsNotEmpty tries to map EmojiStatusClass to NotEmptyEmojiStatus.
	AsNotEmpty() (NotEmptyEmojiStatus, bool)
}

// NotEmptyEmojiStatus represents NotEmpty subset of EmojiStatusClass.
type NotEmptyEmojiStatus interface {
	bin.Encoder
	bin.Decoder
	bin.BareEncoder
	bin.BareDecoder
	construct() EmojiStatusClass

	// TypeID returns type id in TL schema.
	//
	// See https://core.telegram.org/mtproto/TL-tl#remarks.
	TypeID() uint32
	// TypeName returns name of type in TL schema.
	TypeName() string
	// String implements fmt.Stringer.
	String() string
	// Zero returns true if current object has a zero value.
	Zero() bool

	// Custom emoji document ID¹
	//
	// Links:
	//  1) https://core.telegram.org/api/custom-emoji
	GetDocumentID() (value int64)
}

// AsNotEmpty tries to map EmojiStatusEmpty to NotEmptyEmojiStatus.
func ( *EmojiStatusEmpty) () (NotEmptyEmojiStatus, bool) {
	,  := (EmojiStatusClass()).(NotEmptyEmojiStatus)
	return , 
}

// AsNotEmpty tries to map EmojiStatus to NotEmptyEmojiStatus.
func ( *EmojiStatus) () (NotEmptyEmojiStatus, bool) {
	,  := (EmojiStatusClass()).(NotEmptyEmojiStatus)
	return , 
}

// AsNotEmpty tries to map EmojiStatusUntil to NotEmptyEmojiStatus.
func ( *EmojiStatusUntil) () (NotEmptyEmojiStatus, bool) {
	,  := (EmojiStatusClass()).(NotEmptyEmojiStatus)
	return , 
}

// DecodeEmojiStatus implements binary de-serialization for EmojiStatusClass.
func ( *bin.Buffer) (EmojiStatusClass, error) {
	,  := .PeekID()
	if  != nil {
		return nil, 
	}
	switch  {
	case EmojiStatusEmptyTypeID:
		// Decoding emojiStatusEmpty#2de11aae.
		 := EmojiStatusEmpty{}
		if  := .Decode();  != nil {
			return nil, fmt.Errorf("unable to decode EmojiStatusClass: %w", )
		}
		return &, nil
	case EmojiStatusTypeID:
		// Decoding emojiStatus#929b619d.
		 := EmojiStatus{}
		if  := .Decode();  != nil {
			return nil, fmt.Errorf("unable to decode EmojiStatusClass: %w", )
		}
		return &, nil
	case EmojiStatusUntilTypeID:
		// Decoding emojiStatusUntil#fa30a8c7.
		 := EmojiStatusUntil{}
		if  := .Decode();  != nil {
			return nil, fmt.Errorf("unable to decode EmojiStatusClass: %w", )
		}
		return &, nil
	default:
		return nil, fmt.Errorf("unable to decode EmojiStatusClass: %w", bin.NewUnexpectedID())
	}
}

// EmojiStatus boxes the EmojiStatusClass providing a helper.
type EmojiStatusBox struct {
	EmojiStatus EmojiStatusClass
}

// Decode implements bin.Decoder for EmojiStatusBox.
func ( *EmojiStatusBox) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("unable to decode EmojiStatusBox to nil")
	}
	,  := DecodeEmojiStatus()
	if  != nil {
		return fmt.Errorf("unable to decode boxed value: %w", )
	}
	.EmojiStatus = 
	return nil
}

// Encode implements bin.Encode for EmojiStatusBox.
func ( *EmojiStatusBox) ( *bin.Buffer) error {
	if  == nil || .EmojiStatus == nil {
		return fmt.Errorf("unable to encode EmojiStatusClass as nil")
	}
	return .EmojiStatus.Encode()
}