/* * Copyright 2017 Google * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #import NS_ASSUME_NONNULL_BEGIN /** * Sentinel values that can be used when writing document fields with setData() or updateData(). */ NS_SWIFT_NAME(FieldValue) @interface FIRFieldValue : NSObject /** */ - (instancetype)init NS_UNAVAILABLE; /** Used with updateData() to mark a field for deletion. */ // clang-format off + (instancetype)fieldValueForDelete NS_SWIFT_NAME(delete()); // clang-format on /** * Used with setData() or updateData() to include a server-generated timestamp in the written * data. */ + (instancetype)fieldValueForServerTimestamp NS_SWIFT_NAME(serverTimestamp()); /** * Returns a special value that can be used with setData() or updateData() that tells the server to * union the given elements with any array value that already exists on the server. Each * specified element that doesn't already exist in the array will be added to the end. If the * field being modified is not already an array it will be overwritten with an array containing * exactly the specified elements. * * @param elements The elements to union into the array. * @return The FieldValue sentinel for use in a call to setData() or updateData(). */ + (instancetype)fieldValueForArrayUnion:(NSArray *)elements NS_SWIFT_NAME(arrayUnion(_:)); /** * Returns a special value that can be used with setData() or updateData() that tells the server to * remove the given elements from any array value that already exists on the server. All * instances of each element specified will be removed from the array. If the field being * modified is not already an array it will be overwritten with an empty array. * * @param elements The elements to remove from the array. * @return The FieldValue sentinel for use in a call to setData() or updateData(). */ + (instancetype)fieldValueForArrayRemove:(NSArray *)elements NS_SWIFT_NAME(arrayRemove(_:)); @end NS_ASSUME_NONNULL_END