Initial commit: WordPress wp-content (themes, plugins, languages)
- Theme: momentry (custom theme with REST API routes) - Plugins: code-snippets (contains all API proxies) - Languages: zh_TW translations - Excludes: cache, backups, uploads, logs
This commit is contained in:
51
plugins/code-snippets/js/utils/snippets/objects.ts
Normal file
51
plugins/code-snippets/js/utils/snippets/objects.ts
Normal file
@@ -0,0 +1,51 @@
|
||||
import { SNIPPET_TYPE_SCOPES } from '../../types/Snippet'
|
||||
import { isNetworkAdmin } from '../screen'
|
||||
import type { Snippet, SnippetScope } from '../../types/Snippet'
|
||||
|
||||
const defaults: Omit<Snippet, 'tags'> = {
|
||||
id: 0,
|
||||
name: '',
|
||||
code: '',
|
||||
desc: '',
|
||||
scope: 'global',
|
||||
modified: '',
|
||||
active: false,
|
||||
network: isNetworkAdmin(),
|
||||
shared_network: null,
|
||||
priority: 10,
|
||||
conditionId: 0
|
||||
}
|
||||
|
||||
const isAbsInt = (value: unknown): value is number =>
|
||||
'number' === typeof value && 0 < value
|
||||
|
||||
const parseStringArray = (value: unknown): string[] | undefined =>
|
||||
Array.isArray(value) ? value.filter(entry => 'string' === typeof entry) : undefined
|
||||
|
||||
export const isValidScope = (scope: unknown): scope is SnippetScope =>
|
||||
'string' === typeof scope && Object.values(SNIPPET_TYPE_SCOPES).some(typeScopes =>
|
||||
typeScopes.some(typeScope => typeScope === scope))
|
||||
|
||||
export const parseSnippetObject = (fields: unknown): Snippet => {
|
||||
const result: { -readonly [F in keyof Snippet]: Snippet[F] } = { ...defaults, tags: [] }
|
||||
|
||||
if ('object' !== typeof fields || null === fields) {
|
||||
return result
|
||||
}
|
||||
|
||||
return {
|
||||
...result,
|
||||
...'id' in fields && isAbsInt(fields.id) && { id: fields.id },
|
||||
...'name' in fields && 'string' === typeof fields.name && { name: fields.name },
|
||||
...'desc' in fields && 'string' === typeof fields.desc && { desc: fields.desc },
|
||||
...'code' in fields && 'string' === typeof fields.code && { code: fields.code },
|
||||
...'tags' in fields && { tags: parseStringArray(fields.tags) ?? result.tags },
|
||||
...'scope' in fields && isValidScope(fields.scope) && { scope: fields.scope },
|
||||
...'modified' in fields && 'string' === typeof fields.modified && { modified: fields.modified },
|
||||
...'active' in fields && 'boolean' === typeof fields.active && { active: fields.active },
|
||||
...'network' in fields && 'boolean' === typeof fields.network && { network: fields.network },
|
||||
...'shared_network' in fields && 'boolean' === typeof fields.shared_network && { shared_network: fields.shared_network },
|
||||
...'priority' in fields && 'number' === typeof fields.priority && { priority: fields.priority },
|
||||
...'condition_id' in fields && isAbsInt(fields.condition_id) && { conditionId: fields.condition_id }
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user