All Downloads are FREE. Search and download functionalities are using the official Maven repository.

pro.zackpollard.telegrambot.api.keyboards.KeyboardButton Maven / Gradle / Ivy

package pro.zackpollard.telegrambot.api.keyboards;

import lombok.AccessLevel;
import lombok.NonNull;
import lombok.RequiredArgsConstructor;
import lombok.ToString;

/**
 * @author zackp
 */
@ToString
@RequiredArgsConstructor(access = AccessLevel.PRIVATE)
public class KeyboardButton {

    @NonNull
    private final String text;
    private final boolean request_contact;
    private final boolean request_location;

    /**
     * This builder will allow you to progressively construct this object.
     *
     * @return A KeyboardButtonBuilder object used to construct the KeyboardButton object
     */
    public static KeyboardButtonBuilder builder() {
        return new KeyboardButtonBuilder();
    }

    /**
     * Gets the text that this KeyboardButton will have
     *
     * @return The text that this KeyboardButton will have
     */
    public String getText() {
        return this.text;
    }

    /**
     * Gets whether the users contact should be sent when the button is pressed. If True, the user's phone number will
     * be sent as a contact when the button is pressed. Available in private chats only
     *
     * @return True if the users contact should be sent, otherwise False
     */
    public boolean isRequestContact() {
        return this.request_contact;
    }

    /**
     * Gets whether the users location should be sent when the button is pressed.  If True, the user's current location
     * will be sent when the button is pressed. Available in private chats only
     *
     * @return True if the users location should be sent, otherwise False
     */
    public boolean isRequestLocation() {
        return this.request_location;
    }

    @ToString
    public static class KeyboardButtonBuilder {
        private String text;
        private boolean request_contact = false;
        private boolean request_location = false;

        KeyboardButtonBuilder() {
        }

        /**
         * *Required*
         * Sets the text that will be displayed on this button
         *
         * @param text The text that will be displayed on this button
         *
         * @return The builder object
         */
        public KeyboardButton.KeyboardButtonBuilder text(String text) {
            this.text = text;
            return this;
        }

        /**
         * *Optional*
         * Sets whether the button should request the users contact information when clicked
         *
         * @param requestContact True will set the button to request the contact information, False is the default
         *
         * @return The builder object
         */
        public KeyboardButton.KeyboardButtonBuilder requestContact(boolean requestContact) {
            this.request_contact = requestContact;
            if(requestContact) this.request_location = false;
            return this;
        }

        /**
         * *Optional*
         * Sets whether the button should request the users location information when clicked
         *
         * @param requestLocation True will set the button to request the location information, False is the default
         *
         * @return The builder object
         */
        public KeyboardButton.KeyboardButtonBuilder requestLocation(boolean requestLocation) {
            this.request_location = requestLocation;
            if(requestLocation) this.request_contact = false;
            return this;
        }

        /**
         * Builds the KeyboardButton object
         *
         * @return A KeyboardButton object based on the previously provided values
         */
        public KeyboardButton build() {
            return new KeyboardButton(text, request_contact, request_location);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy