mirror of
				https://github.com/Azure/cosmos-explorer.git
				synced 2025-10-25 13:09:02 +01:00 
			
		
		
		
	Enable Full Text Search on all NoSQL accounts (#2157)
* Enable Full Text Search on all NoSQL accounts * format * fix tests * run tests --------- Co-authored-by: Asier Isayas <aisayas@microsoft.com>
This commit is contained in:
		
							parent
							
								
									45513e5e1b
								
							
						
					
					
						commit
						f14b574527
					
				| @ -13,7 +13,7 @@ import { | ||||
| } from "Explorer/Controls/Settings/SettingsSubComponents/ThroughputInputComponents/ThroughputBucketsComponent"; | ||||
| import { useDatabases } from "Explorer/useDatabases"; | ||||
| import { isFabricNative } from "Platform/Fabric/FabricUtil"; | ||||
| import { isFullTextSearchEnabled, isVectorSearchEnabled } from "Utils/CapabilityUtils"; | ||||
| import { isVectorSearchEnabled } from "Utils/CapabilityUtils"; | ||||
| import { isRunningOnPublicCloud } from "Utils/CloudUtils"; | ||||
| import * as React from "react"; | ||||
| import DiscardIcon from "../../../../images/discard.svg"; | ||||
| @ -188,7 +188,7 @@ export class SettingsComponent extends React.Component<SettingsComponentProps, S | ||||
|       this.isGlobalSecondaryIndex = | ||||
|         !!this.collection?.materializedViewDefinition() || !!this.collection?.materializedViews(); | ||||
|       this.isVectorSearchEnabled = isVectorSearchEnabled() && !hasDatabaseSharedThroughput(this.collection); | ||||
|       this.isFullTextSearchEnabled = isFullTextSearchEnabled() && !hasDatabaseSharedThroughput(this.collection); | ||||
|       this.isFullTextSearchEnabled = userContext.apiType === "SQL"; | ||||
| 
 | ||||
|       this.changeFeedPolicyVisible = userContext.features.enableChangeFeedPolicy; | ||||
|       this.throughputBucketsEnabled = userContext.throughputBucketsEnabled; | ||||
|  | ||||
| @ -198,6 +198,32 @@ exports[`SettingsComponent renders 1`] = ` | ||||
|           timeToLiveSecondsBaseline={5} | ||||
|         /> | ||||
|       </PivotItem> | ||||
|       <PivotItem | ||||
|         headerText="Container Policies" | ||||
|         itemKey="ContainerVectorPolicyTab" | ||||
|         key="ContainerVectorPolicyTab" | ||||
|         style={ | ||||
|           { | ||||
|             "marginTop": 20, | ||||
|           } | ||||
|         } | ||||
|       > | ||||
|         <ContainerPolicyComponent | ||||
|           fullTextPolicy={{}} | ||||
|           fullTextPolicyBaseline={{}} | ||||
|           isFullTextSearchEnabled={true} | ||||
|           isGlobalSecondaryIndex={true} | ||||
|           isVectorSearchEnabled={false} | ||||
|           onFullTextPolicyChange={[Function]} | ||||
|           onFullTextPolicyDirtyChange={[Function]} | ||||
|           onVectorEmbeddingPolicyChange={[Function]} | ||||
|           onVectorEmbeddingPolicyDirtyChange={[Function]} | ||||
|           resetShouldDiscardContainerPolicyChange={[Function]} | ||||
|           shouldDiscardContainerPolicies={false} | ||||
|           vectorEmbeddingPolicy={{}} | ||||
|           vectorEmbeddingPolicyBaseline={{}} | ||||
|         /> | ||||
|       </PivotItem> | ||||
|       <PivotItem | ||||
|         headerText="Indexing Policy" | ||||
|         itemKey="IndexingPolicyTab" | ||||
|  | ||||
| @ -49,12 +49,7 @@ import { Action } from "Shared/Telemetry/TelemetryConstants"; | ||||
| import * as TelemetryProcessor from "Shared/Telemetry/TelemetryProcessor"; | ||||
| import { userContext } from "UserContext"; | ||||
| import { getCollectionName } from "Utils/APITypeUtils"; | ||||
| import { | ||||
|   isCapabilityEnabled, | ||||
|   isFullTextSearchEnabled, | ||||
|   isServerlessAccount, | ||||
|   isVectorSearchEnabled, | ||||
| } from "Utils/CapabilityUtils"; | ||||
| import { isCapabilityEnabled, isServerlessAccount, isVectorSearchEnabled } from "Utils/CapabilityUtils"; | ||||
| import { getUpsellMessage } from "Utils/PricingUtils"; | ||||
| import { ValidCosmosDbIdDescription, ValidCosmosDbIdInputPattern } from "Utils/ValidationUtils"; | ||||
| import { CollapsibleSectionComponent } from "../../Controls/CollapsiblePanel/CollapsibleSectionComponent"; | ||||
| @ -110,6 +105,7 @@ export class AddCollectionPanel extends React.Component<AddCollectionPanelProps, | ||||
|   private collectionThroughput: number; | ||||
|   private isCollectionAutoscale: boolean; | ||||
|   private isCostAcknowledged: boolean; | ||||
|   private showFullTextSearch: boolean; | ||||
| 
 | ||||
|   constructor(props: AddCollectionPanelProps) { | ||||
|     super(props); | ||||
| @ -144,6 +140,8 @@ export class AddCollectionPanel extends React.Component<AddCollectionPanelProps, | ||||
|       fullTextIndexes: [], | ||||
|       fullTextPolicyValidated: true, | ||||
|     }; | ||||
| 
 | ||||
|     this.showFullTextSearch = userContext.apiType === "SQL"; | ||||
|   } | ||||
| 
 | ||||
|   componentDidMount(): void { | ||||
| @ -869,7 +867,7 @@ export class AddCollectionPanel extends React.Component<AddCollectionPanelProps, | ||||
|               </CollapsibleSectionComponent> | ||||
|             </Stack> | ||||
|           )} | ||||
|           {this.shouldShowFullTextSearchParameters() && ( | ||||
|           {this.showFullTextSearch && ( | ||||
|             <Stack> | ||||
|               <CollapsibleSectionComponent | ||||
|                 title="Container Full Text Search Policy" | ||||
| @ -1160,10 +1158,6 @@ export class AddCollectionPanel extends React.Component<AddCollectionPanelProps, | ||||
|     return isVectorSearchEnabled() && (isServerlessAccount() || this.shouldShowCollectionThroughputInput()); | ||||
|   } | ||||
| 
 | ||||
|   private shouldShowFullTextSearchParameters() { | ||||
|     return isFullTextSearchEnabled() && (isServerlessAccount() || this.shouldShowCollectionThroughputInput()); | ||||
|   } | ||||
| 
 | ||||
|   private parseUniqueKeys(): DataModels.UniqueKeyPolicy { | ||||
|     if (this.state.uniqueKeys?.length === 0) { | ||||
|       return undefined; | ||||
| @ -1316,7 +1310,7 @@ export class AddCollectionPanel extends React.Component<AddCollectionPanelProps, | ||||
|       }; | ||||
|     } | ||||
| 
 | ||||
|     if (this.shouldShowFullTextSearchParameters()) { | ||||
|     if (this.showFullTextSearch) { | ||||
|       indexingPolicy.fullTextIndexes = this.state.fullTextIndexes; | ||||
|     } | ||||
| 
 | ||||
|  | ||||
| @ -411,6 +411,44 @@ exports[`AddCollectionPanel should render Default properly 1`] = ` | ||||
|         /> | ||||
|       </Stack> | ||||
|     </Stack> | ||||
|     <Stack> | ||||
|       <CollapsibleSectionComponent | ||||
|         isExpandedByDefault={false} | ||||
|         onExpand={[Function]} | ||||
|         title="Container Full Text Search Policy" | ||||
|       > | ||||
|         <Stack | ||||
|           id="collapsibleFullTextPolicySectionContent" | ||||
|           styles={ | ||||
|             { | ||||
|               "root": { | ||||
|                 "position": "relative", | ||||
|               }, | ||||
|             } | ||||
|           } | ||||
|         > | ||||
|           <Stack | ||||
|             styles={ | ||||
|               { | ||||
|                 "root": { | ||||
|                   "paddingLeft": 40, | ||||
|                 }, | ||||
|               } | ||||
|             } | ||||
|           > | ||||
|             <FullTextPoliciesComponent | ||||
|               fullTextPolicy={ | ||||
|                 { | ||||
|                   "defaultLanguage": "en-US", | ||||
|                   "fullTextPaths": [], | ||||
|                 } | ||||
|               } | ||||
|               onFullTextPathChange={[Function]} | ||||
|             /> | ||||
|           </Stack> | ||||
|         </Stack> | ||||
|       </CollapsibleSectionComponent> | ||||
|     </Stack> | ||||
|     <CollapsibleSectionComponent | ||||
|       isExpandedByDefault={false} | ||||
|       onExpand={[Function]} | ||||
|  | ||||
| @ -40,12 +40,12 @@ import { PanelInfoErrorComponent } from "Explorer/Panes/PanelInfoErrorComponent" | ||||
| import { PanelLoadingScreen } from "Explorer/Panes/PanelLoadingScreen"; | ||||
| import { useDatabases } from "Explorer/useDatabases"; | ||||
| import { useSidePanel } from "hooks/useSidePanel"; | ||||
| import React, { useEffect, useState } from "react"; | ||||
| import React, { MutableRefObject, useEffect, useRef, useState } from "react"; | ||||
| import { CollectionCreation } from "Shared/Constants"; | ||||
| import { Action } from "Shared/Telemetry/TelemetryConstants"; | ||||
| import * as TelemetryProcessor from "Shared/Telemetry/TelemetryProcessor"; | ||||
| import { userContext } from "UserContext"; | ||||
| import { isFullTextSearchEnabled, isServerlessAccount, isVectorSearchEnabled } from "Utils/CapabilityUtils"; | ||||
| import { isServerlessAccount, isVectorSearchEnabled } from "Utils/CapabilityUtils"; | ||||
| import { ValidCosmosDbIdDescription, ValidCosmosDbIdInputPattern } from "Utils/ValidationUtils"; | ||||
| 
 | ||||
| export interface AddGlobalSecondaryIndexPanelProps { | ||||
| @ -75,6 +75,8 @@ export const AddGlobalSecondaryIndexPanel = (props: AddGlobalSecondaryIndexPanel | ||||
|   const [showErrorDetails, setShowErrorDetails] = useState<boolean>(); | ||||
|   const [isExecuting, setIsExecuting] = useState<boolean>(); | ||||
| 
 | ||||
|   const showFullTextSearch: MutableRefObject<boolean> = useRef<boolean>(userContext.apiType === "SQL"); | ||||
| 
 | ||||
|   useEffect(() => { | ||||
|     const sourceContainerOptions: IDropdownOption[] = []; | ||||
|     useDatabases.getState().databases.forEach((database: Database) => { | ||||
| @ -140,10 +142,6 @@ export const AddGlobalSecondaryIndexPanel = (props: AddGlobalSecondaryIndexPanel | ||||
|     return isVectorSearchEnabled() && (isServerlessAccount() || showCollectionThroughputInput()); | ||||
|   }; | ||||
| 
 | ||||
|   const showFullTextSearchParameters = (): boolean => { | ||||
|     return isFullTextSearchEnabled() && (isServerlessAccount() || showCollectionThroughputInput()); | ||||
|   }; | ||||
| 
 | ||||
|   const getAnalyticalStorageTtl = (): number => { | ||||
|     if (!isSynapseLinkEnabled()) { | ||||
|       return undefined; | ||||
| @ -228,7 +226,7 @@ export const AddGlobalSecondaryIndexPanel = (props: AddGlobalSecondaryIndexPanel | ||||
|       }; | ||||
|     } | ||||
| 
 | ||||
|     if (showFullTextSearchParameters()) { | ||||
|     if (showFullTextSearch) { | ||||
|       indexingPolicy.fullTextIndexes = fullTextIndexes; | ||||
|     } | ||||
| 
 | ||||
| @ -387,7 +385,7 @@ export const AddGlobalSecondaryIndexPanel = (props: AddGlobalSecondaryIndexPanel | ||||
|               }} | ||||
|             /> | ||||
|           )} | ||||
|           {showFullTextSearchParameters() && ( | ||||
|           {showFullTextSearch && ( | ||||
|             <FullTextSearchComponent | ||||
|               {...{ fullTextPolicy, setFullTextPolicy, setFullTextIndexes, setFullTextPolicyValidated }} | ||||
|             /> | ||||
|  | ||||
| @ -172,6 +172,17 @@ exports[`AddGlobalSecondaryIndexPanel render default panel 1`] = ` | ||||
|         } | ||||
|         setEnableAnalyticalStore={[Function]} | ||||
|       /> | ||||
|       <FullTextSearchComponent | ||||
|         fullTextPolicy={ | ||||
|           { | ||||
|             "defaultLanguage": "en-US", | ||||
|             "fullTextPaths": [], | ||||
|           } | ||||
|         } | ||||
|         setFullTextIndexes={[Function]} | ||||
|         setFullTextPolicy={[Function]} | ||||
|         setFullTextPolicyValidated={[Function]} | ||||
|       /> | ||||
|       <AdvancedComponent | ||||
|         setSubPartitionKeys={[Function]} | ||||
|         setUseHashV1={[Function]} | ||||
|  | ||||
| @ -20,7 +20,3 @@ export const isServerlessAccount = (): boolean => { | ||||
| export const isVectorSearchEnabled = (): boolean => { | ||||
|   return userContext.apiType === "SQL" && isCapabilityEnabled(Constants.CapabilityNames.EnableNoSQLVectorSearch); | ||||
| }; | ||||
| 
 | ||||
| export const isFullTextSearchEnabled = (): boolean => { | ||||
|   return userContext.apiType === "SQL" && isCapabilityEnabled(Constants.CapabilityNames.EnableNoSQLFullTextSearch); | ||||
| }; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user