Для изменения размера нажмите или перетащите

CardExtensionHelperFixUniqueIdentifiersOnClientAsync - метод

Исправляет список уникальных ссылок, задаваемых идентификаторами любого типа в полях identifierFieldName в коллекционной секции с именем sectionName. Под уникальностью ссылки подразумевается, что в одну и ту же карточку не может быть добавлено более одной ссылки с одним и тем же идентификатором. Метод следует вызывать в расширении на сохранение карточки, файла или задания, передаваемого в поле card.

Пространство имён:  Tessa.Cards.Extensions
Сборка:  Tessa (в Tessa.dll) Версия: 3.5.0.19
Синтаксис
public static ValueTask FixUniqueIdentifiersOnClientAsync(
	Card card,
	string sectionName,
	string identifierFieldName,
	string parentRowIDFieldName = null,
	string orderFieldName = null,
	Func<IList<CardRow>, CardRow, CancellationToken, ValueTask> removeRowFuncAsync = null,
	CancellationToken cancellationToken = default
)

Параметры

card
Тип: Tessa.CardsCard
Сохраняемая карточка. Может быть обычной карточкой, файлов или заданием.
sectionName
Тип: SystemString
Имя коллекционной секции, которая содержит список идентификаторов.
identifierFieldName
Тип: SystemString
Имя поля в секции sectionName, которое содержит идентификатор любого типа, уникальность которого требуется обеспечить в пределах карточки.
parentRowIDFieldName (Optional)
Тип: SystemString
Имя поля в секции sectionName, которое содержит идентификатор родительской строки, уникальность которого требуется обеспечить в пределах карточки, или null, если секция sectionName не является дочерней.
orderFieldName (Optional)
Тип: SystemString
Имя поля для сортировки в строках карточки или null, если поле не задано.
removeRowFuncAsync (Optional)
Тип: SystemFuncIListCardRow, CardRow, CancellationToken, ValueTask
Функция, выполняющая удаление указанной строки из коллекции строк, или null, если строка удаляется обычным образом. Переопределять удаление имеет смысл на клиенте, где также требуется удалить дочерние строки из структуры карточки.
cancellationToken (Optional)
Тип: System.ThreadingCancellationToken
Объект, посредством которого можно отменить асинхронную задачу.

Возвращаемое значение

Тип: ValueTask
Асинхронная задача.
Заметки

Метод гарантирует, что если пользователь удалит и тут же добавит строку с таким же идентификатором в поле identifierFieldName, то удалённая не будет удалена, а новая строка не будет добавлена.

Рекомендуется использовать метод в случае, если в секции sectionName есть уникальный индекс на идентификатор карточки и идентификатор в поле identifierFieldName.

См. также