diff --git a/INTERNATIONALIZATION.md b/INTERNATIONALIZATION.md index 0240826a6..c6aadf2e1 100644 --- a/INTERNATIONALIZATION.md +++ b/INTERNATIONALIZATION.md @@ -2,13 +2,29 @@ ## About -The Shibboleth UI leverages Angular's built in internationalization (i18n) -system feature to allow for localization of the views. +The Shibboleth UI leverages the messages_*_*.properties files common to Java/Spring applications. The default files are located in `backend > src > main > resources > i18n`. - +This will allow any piece of static text in the application to be modified dynamically. -Angular allows any piece of text in an HTML template to be included in the -translation source file. +## Usage + +In the UI code, there are three options for converting the text provided into translated text. + +* Component: `Foo` +* Directive: `` +* Pipe: `{{ action.foo | translate }}` + +In addition, the `application.yml` file is an example of a file where dynamic values from the server, can be populated with an i18n identifier for translation. The json files used to generate the metadata wizards also make use of these identifiers and can be translated. They all use the same `messages.properties` files. + +Here is an example of the identifers and text found in the `messages.properties` files. + +``` +action.cancel=Cancel +action.save=Save +action.delete-type=Delete { type } +``` + +The `action.delete-type=Delete { type }` example shows how dynamic text can be inserted into the translation as well. These values are determined by the application and are populated at runtime based on user interaction. Many of these values can be translated separately. ## Conventions @@ -18,7 +34,7 @@ To allow for easier identification of relevant strings the identifiers are provided in the following format ``` -type--kebab-case-text +type.kebab-case-text ``` For example @@ -26,7 +42,7 @@ For example ```html - + ``` Where `type` is one of the provided types listed in [the types section](#types) @@ -42,15 +58,17 @@ The following types are provided: * `action` buttons or links that cause a state change within the app * `label` label for an input or a section -* `warning` messages that warn a user of exceptions in interactions, i.e. +* `message` messages that warn a user of exceptions in interactions, i.e. validation messages +* `value` text for displaying values such as `true` or `false` +* `branding.*` this special type is used to denote the customizable values located in the `ui > brand.ts` file ### Localize Text Only ```html - ``` @@ -71,9 +89,9 @@ When updating text, update the identifier to match the new text field. ```html - + - + ``` diff --git a/backend/src/main/java/edu/internet2/tier/shibboleth/admin/ui/configuration/InternationalizationConfiguration.java b/backend/src/main/java/edu/internet2/tier/shibboleth/admin/ui/configuration/InternationalizationConfiguration.java index dc8599865..22deef321 100644 --- a/backend/src/main/java/edu/internet2/tier/shibboleth/admin/ui/configuration/InternationalizationConfiguration.java +++ b/backend/src/main/java/edu/internet2/tier/shibboleth/admin/ui/configuration/InternationalizationConfiguration.java @@ -12,6 +12,12 @@ public class InternationalizationConfiguration { public LocaleResolver localeResolver() { // TODO if we want to control the order, we can implement our own locale resolver instead of using the SessionLocaleResolver. SessionLocaleResolver sessionLocaleResolver = new SessionLocaleResolver(); + + // NOTE: If we set a default here, Locale.getDefault's behavior will be consistent, but then Accept-Language + // is not honored (only ?lang=). If we do not set a default, the default is determined at runtime by the JVM. + // This may break unit tests if the system does not determine the default to be English. + // sessionLocaleResolver.setDefaultLocale(new Locale("en")); + return sessionLocaleResolver; } @@ -19,7 +25,9 @@ public LocaleResolver localeResolver() { public MappedResourceBundleMessageSource messageSource() { MappedResourceBundleMessageSource source = new MappedResourceBundleMessageSource(); source.setBasenames("i18n/messages"); - source.setUseCodeAsDefaultMessage(true); + source.setUseCodeAsDefaultMessage(false); //TODO Why was this true? + source.setFallbackToSystemLocale(false); // allows us to return messages.properties instead of + // messages_en.properties for unsupported languages. return source; } } diff --git a/backend/src/main/resources/i18n/messages.properties b/backend/src/main/resources/i18n/messages.properties index d9a5d0df4..ed9e61e67 100644 --- a/backend/src/main/resources/i18n/messages.properties +++ b/backend/src/main/resources/i18n/messages.properties @@ -8,3 +8,452 @@ # # Do this for each language we want to support. # Ideally, all messages should exist for each language. + +action.dashboard=Dashboard +action.logout=Logout +action.add=Add +action.add-new=Add New +action.add-new-provider=Add a new metadata provider +action.add-new-source=Add a new metadata source +action.clear=Clear +action.delete=Delete +action.remove=Remove +action.save=Save +action.toggle=Toggle +action.add-contact=Add Contact +action.add-contacts=Add Contacts +action.use-mine=Use My Changes +action.use-theirs=Use Their Changes +action.discard-changes=Discard Changes +action.add-endpoint=Add Endpoint +action.add-nameid-format=Add NameID Format +action.add-certificate=Add Certificate +action.add-entity-id=Add Entity ID +action.download-file=Download File +action.cancel=Cancel +action.search=Search +action.select-id=Select ID +action.finish-later=Finish Later +action.back=Back +action.next=Next +action.create=Create +action.copy=Copy +action.choose-file=Choose File +action.search-by=Search By +action.preview=Preview +action.select-metadata-filter-type=Select a metadata filter type +action.add-authentication-method=Add Authentication Method +action.move-up=Move Up +action.move-down=Move Down +action.edit=Edit +action.add-filter=Add Filter +action.manage-filters=Manage Filters + +value.enabled=Enabled +value.disabled=Disabled +value.none=None +value.file=File +value.memory=Memory +value.true=True +value.false=False +value.regex=Regex +value.script=Script +value.entity-id=Entity ID + +value.file-backed-http-metadata-provider=FileBackedHttpMetadataProvider +value.entity-attributes-filter=EntityAttributes Filter +value.spdescriptor=SPSSODescriptor +value.attr-auth-descriptor=AttributeAuthorityDescriptor + +brand.header.title=Source Management (default) +brand.logo-link-label=Shibboleth +brand.logo-link-description=Link to Shibboleth Website +brand.logo-alt=Shibboleth Logo - Click to be directed to www.shibboleth.net +brand.footer.text=Links to Shibboleth resources: +brand.footer.links-label-1=Home Page +brand.footer.links-desc-1=Shibboleth.net open-source community home page +brand.footer.links-label-2=Wiki +brand.footer.links-desc-2=Shibboleth.net open-source community wiki +brand.footer.links-label-3=Issue Tracker +brand.footer.links-desc-3=Shibboleth.net open-source community issue tracker +brand.footer.links-label-4=Mailing List +brand.footer.links-desc-4=Shibboleth.net open-source community mailing list +brand.footer.copyright=Copyright \u00A9 Internet2 + +heading.shibboleth=Shibboleth + +label.metadata-source=Metadata Source +label.metadata-sources=Metadata Sources +label.metadata-provider=Metadata Provider +label.metadata-providers=Metadata Providers +label.source-management=Source Management +label.search-files=Search Files +label.service-provider-entity-id=Service Provider Entity ID +label.service-provider-name-dashboard-display-only=Service Provider Name (Dashboard Display Only) +label.enable-this-service=Enable this service? +label.organization-name=Organization Name +label.organization-display-name=Organization Display Name +label.organization-url=Organization URL +label.contact-information=Contact Information: +label.name=Name +label.type=Type +label.email-address=Email Address +label.assertion-consumer-service-endpoints=Assertion Consumer Service Endpoints +label.my-changes=My Changes +label.their-changes=Their Changes +label.new-endpoint=New Endpoint +label.default=(default) +label.assertion-consumer-services-location=Assertion Consumer Service Location +label.assertion-consumer-service-location-binding=Assertion Consumer Service Location Binding +label.select-binding=Select Binding Type +label.mark-as-default=Mark as Default +label.attribute-name=Attribute Name +label.yes=Yes +label.check-all-attributes=Check All Attributes +label.clear-all-attributes=Clear All Attributes +label.protocol-support-enumeration=Protocol Support Enumeration +label.select-protocol=Select Protocol +label.nameid-format=NameID Format +label.enable-this-service-opon-saving=Enable this service upon saving? +label.name-and-entity-id=Name and Entity ID +label.organization-information=Organization Information +label.contact-information=Contact Information +label.given-name=Given Name +label.contact-type=Contact Type +label.user-interface-mdui-infromation=User Interface / MDUI Information +label.display-name=Display Name +label.information-url=Information URL +label.description=Description +label.privacy-statement=Privacy Statement URL +label.logo-url=Logo URL +label.logo-width=Logo Width +label.logo-height=Logo Height +label.sp-sso-descriptor-information=SP SSO Descriptor Information +label.logout-endpoints=Logout Endpoints +label.binding-types=Binding Type +label.security-information=Security Information +label.is-there-a-x509-certificate=Is there a X509 Certificate? +label.authentication-requests-signed=Authentication Requests Signed? +label.want-assertions-signed=Want Assertions Signed? +label.x509-certificates=X509 Certificates +label.certificate-name-display-only=Certificate Name (Display Only) +label.certificate=Certificate +label.assertion-consumer-services=Assertion Consumer Services +label.assertion-consumer-service-locations=Assertion Consumer Service Location +label.assertion-consumer-service-location-binding=Assertion Consumer Service Binding +label.relying-party-overrides=Relying Party Overrides +label.sign-the-assertion=Sign the Assertion? +label.turn-off-encryption-of-response=Turn off Encryption of Response? +label.use-sha1-signing-algorithm=Use SHA1 Signing Algorithm? +label.ignore-any-sp-requested-authentication-method=Ignore any SP-Requested Authentication Method? +label.omit-not-before-condition=Omit Not Before Condition? +label.responderid=ResponderID +label.attribute-release=Attribute Release +label.true=True +label.false=False +label.no=No +label.new-cert=New Certificate +label.url=URL +label.privacy-statement-url=Privacy Statement URL +label.contact-name=Contact Name +label.select-contact-type=Select Contact Type +label.contact-email-address=Contact Email Address +label.sign-the-assertion=Sign the Assertion +label.dont-sign-the-response=Don\u0027t Sign the Response +label.turn-off-encryption-of-response=Turn Off Encryption of Response +label.use-sha1-signing-algorithm=Use SHA1 Signing Algorithm +label.nameid-format-to-send=NameID Format to Send +label.authentication-methods-to-use=Authentication Methods to Use +label.auth-method-indexed=Authentication Method +label.ignore-any-sp-requested-authentication-method=Ignore any SP-Requested Authentication Method +label.omit-not-before-condition=Omit Not Before Condition +label.responder-id=ResponderID +label.preview-provider=Preview XML +label.search-entity-id=Search Entity Id +label.new-filter=Edit EntityAttributesFilter +label.min-4-chars=Minimum 4 characters. +label.new-filter=New Filter - EntityAttributes +label.service-provider=Metadata Source Name: +label.created-date=Created Date: +label.service-entity-id=Metadata Source Entity ID: +label.service-provider-status=Metadata Source Status: +label.current-metadata-sources=Current Metadata Sources +label.current-metadata-providers=Current Metadata Providers +label.add-a-new-metadata-provider=Add a new metadata provider +label.name-and-entityid=Name and EntityId +label.org-info=Organization Information +label.service-resolver-name-dashboard-display-only=Service Resolver Name (Dashboard Display Only) +label.service-resolver-entity-id=Service Resolver Entity ID +label.add-a-new-metadata-source=Add a new metadata source - Finish Summary +label.name-and-entityid=Name and Entity ID. +label.finish-summary-validation=Finished! +label.select-entity-id-to-copy=Select the Entity ID to copy +label.metadata-source-name-dashboard-display-only=Metadata Source Name (Dashboard Display Only) +label.service-resolver-entity-id=New Entity ID +label.sections-to-copy=Sections to Copy? +label.add-a-new-metadata-resolver=Add a new metadata source +label.how-are-you-adding-the-metadata-information=How are you adding the metadata information? +label.upload-url=Upload/URL +label.or=or +label.name-and-upload-url=Name and Upload Url +label.service-resolver-file=Select Resolver Metadata File +label.service-resolver-metadata-url=Service Resolver Metadata URL +label.search-criteria-by=Search Criteria by { displayType } +label.entity-ids-added=Entity Ids Added +label.ui-mdui-info=User Interface / MDUI Information +label.sp-sso-descriptor-info=SP SSO Descriptor Information +label.security-info=Security Information +label.assertion-consumer-services=Assertion Consumer Service +label.sp-org-info=SP/Organization Information +label.finished=Finished! +label.signing=Signing +label.encryption=Encryption +label.both=Both +label.sp-sso-descriptor-info=Organization Information +label.security-descriptor-info=Security Descriptor Information +label.entity-id=Entity ID +label.service-provider-name=Service Provider Name +label.organization=Organization +label.contacts=Contacts +label.mdui=MDUI Information +label.service-provider-sso-descriptor=Service Provider Sso Descriptor +label.service-enabled=Service Enabled +label.filter-name=Filter Name +label.filter-enabled=Filter Enabled +label.filter-target=FilterTarget +label.filter-type=Filter Type +label.value=Value +label.binding-type=Binding Type +label.sign-assertion=Sign Assertions +label.dont-sign-response=Don\u0027t Sign Response +label.turn-off-encryption=Turn off encryption +label.use-sha=Use Sha +label.ignore-authentication-method=Ignore Authentication Method +label.omit-not-before=Omit Not Before +label.responder-id=Responder ID +label.name-id-formats=Name ID Formats +label.name-id-format= Name ID Format +label.authentication-methods=Authentication Methods +label.authentication-method=Authentication Method +label.x509-certificate-available=x509 Certificate Available +label.authentication-requests-signed=Authentication Requests Signed +label.want-assertions-signed=Want Assertions Signed +label.x509-certificates=x509 Certificates +label.protocol-support-enum=Protocol Support Enumeration +label.binding=Binding +label.location-url=Location URL +label.make-default=Make Default +label.metadata-provider-name-dashboard-display-only=Metadata Provider Name (Dashboard Display Only) +label.default-authentication-methods=Default Authentication Method(s) + +label.filter-name=Filter Name (Dashboard Display Only) +label.metadata-filter-name=Metadata Filter Name (Dashboard Display Only) +label.filter-enable=Enable this Filter? +label.search-criteria=Search Criteria +label.metadata-filter=Metadata Filter +label.metadata-filter-type=Metadata Filter Type + +label.http-connection-attributes=HTTP Connection Attributes +label.http-security-attributes=HTTP Security Attributes +label.http-proxy-attributes=HTTP Proxy Attributes +label.http-caching-attributes=HTTP Caching Attributes + +label.connection-request-timeout=Connection Request Timeout +label.connection-timeout=Connection Timeout +label.socket-timeout=Socket Timeout +label.disregard-tls-cert=Disregard TLS Certificate? +label.proxy-host=Proxy Host +label.proxy-port=Proxy Port +label.proxy-user=Proxy User +label.proxy-password=Proxy Password +label.http-caching=HTTP Caching? +label.select-caching-type=Select Caching Type +label.http-caching-directory=HTTP Cache Directory +label.http-max-cache-entries=HTTP Max Cache Entries +label.max-cache-entry-size=HTTP Max Cache Entry Size +label.duration=Duration +label.real-number=Real Number (between 0.0 and 1.0) +label.min-refresh-delay=Min Refresh Delay +label.max-refresh-delay=Max Refresh Delay +label.refresh-delay-factor=Refresh Delay Factor +label.resolve-via-predicates-only=Resolve Via Predicates Only? +label.expiration-warning-threshold=Expiration Warning Threshold + +label.satisfy-any-predicates=Satisfy Any Predicates? +label.use-default-predicate-reg=Use Default Predicate Registry? +label.fail-fast-init=Fail Fast Initialization? +label.require-valid-metadata=Require Valid Metadata? +label.backup-file-init-refresh-delay=Backup File Init Next Refresh Delay +label.backing-file=Backing File +label.init-from-backup=Initialize From Backup File? +label.metadata-url=Metadata URL +label.xml-id=ID +label.enable-service=Enable this service? +label.metadata-provider-type=Metadata Provider Type +label.metadata-provider-name=Metadata Provider Name +label.select-metadata-type=Select a metadata provider type +label.metadata-provider-status=Metadata Provider Status +label.enable-provider-upon-saving=Enable Metadata Provider upon saving? + +label.enable-filter=Enable Filter? +label.required-valid-until=Required Valid Until Filter +label.max-validity-interval=Max Validity Interval +label.signature-validation-filter=Signature Validation Filter +label.require-signed-root=Require Signed Root +label.certificate-file=Certificate File +label.entity-role-whitelist=Entity Role Whitelist Filter +label.retained-roles=Retained Roles +label.remove-roleless-entity-descriptors=Remove Roleless Entity Descriptors? +label.remove-empty-entities-descriptors=Remove Empty Entities Descriptors? + +label.select-metadata-provider-type=Select Metadata Provider Type +label.filter-list=Filter List +label.common-attributes=Common Attributes +label.reloading-attributes=Reloading Attributes +label.metadata-filter-plugins=Metadata Filter Plugins +label.advanced-settings=Advanced Settings +label.edit-metadata-provider=Edit Metadata Provider + +label.metadata-ui=User Interface / MDUI Information +label.descriptor-info=SP SSO Descriptor Information +label.key-info=Security Information +label.assertion=Assertion Consumer Service +label.relying-party=Relying Party Overrides +label.org-info=Organization Information + +label.attribute-eduPersonPrincipalName=eduPersonPrincipalName (EPPN) +label.attribute-uid=uid +label.attribute-mail=mail +label.attribute-surname=surname +label.attribute-givenName=givenName +label.attribute-eduPersonAffiliation=eduPersonAffiliation +label.attribute-eduPersonScopedAffiliation=eduPersonScopedAffiliation +label.attribute-eduPersonPrimaryAffiliation=eduPersonPrimaryAffiliation +label.attribute-eduPersonEntitlement=eduPersonEntitlement +label.attribute-eduPersonAssurance=eduPersonAssurance +label.attribute-eduPersonUniqueId=eduPersonUniqueId +label.attribute-employeeNumber=employeeNumber +label.force-authn=Force AuthN + +message.must-be-unique=Must be unique. +message.name-must-be-unique=Name must be unique. +message.uri-valid-format=URI must be valid format. +message.id-unique=ID must be unique. + +message.conflict=Conflict +message.data-version-contention=Data Version Contention +message.contention-new-version=A newer version of this metadata source has been saved. Below are a list of changes. You can use your changes or their changes. +message.organization-feedback=These three fields must all be entered if any single field has a value. +message.valid-email=Must be a valid Email Address +message.valid-url=Must be a valid URL +message.must-be-valid-url=Must be a valid URL +message.must-be-integer=Must be an integer equal to or greater than 0 +message.delete-source-title=Delete Metadata Source? +message.delete-source-body=You are deleting a metadata source. This cannot be undone. Continue? +message.incomplete-form=Incomplete Form +message.delete-filter-title=Delete Metadata Filter? +message.delete-filter-body=You are deleting a metadata filter. This cannot be undone. Continue? +message.unsaved-dialog-title=Save your information? +message.unsaved-editor=You have not saved your changes. If you exit this screen, your changes will be lost. +message.editor-invalid=All forms must be valid before changes can be saved! +message.unsaved-source-1=You have not completed the wizard! Do you wish to save this information? You can finish the wizard later by clicking the \u0027Edit\u0027 +message.unsaved-source-2=icon on the dashboard. +message.service-resolver-name-required=Service Resolver Name is required +message.entity-id-required=Entity ID is required +message.entity-id-must-be-unique=Entity ID must be unique +message.file-upload-alert=Note: You can only import a file with a single entityID (EntityDescriptor element) in it. Anything more in that file will result in an error. +message.add-new-md-resolver=Add a new metadata source +message.wizard-status=Step { index } of { length } +message.entity-id-min-unique=You must add at least one entity id target and they must each be unique. +message.required-for-scripts=Required for Scripts +message.required-for-regex=Required for Regex + +tooltip.force-authn=Disallows use (or reuse) of authentication results and login flows that don\u0027t provide a real-time proof of user presence in the login process +tooltip.service-provider-name-dashboard-display-only=Service Provider Name (Dashboard Display Only) +tooltip.service-provider-entity-id=Service Provider Entity ID +tooltip.organization-name=Organization Name +tooltip.organization-display-name=Organization Display Name +tooltip.organization-url=Organization URL +tooltip.name=Name +tooltip.type=Type +tooltip.email-address=Email Address +tooltip.assertion-consumer-service-location=Assertion Consumer Service Location +tooltip.assertion-consumer-service-location-binding=Assertion Consumer Service Location Binding +tooltip.mark-as-default=Mark as Default +tooltip.protocol-support-enumeration=Protocol Support Enumeration +tooltip.nameid-format=Add NameID Format +tooltip.enable-this-service-upon-saving=Enable this service upon saving +tooltip.authentication-requests-signed=Authentication Requests Signed +tooltip.want-assertions-signed=Want Assertions Signed +tooltip.certificate-name=Certificate Name +tooltip.certificate-type=Certificate Type +tooltip.certificate=Certificate +tooltip.logout-endpoints-url=Logout Endpoints Url +tooltip.logout-endpoints-binding-type=Logout Endpoints Binding Type +tooltip.mdui-display-name=Typically, the IdP Display Name field will be presented on IdP discovery service interfaces. +tooltip.mdui-information-url=The IdP Information URL is a link to a comprehensive information page about the IdP. This page should expand on the content of the IdP Description field. +tooltip.mdui-description=The IdP Description is a brief description of the IdP service. On a well-designed discovery interface, the IdP Description will be presented to the user in addition to the IdP Display Name, and so the IdP Description helps disambiguate duplicate or similar IdP Display Names. +tooltip.mdui-privacy-statement-url=The IdP Privacy Statement URL is a link to the IdP\u0027s Privacy Statement. The content of the Privacy Statement should be targeted at end users. +tooltip.mdui-logo-url=The IdP Logo URL in metadata points to an image file on a remote server. A discovery service, for example, may rely on a visual cue (i.e., a logo) instead of or in addition to the IdP Display Name. +tooltip.mdui-logo-width=The logo should have a minimum width of 100 pixels +tooltip.mdui-logo-height=The logo should have a minimum height of 75 pixels and a maximum height of 150 pixels (or the application will scale it proportionally) +tooltip.organization-name=Organization Name +tooltip.organization-display-name=Organization Display Name +tooltip.organization-url=Organization Url +tooltip.contact-name=Contact Name +tooltip.contact-type=Contact Type +tooltip.contact-email=Contact Email +tooltip.sign-assertion=Sign Assertion +tooltip.dont-sign-response=Don\u0027t Sign Response +tooltip.turn-off-encryption=Turn Off Encryption of Response +tooltip.usa-sha-algorithm=Use SHA1 Signing Algorithm +tooltip.authentication-methods-to-use=Authentication Methods to Use +tooltip.ignore-auth-method=Ignore any SP-Requested Authentication Method +tooltip.omit-not-before-condition=Omit Not Before Condition +tooltip.responder-id=ResponderId +tooltip.instruction=Information icon - press spacebar to read additional information for this form field +tooltip.attribute-release-table=Attribute release table - select the attributes you want to release (default unchecked) +tooltip.metadata-filter-name=Metadata Filter Name +tooltip.metadata-filter-type=Metadata Filter Type +tooltip.connection-request-timeout=The maximum amount of time to wait for a connection to be returned from the HTTP client\u0027s connection pool manager. Set to PT0S to disable. This attribute is incompatible with httpClientRef. +tooltip.connection-timeout=The maximum amount of time to wait to establish a connection with the remote server. Set to PT0S to disable. This attribute is incompatible with httpClientRef. +tooltip.socket-timeout=The maximum amount of time to wait between two consecutive packets while reading from the socket connected to the remote server. Set to PT0S to disable. This attribute is incompatible with httpClientRef. +tooltip.disregard-tls-cert=If true, no TLS certificate checking will take place over an HTTPS connection. This attribute is incompatible with httpClientRef. (Be careful with this setting, it is typically only used during testing. See the HttpClientConfiguration topic for more information.) +tooltip.proxy-host=The hostname of the HTTP proxy through which connections will be made. This attribute is incompatible with httpClientRef. +tooltip.proxy-port=The port of the HTTP proxy through which connections will be made. This attribute is incompatible with httpClientRef. +tooltip.proxy-user=The username used with the HTTP proxy through which connections will be made. This attribute is incompatible with httpClientRef. +tooltip.proxy-password=The password used with the HTTP proxy through which connections will be made. This attribute is incompatible with httpClientRef. +tooltip.http-caching=The type of low-level HTTP caching to perform. There are three choices: 'none' indicates the HTTP response is not cached by the client library, 'file' indicates the HTTP response is written to disk (but will not survive a restart), 'memory' indicates the HTTP response is stored in memory. This attribute is incompatible with httpClientRef and its value may not be specified as a bean property. Some metadata providers, most notably the reloading 'batch-oriented' providers, implement HTTP caching at a higher layer and tend to work best with httpCaching='none'. +tooltip.http-caching-directory=If httpCaching='file', this attribute specifies where retrieved files are to be cached. This attribute is incompatible with httpClientRef. +tooltip.http-max-cache-entries=The maximum number of responses written to cache. This attribute is incompatible with httpClientRef. +tooltip.max-cache-entry-size=The maximum response body size that may be cached, in bytes. This attribute is incompatible with httpClientRef. + +tooltip.metadata-provider-name=Metadata Provider Name +tooltip.metadata-provider-type=Metadata Provider Type +tooltip.xml-id=Identifier for logging, identification for command line reload, etc. +tooltip.metadata-url=Identifier for logging, identification for command line reload, etc. +tooltip.init-from-backup=Flag indicating whether initialization should first attempt to load metadata from the backup file. If true, foreground initialization will be performed by loading the backing file, and then a refresh from the remote HTTP server will be scheduled to execute in a background thread, after a configured delay. This can improve IdP startup times when the remote HTTP file is large in size. +tooltip.backing-file=Specifies where the backing file is located. If the remote server is unavailable at startup, the backing file is loaded instead. +tooltip.backup-file-init-refresh-delay=Delay duration after which to schedule next HTTP refresh when initialized from the backing file. +tooltip.require-valid-metadata=Whether candidate metadata found by the resolver must be valid in order to be returned (where validity is implementation specific, but in SAML cases generally depends on a validUntil attribute.) If this flag is true, then invalid candidate metadata will not be returned. +tooltip.fail-fast-init=Whether to fail initialization of the underlying MetadataResolverService (and possibly the IdP as a whole) if the initialization of a metadata provider fails. When false, the IdP may start, and will continue to attempt to reload valid metadata if configured to do so, but operations that require valid metadata will fail until it does. +tooltip.use-default-predicate-reg=Whether to fail initialization of the underlying MetadataResolverService (and possibly the IdP as a whole) if the initialization of a metadata provider fails. When false, the IdP may start, and will continue to attempt to reload valid metadata if configured to do so, but operations that require valid metadata will fail until it does. +tooltip.satisfy-any-predicates=Flag which determines whether predicates used in filtering are connected by a logical 'OR' (true) or by logical 'AND' (false). +tooltip.enable-provider-upon-saving=Enable Metadata Provider upon saving? + +tooltip.max-validity-interval=Defines the window within which the metadata is valid. +tooltip.require-signed-root=If true, this fails to load metadata with no signature on the root XML element. +tooltip.certificate-file=A key used to verify the signature. Conflicts with trustEngineRef and both of the child elements. +tooltip.retained-roles=Controls whether to keep entity descriptors that contain no roles +tooltip.remove-roleless-entity-descriptors=Controls whether to keep entity descriptors that contain no roles. +tooltip.remove-empty-entities-descriptors=Controls whether to keep entities descriptors that contain no entity descriptors. + +tooltip.min-refresh-delay=Lower bound on the next refresh from the time calculated based on the metadata\u0027s expiration. +tooltip.max-refresh-delay=Upper bound on the next refresh from the time calculated based on the metadata\u0027s expiration. +tooltip.refresh-delay-factor=A factor applied to the initially determined refresh time in order to determine the next refresh time (typically to ensure refresh takes place prior to the metadata\u0027s expiration). Attempts to refresh metadata will generally begin around the product of this number and the maximum refresh delay. +tooltip.resolve-via-predicates-only=Flag indicating whether resolution may be performed solely by applying predicates to the entire metadata collection, when an entityID input criterion is not supplied. +tooltip.expiration-warning-threshold=For each attempted metadata refresh (whether or not fresh metadata is obtained), if requireValidMetadata is true, and there is a validUntil XML attribute on the document root element, and the difference between validUntil and the current time is less than expirationWarningThreshold, the system logs a warning about the impending expiration. + +tooltip.filter-name=Filter Name +tooltip.enable-filter=Enable Filter? +tooltip.enable-service=Enable Service? diff --git a/backend/src/main/resources/i18n/messages_en.properties b/backend/src/main/resources/i18n/messages_en.properties index 8b20b2efc..6d64dd72a 100644 --- a/backend/src/main/resources/i18n/messages_en.properties +++ b/backend/src/main/resources/i18n/messages_en.properties @@ -433,7 +433,7 @@ tooltip.enable-provider-upon-saving=Enable Metadata Provider upon saving? tooltip.max-validity-interval=Defines the window within which the metadata is valid. tooltip.require-signed-root=If true, this fails to load metadata with no signature on the root XML element. tooltip.certificate-file=A key used to verify the signature. Conflicts with trustEngineRef and both of the child elements. -tooltip.retained-roles=Retained Roles +tooltip.retained-roles=Controls whether to keep entity descriptors that contain no roles tooltip.remove-roleless-entity-descriptors=Controls whether to keep entity descriptors that contain no roles. tooltip.remove-empty-entities-descriptors=Controls whether to keep entities descriptors that contain no entity descriptors. diff --git a/backend/src/test/groovy/edu/internet2/tier/shibboleth/admin/ui/controller/InternationalizationMessagesControllerTests.groovy b/backend/src/test/groovy/edu/internet2/tier/shibboleth/admin/ui/controller/InternationalizationMessagesControllerTests.groovy index 73acb5d14..9287ff552 100644 --- a/backend/src/test/groovy/edu/internet2/tier/shibboleth/admin/ui/controller/InternationalizationMessagesControllerTests.groovy +++ b/backend/src/test/groovy/edu/internet2/tier/shibboleth/admin/ui/controller/InternationalizationMessagesControllerTests.groovy @@ -106,11 +106,21 @@ class InternationalizationMessagesControllerTests extends Specification { result.andExpect(content().json(expectedFrenchResult)) } - def "GET messages with an unsupported Accept-Language returns the default language"() { + def "GET messages with an unsupported Accept-Language returns the default (unspecified) language"() { when: def result = mockMvc.perform( get(messagesUrl) - .header("Accept-Language", "es")) + .header("Accept-Language", "ja")) + + then: + result.andExpect(content().json(expectedDefaultResult)) + } + + def "GET messages with a made-up Accept-Language returns the default (unspecified) language"() { + when: + def result = mockMvc.perform( + get(messagesUrl) + .header("Accept-Language", "foo")) then: result.andExpect(content().json(expectedDefaultResult)) diff --git a/backend/src/main/resources/i18n/messages_es.properties b/backend/src/test/resources/i18n/messages_es.properties similarity index 100% rename from backend/src/main/resources/i18n/messages_es.properties rename to backend/src/test/resources/i18n/messages_es.properties diff --git a/ui/README.md b/ui/README.md index 0e52b0fc9..5e86acade 100644 --- a/ui/README.md +++ b/ui/README.md @@ -78,17 +78,6 @@ change to... header: 'Metadata Management' };` -### Sitewide text -Finally, this project has support for internationalization (i18n). In the folder `backend > src > main > resources > i18n` folder there is a group of files which can be used to modify the text seen throughout the application. In order to change the default value, you can override the text in the messages_en file with the desired text. - -For example: - -`action.logout=Logout` - -change to... - -`action.logout=Sign Out` - # Development diff --git a/ui/package-lock.json b/ui/package-lock.json index c3b83f2ca..4850aa82f 100644 --- a/ui/package-lock.json +++ b/ui/package-lock.json @@ -183,6 +183,7 @@ "anymatch": "2.0.0", "async-each": "1.0.1", "braces": "2.3.2", + "fsevents": "1.2.4", "glob-parent": "3.1.0", "inherits": "2.0.3", "is-binary-path": "1.0.1", @@ -525,6 +526,7 @@ "anymatch": "2.0.0", "async-each": "1.0.1", "braces": "2.3.2", + "fsevents": "1.2.4", "glob-parent": "3.1.0", "inherits": "2.0.3", "is-binary-path": "1.0.1", @@ -922,6 +924,7 @@ "anymatch": "2.0.0", "async-each": "1.0.1", "braces": "2.3.2", + "fsevents": "1.2.4", "glob-parent": "3.1.0", "inherits": "2.0.3", "is-binary-path": "1.0.1", @@ -1339,9 +1342,19 @@ } }, "@ng-bootstrap/ng-bootstrap": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@ng-bootstrap/ng-bootstrap/-/ng-bootstrap-1.1.2.tgz", - "integrity": "sha512-lPB4WdFk3s4k1OMKiZsmbxSE3r8qBFapov0HudEVi8HYkm6LBxZmWqy9I6KAC9NnhVUVIYnCixvRSNwOQvIwwA==" + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/@ng-bootstrap/ng-bootstrap/-/ng-bootstrap-3.2.2.tgz", + "integrity": "sha512-LdC08mKVJpDvu0wdMJXFql2KmLdESiSBXKXYt7j1JDExtPk0inNxNjdY3mhE2I3RFpEeXNcI6/pPkAlk/unwzw==", + "requires": { + "tslib": "1.9.3" + }, + "dependencies": { + "tslib": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", + "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==" + } + } }, "@ngrx/effects": { "version": "5.2.0", @@ -1462,6 +1475,7 @@ "anymatch": "2.0.0", "async-each": "1.0.1", "braces": "2.3.2", + "fsevents": "1.2.4", "glob-parent": "3.1.0", "inherits": "2.0.3", "is-binary-path": "1.0.1", @@ -2797,6 +2811,7 @@ "requires": { "anymatch": "1.3.2", "async-each": "1.0.1", + "fsevents": "1.2.4", "glob-parent": "2.0.0", "inherits": "2.0.3", "is-binary-path": "1.0.1", @@ -4621,6 +4636,535 @@ "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", "dev": true }, + "fsevents": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.4.tgz", + "integrity": "sha512-z8H8/diyk76B7q5wg+Ud0+CqzcAF3mBBI/bA5ne5zrRUUIvNkJY//D3BqyH571KuAC4Nr7Rw7CjWX4r0y9DvNg==", + "dev": true, + "optional": true, + "requires": { + "nan": "2.11.1", + "node-pre-gyp": "0.10.0" + }, + "dependencies": { + "abbrev": { + "version": "1.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true, + "dev": true + }, + "aproba": { + "version": "1.2.0", + "bundled": true, + "dev": true, + "optional": true + }, + "are-we-there-yet": { + "version": "1.1.4", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "delegates": "1.0.0", + "readable-stream": "2.3.6" + } + }, + "balanced-match": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "bundled": true, + "dev": true, + "requires": { + "balanced-match": "1.0.0", + "concat-map": "0.0.1" + } + }, + "chownr": { + "version": "1.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "bundled": true, + "dev": true + }, + "console-control-strings": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "core-util-is": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "debug": { + "version": "2.6.9", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "ms": "2.0.0" + } + }, + "deep-extend": { + "version": "0.5.1", + "bundled": true, + "dev": true, + "optional": true + }, + "delegates": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "detect-libc": { + "version": "1.0.3", + "bundled": true, + "dev": true, + "optional": true + }, + "fs-minipass": { + "version": "1.2.5", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "minipass": "2.2.4" + } + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "gauge": { + "version": "2.7.4", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "aproba": "1.2.0", + "console-control-strings": "1.1.0", + "has-unicode": "2.0.1", + "object-assign": "4.1.1", + "signal-exit": "3.0.2", + "string-width": "1.0.2", + "strip-ansi": "3.0.1", + "wide-align": "1.1.2" + } + }, + "glob": { + "version": "7.1.2", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "fs.realpath": "1.0.0", + "inflight": "1.0.6", + "inherits": "2.0.3", + "minimatch": "3.0.4", + "once": "1.4.0", + "path-is-absolute": "1.0.1" + } + }, + "has-unicode": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "iconv-lite": { + "version": "0.4.21", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "safer-buffer": "2.1.2" + } + }, + "ignore-walk": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "minimatch": "3.0.4" + } + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "once": "1.4.0", + "wrappy": "1.0.2" + } + }, + "inherits": { + "version": "2.0.3", + "bundled": true, + "dev": true + }, + "ini": { + "version": "1.3.5", + "bundled": true, + "dev": true, + "optional": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "number-is-nan": "1.0.1" + } + }, + "isarray": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "dev": true, + "requires": { + "brace-expansion": "1.1.11" + } + }, + "minimist": { + "version": "0.0.8", + "bundled": true, + "dev": true + }, + "minipass": { + "version": "2.2.4", + "bundled": true, + "dev": true, + "requires": { + "safe-buffer": "5.1.1", + "yallist": "3.0.2" + } + }, + "minizlib": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "minipass": "2.2.4" + } + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "dev": true, + "requires": { + "minimist": "0.0.8" + } + }, + "ms": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "needle": { + "version": "2.2.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "debug": "2.6.9", + "iconv-lite": "0.4.21", + "sax": "1.2.4" + } + }, + "node-pre-gyp": { + "version": "0.10.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "detect-libc": "1.0.3", + "mkdirp": "0.5.1", + "needle": "2.2.0", + "nopt": "4.0.1", + "npm-packlist": "1.1.10", + "npmlog": "4.1.2", + "rc": "1.2.7", + "rimraf": "2.6.2", + "semver": "5.5.0", + "tar": "4.4.1" + } + }, + "nopt": { + "version": "4.0.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "abbrev": "1.1.1", + "osenv": "0.1.5" + } + }, + "npm-bundled": { + "version": "1.0.3", + "bundled": true, + "dev": true, + "optional": true + }, + "npm-packlist": { + "version": "1.1.10", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "ignore-walk": "3.0.1", + "npm-bundled": "1.0.3" + } + }, + "npmlog": { + "version": "4.1.2", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "are-we-there-yet": "1.1.4", + "console-control-strings": "1.1.0", + "gauge": "2.7.4", + "set-blocking": "2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "once": { + "version": "1.4.0", + "bundled": true, + "dev": true, + "requires": { + "wrappy": "1.0.2" + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "os-tmpdir": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "osenv": { + "version": "0.1.5", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "os-homedir": "1.0.2", + "os-tmpdir": "1.0.2" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "process-nextick-args": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "rc": { + "version": "1.2.7", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "deep-extend": "0.5.1", + "ini": "1.3.5", + "minimist": "1.2.0", + "strip-json-comments": "2.0.1" + }, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true, + "dev": true, + "optional": true + } + } + }, + "readable-stream": { + "version": "2.3.6", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "core-util-is": "1.0.2", + "inherits": "2.0.3", + "isarray": "1.0.0", + "process-nextick-args": "2.0.0", + "safe-buffer": "5.1.1", + "string_decoder": "1.1.1", + "util-deprecate": "1.0.2" + } + }, + "rimraf": { + "version": "2.6.2", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "glob": "7.1.2" + } + }, + "safe-buffer": { + "version": "5.1.1", + "bundled": true, + "dev": true + }, + "safer-buffer": { + "version": "2.1.2", + "bundled": true, + "dev": true, + "optional": true + }, + "sax": { + "version": "1.2.4", + "bundled": true, + "dev": true, + "optional": true + }, + "semver": { + "version": "5.5.0", + "bundled": true, + "dev": true, + "optional": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "requires": { + "code-point-at": "1.1.0", + "is-fullwidth-code-point": "1.0.0", + "strip-ansi": "3.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "safe-buffer": "5.1.1" + } + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "2.1.1" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "tar": { + "version": "4.4.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "chownr": "1.0.1", + "fs-minipass": "1.2.5", + "minipass": "2.2.4", + "minizlib": "1.1.0", + "mkdirp": "0.5.1", + "safe-buffer": "5.1.1", + "yallist": "3.0.2" + } + }, + "util-deprecate": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "wide-align": { + "version": "1.1.2", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "string-width": "1.0.2" + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "yallist": { + "version": "3.0.2", + "bundled": true, + "dev": true + } + } + }, "fstream": { "version": "1.0.11", "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", @@ -7346,6 +7890,13 @@ "integrity": "sha1-iZ8R2WhuXgXLkbNdXw5jt3PPyQE=", "dev": true }, + "nan": { + "version": "2.11.1", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.11.1.tgz", + "integrity": "sha512-iji6k87OSXa0CcrLl9z+ZiYSuR2o+c0bGuNmXdrhTQTakxytAFsC56SArGYoiHlJlFoHSnvmhpceZJaXkVuOtA==", + "dev": true, + "optional": true + }, "nanomatch": { "version": "1.2.9", "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.9.tgz", @@ -11056,6 +11607,7 @@ "anymatch": "2.0.0", "async-each": "1.0.1", "braces": "2.3.2", + "fsevents": "1.2.4", "glob-parent": "3.1.0", "inherits": "2.0.3", "is-binary-path": "1.0.1", @@ -11903,6 +12455,7 @@ "anymatch": "2.0.0", "async-each": "1.0.1", "braces": "2.3.2", + "fsevents": "1.2.4", "glob-parent": "3.1.0", "inherits": "2.0.3", "is-binary-path": "1.0.1", diff --git a/ui/package.json b/ui/package.json index d89f39898..b02a3f394 100644 --- a/ui/package.json +++ b/ui/package.json @@ -23,7 +23,7 @@ "@angular/platform-browser": "^6.0.2", "@angular/platform-browser-dynamic": "^6.0.2", "@angular/router": "^6.0.2", - "@ng-bootstrap/ng-bootstrap": "^1.1.2", + "@ng-bootstrap/ng-bootstrap": "^3.2.2", "@ngrx/effects": "^5.2.0", "@ngrx/entity": "^5.2.0", "@ngrx/router-store": "^5.2.0", diff --git a/ui/src/app/metadata/domain/component/forms/advanced-info-form.component.html b/ui/src/app/metadata/domain/component/forms/advanced-info-form.component.html index 50c608d33..e7e9399bb 100644 --- a/ui/src/app/metadata/domain/component/forms/advanced-info-form.component.html +++ b/ui/src/app/metadata/domain/component/forms/advanced-info-form.component.html @@ -10,12 +10,7 @@ - - Service Provider Name (Dashboard Display Only) popover - - + - - Service Provider Entity ID popover - - + - - Organization Name popover - - + - - Organization Display Name popover - - + - - Organization URL popover - - + Name - - Name popover - - + Type - - Type popover - - + ` @@ -51,8 +52,8 @@ describe('Advanced Info Form Component', () => { imports: [ NoopAnimationsModule, ReactiveFormsModule, - NgbPopoverModule, - MockI18nModule + MockI18nModule, + MockSharedModule ], declarations: [ AdvancedInfoFormComponent, diff --git a/ui/src/app/metadata/domain/component/forms/assertion-form.component.html b/ui/src/app/metadata/domain/component/forms/assertion-form.component.html index 7433c7711..8cf76147a 100644 --- a/ui/src/app/metadata/domain/component/forms/assertion-form.component.html +++ b/ui/src/app/metadata/domain/component/forms/assertion-form.component.html @@ -45,12 +45,7 @@ Assertion Consumer Service Location - - Assertion Consumer Service Location popover - - + @@ -66,12 +61,7 @@ Assertion Consumer Service Location Binding - - Assertion Consumer Service Location Binding - - + { let fixture: ComponentFixture; @@ -21,7 +22,7 @@ describe('Assertion Form Component', () => { imports: [ NoopAnimationsModule, ReactiveFormsModule, - NgbPopoverModule, + MockSharedModule, MockI18nModule ], declarations: [ diff --git a/ui/src/app/metadata/domain/component/forms/attribute-release-form.component.spec.ts b/ui/src/app/metadata/domain/component/forms/attribute-release-form.component.spec.ts index c05e6bad3..9f9e3f04a 100644 --- a/ui/src/app/metadata/domain/component/forms/attribute-release-form.component.spec.ts +++ b/ui/src/app/metadata/domain/component/forms/attribute-release-form.component.spec.ts @@ -3,12 +3,13 @@ import { ReactiveFormsModule } from '@angular/forms'; import { NoopAnimationsModule } from '@angular/platform-browser/animations'; import { StoreModule, Store, combineReducers } from '@ngrx/store'; import { ProviderValueEmitter, ProviderStatusEmitter } from '../../../domain/service/provider-change-emitter.service'; -import { NgbPopoverModule, NgbPopoverConfig } from '@ng-bootstrap/ng-bootstrap/popover/popover.module'; +import { NgbPopoverModule, NgbPopoverConfig } from '@ng-bootstrap/ng-bootstrap'; import { AttributeReleaseFormComponent } from './attribute-release-form.component'; import { ListValuesService } from '../../../domain/service/list-values.service'; import * as stubs from '../../../../../testing/resolver.stub'; import { MockI18nModule } from '../../../../../testing/i18n.stub'; import { MockListValueService } from '../../../../../testing/list-values.stub'; +import { MockSharedModule } from '../../../../../testing/shared.stub'; describe('Attribute Release Form Component', () => { let fixture: ComponentFixture; @@ -25,7 +26,7 @@ describe('Attribute Release Form Component', () => { imports: [ NoopAnimationsModule, ReactiveFormsModule, - NgbPopoverModule, + MockSharedModule, MockI18nModule ], declarations: [ diff --git a/ui/src/app/metadata/domain/component/forms/descriptor-info-form.component.html b/ui/src/app/metadata/domain/component/forms/descriptor-info-form.component.html index 23e3687ac..6aac2a7b4 100644 --- a/ui/src/app/metadata/domain/component/forms/descriptor-info-form.component.html +++ b/ui/src/app/metadata/domain/component/forms/descriptor-info-form.component.html @@ -7,12 +7,7 @@ Protocol Support Enumeration - - Protocol Support Enumeration popover - - + @@ -152,12 +131,7 @@ - - Certificate Type Popover - - +
@@ -180,12 +154,7 @@ - - Certificate Popover - - +
diff --git a/ui/src/app/metadata/domain/component/forms/key-info-form.component.spec.ts b/ui/src/app/metadata/domain/component/forms/key-info-form.component.spec.ts index 0b6751cc3..bdb50a4ed 100644 --- a/ui/src/app/metadata/domain/component/forms/key-info-form.component.spec.ts +++ b/ui/src/app/metadata/domain/component/forms/key-info-form.component.spec.ts @@ -3,7 +3,7 @@ import { TestBed, ComponentFixture } from '@angular/core/testing'; import { ReactiveFormsModule } from '@angular/forms'; import { NoopAnimationsModule } from '@angular/platform-browser/animations'; import { ProviderValueEmitter, ProviderStatusEmitter } from '../../../domain/service/provider-change-emitter.service'; -import { NgbPopoverModule, NgbPopoverConfig } from '@ng-bootstrap/ng-bootstrap/popover/popover.module'; +import { NgbPopoverModule, NgbPopoverConfig } from '@ng-bootstrap/ng-bootstrap'; import { ListValuesService } from '../../../domain/service/list-values.service'; import { KeyInfoFormComponent } from './key-info-form.component'; @@ -12,6 +12,7 @@ import { FileBackedHttpMetadataResolver } from '../../entity'; import { InputDefaultsDirective } from '../../../../shared/directive/input-defaults.directive'; import { MockI18nModule } from '../../../../../testing/i18n.stub'; import { MockListValueService } from '../../../../../testing/list-values.stub'; +import { MockSharedModule } from '../../../../../testing/shared.stub'; @Component({ template: `` @@ -49,7 +50,7 @@ describe('Security (Key) Info Form Component', () => { imports: [ NoopAnimationsModule, ReactiveFormsModule, - NgbPopoverModule, + MockSharedModule, MockI18nModule ], declarations: [ diff --git a/ui/src/app/metadata/domain/component/forms/logout-form.component.html b/ui/src/app/metadata/domain/component/forms/logout-form.component.html index c8a73f3e6..cf1f091ba 100644 --- a/ui/src/app/metadata/domain/component/forms/logout-form.component.html +++ b/ui/src/app/metadata/domain/component/forms/logout-form.component.html @@ -36,13 +36,7 @@ URL - - Logout Endpoints Url popover - - + @@ -54,13 +48,7 @@ Binding Type - - Logout Endpoints Binding Type popover - - + @@ -24,14 +18,7 @@ Information URL - - The IdP Information URL is a link to a comprehensive information page about the IdP. This page should expand on the - content of the IdP Description field. - - + @@ -43,15 +30,7 @@ Description - - The IdP Description is a brief description of the IdP service. On a well-designed discovery interface, the IdP - Description will be presented to the user in addition to the IdP Display Name, and so the IdP Description helps - disambiguate duplicate or similar IdP Display Names. - - +