summaryrefslogtreecommitdiffstats
path: root/toolkit/components/autocomplete/nsAutoCompleteController.h
diff options
context:
space:
mode:
Diffstat (limited to 'toolkit/components/autocomplete/nsAutoCompleteController.h')
-rw-r--r--toolkit/components/autocomplete/nsAutoCompleteController.h217
1 files changed, 217 insertions, 0 deletions
diff --git a/toolkit/components/autocomplete/nsAutoCompleteController.h b/toolkit/components/autocomplete/nsAutoCompleteController.h
new file mode 100644
index 0000000000..7e6d8a3b06
--- /dev/null
+++ b/toolkit/components/autocomplete/nsAutoCompleteController.h
@@ -0,0 +1,217 @@
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+#ifndef __nsAutoCompleteController__
+#define __nsAutoCompleteController__
+
+#include "nsIAutoCompleteController.h"
+
+#include "nsCOMPtr.h"
+#include "nsIAutoCompleteInput.h"
+#include "nsIAutoCompletePopup.h"
+#include "nsIAutoCompleteResult.h"
+#include "nsIAutoCompleteSearch.h"
+#include "nsINamed.h"
+#include "nsString.h"
+#include "nsITimer.h"
+#include "nsTArray.h"
+#include "nsCOMArray.h"
+#include "nsCycleCollectionParticipant.h"
+#include "mozilla/dom/Element.h"
+
+class nsAutoCompleteController final : public nsIAutoCompleteController,
+ public nsIAutoCompleteObserver,
+ public nsITimerCallback,
+ public nsINamed {
+ public:
+ NS_DECL_CYCLE_COLLECTING_ISUPPORTS
+ NS_DECL_CYCLE_COLLECTION_CLASS_AMBIGUOUS(nsAutoCompleteController,
+ nsIAutoCompleteController)
+ NS_DECL_NSIAUTOCOMPLETECONTROLLER
+ NS_DECL_NSIAUTOCOMPLETEOBSERVER
+ NS_DECL_NSITIMERCALLBACK
+ NS_DECL_NSINAMED
+
+ nsAutoCompleteController();
+
+ protected:
+ MOZ_CAN_RUN_SCRIPT virtual ~nsAutoCompleteController();
+
+ /**
+ * SetValueOfInputTo() sets value of mInput to aValue.
+ */
+ void SetValueOfInputTo(const nsString& aValue);
+
+ /**
+ * SetSearchStringInternal() sets both mSearchString and mSetValue to
+ * aSearchString.
+ */
+ void SetSearchStringInternal(const nsAString& aSearchString) {
+ mSearchString = mSetValue = aSearchString;
+ }
+
+ MOZ_CAN_RUN_SCRIPT nsresult OpenPopup();
+ MOZ_CAN_RUN_SCRIPT nsresult ClosePopup();
+
+ nsresult StartSearch(uint16_t aSearchType);
+
+ nsresult BeforeSearches();
+ MOZ_CAN_RUN_SCRIPT nsresult StartSearches();
+ MOZ_CAN_RUN_SCRIPT void AfterSearches();
+ nsresult ClearSearchTimer();
+ void MaybeCompletePlaceholder();
+
+ MOZ_CAN_RUN_SCRIPT nsresult ProcessResult(int32_t aSearchIndex,
+ nsIAutoCompleteResult* aResult);
+ MOZ_CAN_RUN_SCRIPT nsresult PostSearchCleanup();
+
+ MOZ_CAN_RUN_SCRIPT nsresult EnterMatch(bool aIsPopupSelection,
+ mozilla::dom::Event* aEvent);
+ nsresult RevertTextValue();
+
+ nsresult CompleteDefaultIndex(int32_t aResultIndex);
+ nsresult CompleteValue(nsString& aValue);
+
+ nsresult GetResultAt(int32_t aIndex, nsIAutoCompleteResult** aResult,
+ int32_t* aMatchIndex);
+ nsresult GetResultValueAt(int32_t aIndex, bool aGetFinalValue,
+ nsAString& _retval);
+ nsresult GetResultLabelAt(int32_t aIndex, nsAString& _retval);
+
+ /**
+ * Returns autocomplete popup for the autocomplete input. nsIAutoCompleteInput
+ * can be implemented two different ways to return a popup. The first one is
+ * to return a popup object implementing nsIAutoCompletePopup interface,
+ * the second one is a DOM element representing a popup and implementing
+ * that interface.
+ */
+ already_AddRefed<nsIAutoCompletePopup> GetPopup() {
+ nsCOMPtr<nsIAutoCompletePopup> popup;
+ mInput->GetPopup(getter_AddRefs(popup));
+ if (popup) {
+ return popup.forget();
+ }
+
+ nsCOMPtr<mozilla::dom::Element> popupEl;
+ mInput->GetPopupElement(getter_AddRefs(popupEl));
+ if (popupEl) {
+ return popupEl->AsAutoCompletePopup();
+ }
+ return nullptr;
+ }
+
+ private:
+ nsresult GetResultValueLabelAt(int32_t aIndex, bool aGetFinalValue,
+ bool aGetValue, nsAString& _retval);
+
+ /**
+ * Gets and validates the defaultComplete result and the relative
+ * defaultIndex value.
+ *
+ * @param aResultIndex
+ * Index of the defaultComplete result to be used. Pass -1 to search
+ * for the first result providing a valid defaultIndex.
+ * @param _result
+ * The found result.
+ * @param _defaultIndex
+ * The defaultIndex relative to _result.
+ */
+ nsresult GetDefaultCompleteResult(int32_t aResultIndex,
+ nsIAutoCompleteResult** _result,
+ int32_t* _defaultIndex);
+
+ /**
+ * Gets the defaultComplete value to be suggested to the user.
+ *
+ * @param aResultIndex
+ * Index of the defaultComplete result to be used.
+ * @param aPreserveCasing
+ * Whether user casing should be preserved.
+ * @param _retval
+ * The value to be completed.
+ */
+ nsresult GetDefaultCompleteValue(int32_t aResultIndex, bool aPreserveCasing,
+ nsAString& _retval);
+
+ /**
+ * Gets the defaultComplete value to be used when the user confirms the
+ * current match.
+ * The value is returned only if it case-insensitively matches the current
+ * input text, otherwise the method returns NS_ERROR_FAILURE.
+ * This happens because we don't want to replace text if the user backspaces
+ * just before Enter.
+ *
+ * @param _retval
+ * The value to be completed.
+ */
+ nsresult GetFinalDefaultCompleteValue(nsAString& _retval);
+
+ nsresult ClearResults(bool aIsSearching = false);
+
+ nsresult MatchIndexToSearch(int32_t aMatchIndex, int32_t* aSearchIndex,
+ int32_t* aItemIndex);
+
+ // members //////////////////////////////////////////
+
+ nsCOMPtr<nsIAutoCompleteInput> mInput;
+
+ nsCOMArray<nsIAutoCompleteSearch> mSearches;
+ // This is used as a sparse array, always use SafeObjectAt to access it.
+ nsCOMArray<nsIAutoCompleteResult> mResults;
+ // Temporarily keeps the results alive while invoking startSearch() for each
+ // search. This is needed to allow the searches to reuse the previous result,
+ // since otherwise the first search clears mResults.
+ nsCOMArray<nsIAutoCompleteResult> mResultCache;
+
+ nsCOMPtr<nsITimer> mTimer;
+
+ // mSearchString stores value which is the original value of the input or
+ // typed by the user. When user is choosing an item from the popup, this
+ // is NOT modified by the item because this is used for reverting the input
+ // value when user cancels choosing an item from the popup.
+ // This should be set through only SetSearchStringInternal().
+ nsString mSearchString;
+ nsString mPlaceholderCompletionString;
+ // mSetValue stores value which is expected in the input. So, if input's
+ // value and mSetValue are different, it means somebody has changed the
+ // value like JS of the web content.
+ // This is set only by SetValueOfInputTo() or when modifying mSearchString
+ // through SetSearchStringInternal().
+ nsString mSetValue;
+ bool mDefaultIndexCompleted;
+ bool mPopupClosedByCompositionStart;
+
+ // Whether autofill is allowed for the next search. May be retrieved by the
+ // search through the "prohibit-autofill" searchParam.
+ bool mProhibitAutoFill;
+
+ // Indicates whether the user cleared the autofilled part, returning to the
+ // originally entered search string.
+ bool mUserClearedAutoFill;
+
+ // Indicates whether clearing the autofilled string should issue a new search.
+ bool mClearingAutoFillSearchesAgain;
+
+ enum CompositionState {
+ eCompositionState_None,
+ eCompositionState_Composing,
+ eCompositionState_Committing
+ };
+ CompositionState mCompositionState;
+ uint16_t mSearchStatus;
+ uint32_t mMatchCount;
+ uint32_t mSearchesOngoing;
+ uint32_t mSearchesFailed;
+ uint32_t mImmediateSearchesCount;
+ // The index of the match on the popup that was selected using the keyboard,
+ // if the completeselectedindex attribute is set.
+ // This is used to distinguish that selection (which would have been put in
+ // the input on being selected) from a moused-over selectedIndex value. This
+ // distinction is used to prevent mouse moves from inadvertently changing
+ // what happens once the user hits Enter on the keyboard.
+ // See bug 1043584 for more details.
+ int32_t mCompletedSelectionIndex;
+};
+
+#endif /* __nsAutoCompleteController__ */