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

feat(codex-ui): popup and confirm implementation #254

Merged
merged 43 commits into from
Dec 5, 2024
Merged
Show file tree
Hide file tree
Changes from 38 commits
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
0eaaafd
Added popup to the Playground
Jul 5, 2024
030c3a0
Added popup container
Jul 5, 2024
7db5988
Added close button
Jul 5, 2024
8a17f3e
Fix border
Jul 5, 2024
524df3c
Added trigger component what can show popup
Jul 6, 2024
c7a1a82
Added close button
Jul 6, 2024
36c01de
Added teleport
Jul 6, 2024
246848f
Added confirm component
Jul 6, 2024
56a0795
Remove useless style
Jul 6, 2024
3e3d8c3
Added functions to the buttons
Jul 6, 2024
243279a
Fix component description
Jul 7, 2024
aa750f4
Fix naming of the buttons
Jul 7, 2024
9ab7986
Move popup to the bottom of Playground
Jul 7, 2024
8ed65a1
Added usePopup function
Jul 7, 2024
3b27cf0
Remove vue teleport
Jul 15, 2024
bdd791c
Added Popup to the playground
Jul 15, 2024
0aea846
Merge branch 'main' into feat/popup-implementation
Jul 15, 2024
74d557f
Fix export
Jul 15, 2024
e5efa9a
Fix naming
Jul 17, 2024
baea337
Added missed comment
Jul 20, 2024
382694b
Added close on click outside the popup container
Jul 20, 2024
1a8764f
Added close on esc button
Jul 20, 2024
01a94ee
Change z-index level and rename body to text
Jul 20, 2024
3f2bb38
Added support enter button for confirm
Jul 20, 2024
1da8277
Change popup z-index
Jul 20, 2024
9698e0a
Move confirm to separate folder
Jul 21, 2024
87fac03
Added useConfirm
Jul 21, 2024
6d1fcba
Move onCancel and onConfirm logic
Jul 21, 2024
8ef117c
move usePopup logic to the useConfirm
Jul 21, 2024
c85ec65
Fix await logic
Jul 21, 2024
bffc40a
Remove interval
Jul 24, 2024
7e49c70
Merge branch 'main' into feat/popup-implementation
Sep 4, 2024
97dae48
Removed reduant onConfirm and onCancel fuctions
Sep 4, 2024
ee91e7c
Added separate page for Confirm
Sep 6, 2024
28bd1c3
Added stub text component
Sep 6, 2024
fb7215f
get rid of result ref
Sep 6, 2024
34ef9e1
Move on Escape reaction in usePopup
Sep 6, 2024
84d5273
Added hover to close button
Sep 6, 2024
5b52b28
Move StubText to another folder
Oct 2, 2024
e6e6f62
Added hidePoput punc oh Confirm and on Cancel
Dec 4, 2024
79fa04e
Fixed components positions
Dec 4, 2024
27d14cd
Fix Enter press
Dec 4, 2024
54f25f6
Fix Esc behavior
Dec 5, 2024
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
14 changes: 13 additions & 1 deletion codex-ui/dev/Playground.vue
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@
</div>
</div>
<Popover />
<Popup />
</div>
</template>

Expand All @@ -38,7 +39,8 @@ import { computed } from 'vue';
import {
VerticalMenu,
Tabbar,
Popover
Popover,
Popup
} from '../src/vue';
import { useTheme } from '../src/vue/composables/useTheme';

Expand Down Expand Up @@ -197,6 +199,16 @@ const pages = computed(() => [
onActivate: () => router.push('/components/editor'),
isActive: route.path === '/components/editor',
},
{
title: 'Popup',
onActivate: () => router.push('/components/popup'),
isActive: route.path === '/components/popup',
},
{
title: 'Confirm',
onActivate: () => router.push('/components/confirm'),
isActive: route.path === '/components/confirm',
},
],
},
]);
Expand Down
41 changes: 41 additions & 0 deletions codex-ui/dev/pages/components/Confirm.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
<template>
<PageHeader>
Confirm
<template #description>
A component that allows you to accept or reject a message that appears
</template>
</PageHeader>
<Button
secondary
data-dimensions="large"
@click="show()"
>
Press here to open confirm window
</Button>
</template>

<script setup lang="ts">
import PageHeader from '../../components/PageHeader.vue';
import { Button, useConfirm } from '../../../src/vue';

const { confirm } = useConfirm();

async function show() {
const res = await confirm(
'CodeX',
'Are you sure you want to delete the page?'
);

if (res) {
// eslint-disable-next-line no-console
console.log('The confirm button was pressed');
} else {
// eslint-disable-next-line no-console
console.log('The cancel button was pressed');
neSpecc marked this conversation as resolved.
Show resolved Hide resolved
}
}

</script>

<style scoped>
</style>
33 changes: 33 additions & 0 deletions codex-ui/dev/pages/components/Popup.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
<template>
<PageHeader>
Popup
<template #description>
A component that appears on top of other components. Can include any other component.
</template>
</PageHeader>
<Button
secondary
data-dimensions="large"
@click="show()"
>
Press here to open popup
</Button>
</template>

<script setup lang="ts">
import PageHeader from '../../components/PageHeader.vue';
import { StubText, Button, usePopup } from '../../../src/vue';
neSpecc marked this conversation as resolved.
Show resolved Hide resolved

const { showPopup } = usePopup();

function show(): void {
showPopup({
component: StubText,
props: {},
});
}

</script>

<style scoped>
</style>
10 changes: 10 additions & 0 deletions codex-ui/dev/routes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@ import VerticalMenu from './pages/components/VerticalMenu.vue';
import ContextMenu from './pages/components/ContextMenu.vue';
import Editor from './pages/components/Editor.vue';
import ThemePreview from './pages/components/ThemePreview.vue';
import Popup from './pages/components/Popup.vue';
import Confirm from './pages/components/Confirm.vue';

/**
* Vue router routes list
Expand Down Expand Up @@ -145,6 +147,14 @@ const routes: RouteRecordRaw[] = [
path: '/components/theme-preview',
component: ThemePreview as Component,
},
{
path: '/components/popup',
component: Popup as Component,
},
{
path: '/components/confirm',
component: Confirm as Component,
},
];

export default routes;
1 change: 1 addition & 0 deletions codex-ui/src/styles/z-axis.pcss
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
:root {
--z-popover: 3;
--z-popup: calc(var(--z-popover) + 1);
}
121 changes: 121 additions & 0 deletions codex-ui/src/vue/components/confirm/Confirm.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
<template>
<div
:class="$style['confirm']"
data-dimensions="large"
>
<div class="text-ui-base-bold">
{{ title }}
</div>
<div :class="[$style['confirm__body'], 'text-ui-base-medium']">
{{ text }}
</div>
<div :class="$style['confirm__controls']">
<Button
secondary
@click="onCancel"
>
<div :class="$style['confirm__button-inner']">
{{ cancelText }}
</div>
</Button>
<Button
primary
@click="onConfirm"
>
<div :class="$style['confirm__button-inner']">
{{ confirmText }}
</div>
</Button>
</div>
</div>
</template>

<script setup lang="ts">
import Button from '../button/Button.vue';
import { onMounted, onUnmounted } from 'vue';

const props = withDefaults(
defineProps<{
/**
* Text that will be displayed at the top of comfirm container
*/
title: string;

/**
* Text that will be displayed in the middle part of the confirm container
*/
text: string;

/**
* Text that will be displayed in the confirm button
*/
confirmText?: string;

/**
* Text that will be displayed in the cancel button
*/
cancelText?: string;

/**
* Function that is executed after pressing the Cancel button
*/
onCancel: () => void;

/**
* Function that is executed after pressing the Confirm button
*/
onConfirm: () => void;
}>(),
{
confirmText: 'Confirm',
cancelText: 'Cancel',
}
);

/**
* Call onConfirm when enter was pressed
*
* @param event - the event object representing the keyboard event
* @param event.key - the property of the event object that holds the value of the pressed key
*/
const confirmOnEnter = (event: { key: string }) => {
if (event.key === 'Enter') {
props.onConfirm;
}
};

onMounted(() => {
document.addEventListener('keydown', confirmOnEnter);
});

onUnmounted(() => {
document.removeEventListener('keydown', confirmOnEnter);
});

</script>

<style module>
.confirm {
display: flex;
flex-direction: column;
gap: var(--v-padding);
text-align: center;
width: min-content;

&__body {
padding: 0 var(--spacing-ml) 0 var(--spacing-ml);
word-wrap: break-word;
}

&__controls {
display: flex;
padding: var(--v-padding) 0 0 0;
gap: var(--spacing-m);
}

&__button-inner {
width: 84px;
}
}

</style>
4 changes: 4 additions & 0 deletions codex-ui/src/vue/components/confirm/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
import Confirm from './Confirm.vue';
export * from './useConfirm';

export { Confirm };
38 changes: 38 additions & 0 deletions codex-ui/src/vue/components/confirm/useConfirm.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
import { createSharedComposable } from '@vueuse/core';
import { usePopup } from '../popup';
import { Confirm } from '.';

export const useConfirm = createSharedComposable(() => {
/**
* Used to create a Popup component that will display the current Confirm
*/
const { showPopup } = usePopup();

/**
* @param title - title of the confirm window
* @param text - message to be displayed in confirm window
* @returns user selection result
*/
async function confirm(title: string, text: string): Promise<boolean> {
return new Promise<boolean>((resolve) => {
neSpecc marked this conversation as resolved.
Show resolved Hide resolved
showPopup({
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
component: Confirm,
props: {
title: title,
text: text,
onCancel: () => {
resolve(false);
},
onConfirm: () => {
resolve(true);
},
},
});
});
}

return {
confirm,
};
});
14 changes: 14 additions & 0 deletions codex-ui/src/vue/components/popup/Popup.types.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
import type { Component } from 'vue';

export interface PopupContent {
/**
* Component to render in the popup
*/
component: Component;

/**
* Props to pass to the component
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any
props: Record<string, any>;
}
Loading
Loading