summaryrefslogtreecommitdiffstats
path: root/src/app/globalAutoCompleteSearchBar/GlobalAutoCompleteSearchBarActions.js
diff options
context:
space:
mode:
authorARULNA <arul.nambi@amdocs.com>2017-06-02 16:27:25 -0400
committerARULNA <arul.nambi@amdocs.com>2017-06-02 16:33:14 -0400
commitca007e933bcd9f63aa77801656ed9dd4142c432c (patch)
treece97ed9df8c4fe48a524f0dc1365ad28acef7c46 /src/app/globalAutoCompleteSearchBar/GlobalAutoCompleteSearchBarActions.js
parent42b788b852f0604748828e9e325e4a0f01152c75 (diff)
Initial coomit for AAI-UI(sparky-fe)
Change-Id: I9f8482824a52bac431c100939899e760c0fa4fdb Signed-off-by: ARULNA <arul.nambi@amdocs.com>
Diffstat (limited to 'src/app/globalAutoCompleteSearchBar/GlobalAutoCompleteSearchBarActions.js')
-rw-r--r--src/app/globalAutoCompleteSearchBar/GlobalAutoCompleteSearchBarActions.js176
1 files changed, 176 insertions, 0 deletions
diff --git a/src/app/globalAutoCompleteSearchBar/GlobalAutoCompleteSearchBarActions.js b/src/app/globalAutoCompleteSearchBar/GlobalAutoCompleteSearchBarActions.js
new file mode 100644
index 0000000..4ef684d
--- /dev/null
+++ b/src/app/globalAutoCompleteSearchBar/GlobalAutoCompleteSearchBarActions.js
@@ -0,0 +1,176 @@
+/*
+ * ============LICENSE_START===================================================
+ * SPARKY (AAI UI service)
+ * ============================================================================
+ * Copyright © 2017 AT&T Intellectual Property.
+ * Copyright © 2017 Amdocs
+ * All rights reserved.
+ * ============================================================================
+ * 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.
+ * ============LICENSE_END=====================================================
+ *
+ * ECOMP and OpenECOMP are trademarks
+ * and service marks of AT&T Intellectual Property.
+ */
+
+import {getTSUIElasticSearchQueryString} from 'app/networking/NetworkUtil.js';
+import networkCall from 'app/networking/NetworkCalls.js';
+import {
+ POST,
+ POST_HEADER,
+ ERROR_RETRIEVING_DATA
+} from 'app/networking/NetworkConstants.js';
+
+import {
+ globalAutoCompleteSearchBarActionTypes,
+ ERROR_INVALID_SEARCH_TERMS,
+ GLOBAL_SEARCH_URL
+} from 'app/globalAutoCompleteSearchBar/GlobalAutoCompleteSearchBarConstants.js';
+import {
+ getSetGlobalMessageEvent,
+ getClearGlobalMessageEvent
+} from 'app/GlobalInlineMessageBar/GlobalInlineMessageBarActions.js';
+
+
+function createSuggestionFoundEvent({suggestions}) {
+ return {
+ type: globalAutoCompleteSearchBarActionTypes.SUGGESTION_FOUND,
+ data: {suggestions}
+ };
+}
+
+function createSuggestionNotFoundEvent() {
+ return {
+ type: globalAutoCompleteSearchBarActionTypes.SUGGESTION_NOT_FOUND
+ };
+}
+
+function createSuggestionChangedEvent(value) {
+ return {
+ type: globalAutoCompleteSearchBarActionTypes.SUGGESTION_CHANGED,
+ data: value
+ };
+}
+
+function getInvalidQueryEvent(value) {
+ return {
+ type: globalAutoCompleteSearchBarActionTypes.NETWORK_ERROR,
+ data: {value: value, errorMsg: ERROR_RETRIEVING_DATA}
+ };
+}
+
+function getSearchBarWarningMessageEvent(message) {
+ return {
+ type: globalAutoCompleteSearchBarActionTypes.SEARCH_WARNING_EVENT,
+ data: {errorMsg: message}
+ };
+}
+export function getInvalidSearchInputEvent(value) {
+ return getSearchBarWarningMessageEvent(
+ ERROR_INVALID_SEARCH_TERMS + ': ' + value);
+}
+
+
+function fetchView(selectedSuggestion) {
+ return {
+ type: globalAutoCompleteSearchBarActionTypes.SUGGESTION_CLICKED,
+ data: {selectedSuggestion: selectedSuggestion}
+ };
+}
+
+
+export function populateView(
+ searchRequestObject, keyWord, selectedNodeFetchRequest) {
+ if (selectedNodeFetchRequest === undefined) {
+ let postBody = JSON.stringify(searchRequestObject);
+ selectedNodeFetchRequest =
+ () => networkCall.fetchRequest('', POST,
+ POST_HEADER, postBody);
+ }
+
+ return dispatch => {
+ dispatch(fetchView(searchRequestObject));
+ };
+}
+
+
+export function fetchRequestedValues(fetchRequestCallback, keyWord) {
+ return dispatch => {
+ return fetchRequestCallback().then(
+ (responseJson) => responseJson.suggestions
+ ).then(
+ (filteredResults)=> {
+ if (filteredResults.length > 0) {
+ dispatch(createSuggestionFoundEvent({suggestions: filteredResults}));
+ } else {
+ dispatch(createSuggestionNotFoundEvent());
+ }
+ }
+ ).catch(
+ () => {
+ dispatch(getInvalidQueryEvent(keyWord));
+ }
+ );
+ };
+}
+
+export function queryRequestedValues(keyWord, requestedFetchRequest) {
+ if (requestedFetchRequest === undefined) {
+ let postBody = JSON.stringify(getTSUIElasticSearchQueryString(keyWord));
+ requestedFetchRequest =
+ () => networkCall.fetchRequest(GLOBAL_SEARCH_URL, POST, POST_HEADER,
+ postBody);
+ }
+ return dispatch => {
+ dispatch(fetchRequestedValues(requestedFetchRequest, keyWord), keyWord);
+ };
+}
+
+export function clearSuggestionsTextField() {
+ return dispatch => {
+ dispatch(
+ {type: globalAutoCompleteSearchBarActionTypes.CLEAR_SUGGESTIONS_TEXT_FIELD});
+ };
+}
+
+export function onSuggestionsChange(event, value) {
+ return dispatch => {
+ dispatch(createSuggestionChangedEvent(value));
+ //Only fetch values if the enter key is used.
+ if (event.keyCode === 13) {
+ let postBody = JSON.stringify(getTSUIElasticSearchQueryString(value));
+ dispatch(fetchRequestedValues(
+ () => networkCall.fetchRequest(GLOBAL_SEARCH_URL, POST, POST_HEADER,
+ postBody), value));
+ }
+ };
+}
+
+export function onSuggestionsClearRequested() {
+ return dispatch => {
+ dispatch({type: globalAutoCompleteSearchBarActionTypes.CLEAR_SUGGESTIONS});
+ };
+}
+
+export function setNotificationText(msgText, msgSeverity) {
+ if (msgText.length > 0) {
+ return dispatch => {
+ dispatch(
+ getSetGlobalMessageEvent(msgText, msgSeverity));
+ };
+ } else {
+ return dispatch => {
+ dispatch(getClearGlobalMessageEvent());
+ };
+ }
+}