Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[next] chore(functions): add docs #5693

Merged
merged 1 commit into from
Aug 4, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions docs/functions.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
<!--
- SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
- SPDX-License-Identifier: AGPL-3.0-or-later
-->
21 changes: 21 additions & 0 deletions docs/functions/a11y.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
<!--
- SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
- SPDX-License-Identifier: AGPL-3.0-or-later
-->

```js static
import { isA11yActivation } from '@nextcloud/vue/dist/Functions/a11y.js'
```

## Definitions

```ts static
/**
* Return true if the DOM event is an accessible mouse or keyboard element activation, false otherwise
*
* @param {Event} event DOM event
*
* @return {boolean}
*/
declare function isA11yActivation(event: Event): boolean
```
127 changes: 127 additions & 0 deletions docs/functions/emoji.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,127 @@
<!--
- SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
- SPDX-License-Identifier: AGPL-3.0-or-later
-->

```ts static
import {
EmojiSkinTone,
emojiSearch,
emojiAddRecent,
getCurrentSkinTone,
setCurrentSkinTone,
} from '@nextcloud/vue/dist/Functions/emoji.js'
```

## Definitions

```ts static
/**
* Skin tones supported by Unicode Emojis (Fitzpatrick scale)
* The numeric values align with `emoji-mart-vue`
*/
enum EmojiSkinTone {}

/**
* Get the list of emojis by search filter or the list of frequently used emojis
*
* @param query Emoji search filter string; if no string or empty string is given, the list of frequently used emojis is returned
* @param maxResults Maximum of returned emojis
* @return list of found emojis in the same format as the emoji-mart-vue-fast's EmojiIndex
*/
declare function emojiSearch(query: string, maxResults: number = 10): object[]

/**
* Add emoji to the list of recent emojis.
* This list can be got from emojiSearch function and it is used in NcEmojiPicker.
*
* @param emojiData object with `id` property
* @param emojiData.id the emoji ID from emoji index
*/
declare function emojiAddRecent(emojiData: { id: string }): void

/**
* Get the current skin tone index used for emojis
* @return The skin tone
*/
declare function getCurrentSkinTone(): EmojiSkinTone

/**
* Set the current active skin tone for emojis
*
* @param skinTone Skin tone
*/
declare function setCurrentSkinTone(skinTone: EmojiSkinTone): void
```

## Usage

```vue
<template>
<div>
<NcEmojiPicker :key="selectedTone.value" @select="handleSelect">
<NcButton>Open Emoji Picker</NcButton>
</NcEmojiPicker>

<hr />

<NcSelect v-model="selectedTone" :options="tones" input-label="Current Skin Tone" />

<hr />

<p>
<code>emojiSearch('', 5).map((emoji) => emoji.native)</code>
<br />
{{ recent }}
</p>

<hr />

<NcButton @click="handleAddToRecent">Add 💙 to recent</NcButton>
</div>
</template>

<script>
export default {
data() {
const initialSkinTone = getCurrentSkinTone()
return {
recent: [],
selectedTone: {
label: EmojiSkinTone[initialSkinTone],
value: initialSkinTone,
},
tones: Object.entries(EmojiSkinTone)
.filter(([label, value]) => typeof value === 'number')
.map(([label, value]) => ({ label, value })),
}
},

watch: {
selectedTone({ label, value }) {
setCurrentSkinTone(value)
this.manuallyUpdateRecent()
},
},

created() {
this.manuallyUpdateRecent()
},

methods: {
manuallyUpdateRecent() {
this.recent = emojiSearch('', 5).map((emojiData) => emojiData.native)
},

handleAddToRecent() {
emojiAddRecent({ id: 'blue_heart' })
this.manuallyUpdateRecent()
},

handleSelect() {
this.manuallyUpdateRecent()
},
},
}
</script>
```
4 changes: 4 additions & 0 deletions docs/functions/reference.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
<!--
- SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
- SPDX-License-Identifier: AGPL-3.0-or-later
-->
4 changes: 4 additions & 0 deletions docs/functions/registerReference.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
<!--
- SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
- SPDX-License-Identifier: AGPL-3.0-or-later
-->
70 changes: 70 additions & 0 deletions docs/functions/usernameToColor.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
<!--
- SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
- SPDX-License-Identifier: AGPL-3.0-or-later
-->

```js static
import usernameToColor from '@nextcloud/vue/dist/Functions/usernameToColor.js'
```

## Definition

```ts static
/**
* Generate a color from a username
* Originally taken from https://github.com/nextcloud/server/blob/master/core/js/placeholder.js
*
* @param {string} username Display name or user id to generate from
* @return {{ r: number, g: number, b: number }} the RGB color
*/
declare function usernameToColor(username: string): { r: number, g: number, b: number }
```

## Usage

```vue
<template>
<div>
<NcTextField label="username" v-model="username" />
<hr />
<p class="color" :style="{ backgroundColor: color }">
<span class="color-text">{{ color }}</span>
</p>
</div>
</template>

<script>
export default {
data() {
return {
username: 'alice',
}
},

computed: {
color() {
const { r, g, b } = usernameToColor(this.username)
return `rgb(${r}, ${g}, ${b})`
},
},
}
</script>

<style scoped>
.color {
border-radius: var(--border-radius-large);
width: 100%;
padding: var(--default-grid-baseline);
display: flex;
align-items: center;
justify-content: center;
}

.color-text {
border-radius: var(--border-radius-large);
background-color: white;
color: black;
padding: var(--default-grid-baseline);
}
</style>
```
29 changes: 20 additions & 9 deletions src/functions/emoji/emoji.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,11 +28,13 @@ export enum EmojiSkinTone {
}

/**
* @param {string} query Emoji search string
* @param {number} maxResults Maximum of returned emojis
* @return {Array} list of found emojis
* Get the list of emojis by search filter or the list of frequently used emojis
*
* @param query Emoji search filter string; if no string or empty string is given, the list of frequently used emojis is returned
* @param maxResults Maximum of returned emojis
* @return {object[]} list of found emojis in the same format as the emoji-mart-vue-fast's EmojiIndex
*/
export const emojiSearch = (query: string, maxResults: number = 10) => {
export function emojiSearch(query: string, maxResults: number = 10): object[] {
// If this is the first call of function - initialize EmojiIndex
if (!emojiIndex) {
emojiIndex = new EmojiIndex(data)
Expand All @@ -52,25 +54,34 @@ export const emojiSearch = (query: string, maxResults: number = 10) => {
return results.map((emoji) => emoji.getSkin(currentSkinTone))
}

export const emojiAddRecent = function(id) {
frequently.add(id)
/**
* Add emoji to the list of recent emojis.
* This list can be got from emojiSearch function and it is used in NcEmojiPicker.
*
* @param emojiData object with `id` property
* @param emojiData.id the emoji ID from emoji index
*/
export function emojiAddRecent(emojiData: { id: string }): void {
frequently.add(emojiData)
}

/**
* Get the current skin tone index used for emojis
*
* @return {EmojiSkinTone} The skin tone
*/
export const getCurrentSkinTone = () => {
export function getCurrentSkinTone(): EmojiSkinTone {
const skinTone = Number.parseInt(storage.getItem('NcEmojiPicker::currentSkinTone') ?? '1')
// Clamp skinTone to valid ranges
return Math.min(Math.max(skinTone, EmojiSkinTone.Neutral), EmojiSkinTone.Dark)
}

/**
* Set the current active skin tone for emojis
* @param {EmojiSkinTone} skinTone Skin tone
*
* @param skinTone Skin tone
*/
export const setCurrentSkinTone = (skinTone: EmojiSkinTone) => {
export function setCurrentSkinTone(skinTone: EmojiSkinTone): void {
// Clamp skinTone to valid ranges
skinTone = Math.min(Math.max(skinTone, EmojiSkinTone.Neutral), EmojiSkinTone.Dark)
storage.setItem('NcEmojiPicker::currentSkinTone', skinTone.toString())
Expand Down
3 changes: 2 additions & 1 deletion src/functions/usernameToColor/usernameToColor.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,11 @@ import { GenColors } from '../../utils/GenColors.js'
import md5 from 'md5'

/**
* Generate a color from a username
* Originally taken from https://github.com/nextcloud/server/blob/master/core/js/placeholder.js
*
* @param {string} username Display name or user id to generate from
* @return {object} the rgb colors as {r:255, g:255, b:255}
* @return {{ r: number, g: number, b: number }} the RGB color
*/
const usernameToColor = function(username) {
// Normalize hash
Expand Down
27 changes: 27 additions & 0 deletions styleguide.config.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,33 @@ module.exports = async () => {
},
],
},
{
name: 'Functions',
content: 'docs/functions.md',
sectionDepth: 1,
sections: [
{
name: 'a11y',
content: 'docs/functions/a11y.md',
},
{
name: 'emoji',
content: 'docs/functions/emoji.md',
},
{
name: 'usernameToColor',
content: 'docs/functions/usernameToColor.md',
},
{
name: 'reference',
content: 'docs/functions/reference.md',
},
{
name: 'registerReference',
content: 'docs/functions/registerReference.md',
},
],
},
{
name: 'Components',
content: 'docs/components.md',
Expand Down
13 changes: 13 additions & 0 deletions styleguide/global.requires.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ import 'regenerator-runtime/runtime.js'

import axios from '@nextcloud/axios'

import { isA11yActivation } from '../src/functions/a11y/index.ts'
import { EmojiSkinTone, emojiSearch, emojiAddRecent, getCurrentSkinTone, setCurrentSkinTone } from '../src/functions/emoji/index.ts'
import usernameToColor from '../src/functions/usernameToColor/index.js'

const USER_GROUPS = [
{ id: 'admin', displayname: 'The administrators' },
{ id: 'accounting', displayname: 'Accounting team' },
Expand Down Expand Up @@ -145,6 +149,15 @@ window.OC = {
window.OCA = {}
window.appName = 'nextcloud-vue'

// Exported Functions
window.isA11yActivation = isA11yActivation
window.EmojiSkinTone = EmojiSkinTone
window.emojiSearch = emojiSearch
window.emojiAddRecent = emojiAddRecent
window.getCurrentSkinTone = getCurrentSkinTone
window.setCurrentSkinTone = setCurrentSkinTone
window.usernameToColor = usernameToColor

window.NextcloudVueDocs = {
tags: '<?xml version="1.0"?><d:multistatus xmlns:d="DAV:" xmlns:s="http://sabredav.org/ns" xmlns:oc="http://owncloud.org/ns" xmlns:nc="http://nextcloud.org/ns"><d:response><d:href>/remote.php/dav/systemtags/</d:href><d:propstat><d:prop><oc:id/><oc:display-name/><oc:user-visible/><oc:user-assignable/><oc:can-assign/></d:prop><d:status>HTTP/1.1 404 Not Found</d:status></d:propstat></d:response><d:response><d:href>/remote.php/dav/systemtags/7</d:href><d:propstat><d:prop><oc:id>7</oc:id><oc:display-name>tag1</oc:display-name><oc:user-visible>true</oc:user-visible><oc:user-assignable>true</oc:user-assignable><oc:can-assign>true</oc:can-assign></d:prop><d:status>HTTP/1.1 200 OK</d:status></d:propstat></d:response><d:response><d:href>/remote.php/dav/systemtags/2</d:href><d:propstat><d:prop><oc:id>2</oc:id><oc:display-name>tag2</oc:display-name><oc:user-visible>false</oc:user-visible><oc:user-assignable>true</oc:user-assignable><oc:can-assign>true</oc:can-assign></d:prop><d:status>HTTP/1.1 200 OK</d:status></d:propstat></d:response><d:response><d:href>/remote.php/dav/systemtags/3</d:href><d:propstat><d:prop><oc:id>3</oc:id><oc:display-name>tag3</oc:display-name><oc:user-visible>true</oc:user-visible><oc:user-assignable>true</oc:user-assignable><oc:can-assign>true</oc:can-assign></d:prop><d:status>HTTP/1.1 200 OK</d:status></d:propstat></d:response><d:response><d:href>/remote.php/dav/systemtags/4</d:href><d:propstat><d:prop><oc:id>4</oc:id><oc:display-name>important</oc:display-name><oc:user-visible>true</oc:user-visible><oc:user-assignable>true</oc:user-assignable><oc:can-assign>true</oc:can-assign></d:prop><d:status>HTTP/1.1 200 OK</d:status></d:propstat></d:response><d:response><d:href>/remote.php/dav/systemtags/1</d:href><d:propstat><d:prop><oc:id>1</oc:id><oc:display-name>secret</oc:display-name><oc:user-visible>true</oc:user-visible><oc:user-assignable>false</oc:user-assignable><oc:can-assign>true</oc:can-assign></d:prop><d:status>HTTP/1.1 200 OK</d:status></d:propstat></d:response><d:response><d:href>/remote.php/dav/systemtags/5</d:href><d:propstat><d:prop><oc:id>5</oc:id><oc:display-name>test</oc:display-name><oc:user-visible>true</oc:user-visible><oc:user-assignable>false</oc:user-assignable><oc:can-assign>true</oc:can-assign></d:prop><d:status>HTTP/1.1 200 OK</d:status></d:propstat></d:response><d:response><d:href>/remote.php/dav/systemtags/6</d:href><d:propstat><d:prop><oc:id>6</oc:id><oc:display-name>test2</oc:display-name><oc:user-visible>false</oc:user-visible><oc:user-assignable>false</oc:user-assignable><oc:can-assign>true</oc:can-assign></d:prop><d:status>HTTP/1.1 200 OK</d:status></d:propstat></d:response></d:multistatus>',
}
Loading