2020-06-09 03:38:56 +00:00
|
|
|
/*
|
|
|
|
Copyright 2020 The Matrix.org Foundation C.I.C.
|
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the values for an enum.
|
|
|
|
* @param e The enum.
|
|
|
|
* @returns The enum values.
|
|
|
|
*/
|
|
|
|
export function getEnumValues<T>(e: any): T[] {
|
|
|
|
const keys = Object.keys(e);
|
|
|
|
return keys
|
|
|
|
.filter(k => ['string', 'number'].includes(typeof(e[k])))
|
|
|
|
.map(k => e[k]);
|
|
|
|
}
|
2020-07-20 22:51:16 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Determines if a given value is a valid value for the provided enum.
|
|
|
|
* @param e The enum to check against.
|
|
|
|
* @param val The value to search for.
|
|
|
|
* @returns True if the enum contains the value.
|
|
|
|
*/
|
|
|
|
export function isEnumValue<T>(e: T, val: string | number): boolean {
|
|
|
|
return getEnumValues(e).includes(val);
|
|
|
|
}
|