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

com.adobe.cq.xf.ui.ExperienceFragmentConsoleItem Maven / Gradle / Ivy

/*******************************************************************************
 * ADOBE CONFIDENTIAL
 * __________________
 *
 * Copyright 2016 Adobe Systems Incorporated
 * All Rights Reserved.
 *
 * NOTICE:  All information contained herein is, and remains
 * the property of Adobe Systems Incorporated and its suppliers,
 * if any.  The intellectual and technical concepts contained
 * herein are proprietary to Adobe Systems Incorporated and its
 * suppliers and are protected by trade secret or copyright law.
 * Dissemination of this information or reproduction of this material
 * is strictly forbidden unless prior written permission is obtained
 * from Adobe Systems Incorporated.
 ******************************************************************************/

package com.adobe.cq.xf.ui;

import aQute.bnd.annotation.ProviderType;
import com.day.cq.wcm.api.Page;

import javax.jcr.RepositoryException;
import java.util.Calendar;
import java.util.Set;

/**
 * The administration console item for experience fragments.
 */
@ProviderType
public interface ExperienceFragmentConsoleItem {

    /**
     * Returns the path of the experience fragment.
     *
     * @return String
     */
    String getPath();

    /**
     * Returns the resource type of the experience fragment. Can be the original cq/experience-fragments/components/xfpage or an overlay.
     *
     * @return String
     */
    String getResourceType();

    /**
     * Returns the title of the experience fragment page.
     * @return String
     */
    String getTitle();

    /**
     * Returns the last modification date of the resource.
     *
     * @return {@link Calendar} object
     */
    Calendar getLastModified();

    /**
     * Returns the name of the user that modified this resource.
     *
     * @return String
     */
    String getLastModifiedBy();

    /**
     * Returns the date that this resource was published (activated).
     *
     * @return a {@link Calendar} object or null if the page is not published
     */
    Calendar getPublishedDate();

    /**
     * Returns a set of relation identifiers for the quick actions.
     *
     * @return Set of relation identifiers
     */
    Set getQuickactionsRel() throws RepositoryException;

    /**
     * Returns the URL for the "Properties" action. This URL is determined according to the resource type.
     *
     * @return the "href" property for the "Properties" action.
     */
    String getViewPropertiesHref();

    /**
     * Checks whether the current item is a folder or not.
     *
     * @return true if the resource of this item is a folder, and false otherwise.
     */
    boolean isFolder();

    /**
     * Checks whether the current resource is a live-copy or not.
     *
     * @return true if the page is a live-copy, and false otherwise.
     */
    boolean isLiveCopy();

    /**
     * Checks whether the page represented by this item was created in the last 24hrs.
     *
     * @return true if the page was created in the last 24hrs, false otherwise
     */
    boolean isNew();

    /**
     * Checks whether this resource is an experience fragment "root" page and not a variation.
     *
     * @return
     */
    boolean isExperienceFragmentRoot();

    /**
     * Returns the parent Experience Fragment for this variation
     * @return the {@link Page} which is the Experience Fragment if the current page is a variation or {@code null} otherwise
     */
    Page getParentXf();

    /**
     * Determines the URL that the user navigates when clicking the item.
     *
     * @return A valid URL, or an empty string if the item represents an experience fragment variant.
     */
    String getNavigatorHref();

    /**
     * Checks if the experience fragment is exported as an Adobe Target offer.
     * @return {@code true} if the variation is exported to Adobe Target, {@code false} otherwise
     */
    boolean isExportedToAdobeTarget();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy