/
payment_in.go
85 lines (77 loc) · 5.94 KB
/
payment_in.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package moysklad
import (
"github.com/google/uuid"
)
// PaymentIn Входящий платеж.
// Ключевое слово: paymentin
// Документация МойСклад: https://dev.moysklad.ru/doc/api/remap/1.2/documents/#dokumenty-vhodqschij-platezh
type PaymentIn struct {
AccountID *uuid.UUID `json:"accountId,omitempty"` // ID учетной записи
Agent *Counterparty `json:"agent,omitempty"` // Метаданные контрагента
AgentAccount *AgentAccount `json:"agentAccount,omitempty"` // Метаданные счета контрагента
Applicable *bool `json:"applicable,omitempty"` // Отметка о проведении
Attributes *Attributes `json:"attributes,omitempty"` // Коллекция метаданных доп. полей. Поля объекта
Code *string `json:"code,omitempty"` // Код
Contract *Contract `json:"contract,omitempty"` // Метаданные договора
Created *Timestamp `json:"created,omitempty"` // Дата создания
Deleted *Timestamp `json:"deleted,omitempty"` // Момент последнего удаления
Description *string `json:"description,omitempty"` // Комментарий
ExternalCode *string `json:"externalCode,omitempty"` // Внешний код
Files *Files `json:"files,omitempty"` // Метаданные массива Файлов (Максимальное количество файлов - 100)
Group *Group `json:"group,omitempty"` // Отдел сотрудника
ID *uuid.UUID `json:"id,omitempty"` // ID сущности
IncomingDate *Timestamp `json:"incomingDate,omitempty"` // Входящая дата
IncomingNumber *string `json:"incomingNumber,omitempty"` // Входящий номер
Meta *Meta `json:"meta,omitempty"` // Метаданные
Moment *Timestamp `json:"moment,omitempty"` // Дата документа
Name *string `json:"name,omitempty"` // Наименование
Organization *Organization `json:"organization,omitempty"` // Метаданные юрлица
OrganizationAccount *AgentAccount `json:"organizationAccount,omitempty"` // Метаданные счета юрлица
Owner *Employee `json:"owner,omitempty"` // Владелец (Сотрудник)
PaymentPurpose *string `json:"paymentPurpose,omitempty"` // Назначение платежа
Printed *bool `json:"printed,omitempty"` // Напечатан ли документ
Project *Project `json:"project,omitempty"` // Проект
Published *bool `json:"published,omitempty"` // Опубликован ли документ
Rate *Rate `json:"rate,omitempty"` // Валюта
Shared *bool `json:"shared,omitempty"` // Общий доступ
SalesChannel *SalesChannel `json:"salesChannel,omitempty"` // Метаданные канала продаж
State *State `json:"state,omitempty"` // Метаданные статуса
Sum *float64 `json:"sum,omitempty"` // Сумма
SyncID *uuid.UUID `json:"syncId,omitempty"` // ID синхронизации. После заполнения недоступен для изменения
Updated *Timestamp `json:"updated,omitempty"` // Момент последнего обновления
FactureOut *FactureOut `json:"factureOut,omitempty"` // Ссылка на Счет-фактуру выданный, с которым связан этот платеж в формате Метаданных
Operations *Operations `json:"operations,omitempty"` // Массив ссылок на связанные операции в формате Метаданных
}
func (p PaymentIn) String() string {
return Stringify(p)
}
func (p PaymentIn) MetaType() MetaType {
return MetaTypePaymentIn
}
// BindDocuments Привязка платежей к документам.
// Необходимо передать *Meta документов, к которым необходимо привязать платёж.
// Документация МойСклад: https://dev.moysklad.ru/doc/api/remap/1.2/documents/#dokumenty-obschie-swedeniq-priwqzka-platezhej-k-dokumentam
func (p *PaymentIn) BindDocuments(documentsMeta ...*Meta) *PaymentIn {
if p.Operations == nil {
p.Operations = new(Operations)
}
for _, meta := range documentsMeta {
*p.Operations = append(*p.Operations, Operation{Meta: Deref(meta)})
}
return p
}
// PaymentInTemplateArg
// Документ: Входящий платеж (paymentin)
// Основание, на котором он может быть создан:
// - Заказ покупателя (customerorder)
// - Возврат поставщику (purchasereturn)
// - Отгрузка (demand)
// - Счет покупателю (invoiceout)
// - Полученный отчет комиссионера (commissionreportin)
type PaymentInTemplateArg struct {
CustomerOrder *MetaWrapper `json:"customerOrder,omitempty"`
PurchaseReturn *MetaWrapper `json:"purchaseReturn,omitempty"`
Demand *MetaWrapper `json:"demand,omitempty"`
InvoiceOut *MetaWrapper `json:"invoiceOut,omitempty"`
CommissionReportIn *MetaWrapper `json:"commissionReportIn,omitempty"`
}