Skip to content

Commit

Permalink
chore: allow user to resize modal window
Browse files Browse the repository at this point in the history
  • Loading branch information
cocotime authored and Xaviju committed Oct 8, 2024
1 parent 51625c3 commit 13ea206
Show file tree
Hide file tree
Showing 6 changed files with 66 additions and 20 deletions.
1 change: 1 addition & 0 deletions libs/plugins-runtime/src/lib/assets/resize.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
6 changes: 1 addition & 5 deletions libs/plugins-runtime/src/lib/create-modal.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,10 +44,6 @@ describe('createModal', () => {
'--modal-block-start',
'40px'
);
expect(modal.style.setProperty).toHaveBeenCalledWith(
'--modal-inline-end',
'320px'
);

expect(modal.setAttribute).toHaveBeenCalledWith('title', 'Test Modal');
expect(modal.setAttribute).toHaveBeenCalledWith(
Expand Down Expand Up @@ -83,7 +79,7 @@ describe('createModal', () => {
options
);

const expectedWidth = 680; // 1000 - 320 (initialPosition.inlineEnd)
const expectedWidth = 710; // 1000 - 270 (initialPosition.inlineEnd)
const expectedHeight = 760; // 800 - 40 (initialPosition.blockStart)

expect(modal.setAttribute).toHaveBeenCalledWith(
Expand Down
14 changes: 10 additions & 4 deletions libs/plugins-runtime/src/lib/create-modal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,21 +18,27 @@ export function createModal(
const defaultWidth = 335;
const defaultHeight = 590;

const maxWidth =
(options?.width ?? defaultWidth) > window.innerWidth
? window.innerWidth - 290
: options?.width ?? defaultWidth;

const initialPosition = {
blockStart: 40,
inlineEnd: 320,
// To be able to resize the element as expected the position must be absolute from the right.
// This value is the length of the window minus the width of the element plus the width of the design tab.
inlineStart: window.innerWidth - maxWidth - 290,
};

modal.style.setProperty(
'--modal-block-start',
`${initialPosition.blockStart}px`
);
modal.style.setProperty(
'--modal-inline-end',
`${initialPosition.inlineEnd}px`
'--modal-inline-start',
`${initialPosition.inlineStart}px`
);

const maxWidth = window.innerWidth - initialPosition.inlineEnd;
const maxHeight = window.innerHeight - initialPosition.blockStart;
let width = Math.min(options?.width || defaultWidth, maxWidth);
let height = Math.min(options?.height || defaultHeight, maxHeight);
Expand Down
4 changes: 2 additions & 2 deletions libs/plugins-runtime/src/lib/drag-handler.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
export const dragHandler = (el: HTMLElement, move?: () => void) => {
export const dragHandler = (el: HTMLElement, target: HTMLElement = el, move?: () => void) => {
let currentTranslate = { x: 0, y: 0 };
let initialTranslate = { x: 0, y: 0 };
let initialClientPosition = { x: 0, y: 0 };
Expand All @@ -10,7 +10,7 @@ export const dragHandler = (el: HTMLElement, move?: () => void) => {

currentTranslate = { x: deltaX, y: deltaY };

el.style.transform = `translate(${deltaX}px, ${deltaY}px)`;
target.style.transform = `translate(${deltaX}px, ${deltaY}px)`;

move?.();
};
Expand Down
16 changes: 13 additions & 3 deletions libs/plugins-runtime/src/lib/modal/plugin-modal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ export class PluginModalElement extends HTMLElement {
}

#wrapper: HTMLElement | null = null;
#inner: HTMLElement | null = null;
#dragEvents: ReturnType<typeof dragHandler> | null = null;

setTheme(theme: Theme) {
Expand Down Expand Up @@ -54,12 +55,20 @@ export class PluginModalElement extends HTMLElement {
}

this.#wrapper = document.createElement('div');
this.#inner = document.createElement('div');

this.#inner.classList.add('inner');

this.#wrapper.classList.add('wrapper');
this.#wrapper.style.inlineSize = `${width}px`;
this.#wrapper.style.minInlineSize = `${width}px`;
this.#wrapper.style.blockSize = `${height}px`;
this.#wrapper.style.minBlockSize = `${height}px`;
this.#wrapper.style.maxInlineSize = '90vw';
this.#wrapper.style.maxBlockSize = '90vh';

// move modal to the top
this.#dragEvents = dragHandler(this.#wrapper, () => {
this.#dragEvents = dragHandler(this.#inner, this.#wrapper, () => {
this.calculateZIndex();
});

Expand Down Expand Up @@ -124,8 +133,9 @@ export class PluginModalElement extends HTMLElement {

this.shadowRoot.appendChild(this.#wrapper);

this.#wrapper.appendChild(header);
this.#wrapper.appendChild(iframe);
this.#wrapper.appendChild(this.#inner);
this.#inner.appendChild(header);
this.#inner.appendChild(iframe);

const style = document.createElement('style');
style.textContent = modalCss;
Expand Down
45 changes: 39 additions & 6 deletions libs/plugins-runtime/src/lib/modal/plugin.modal.css
Original file line number Diff line number Diff line change
Expand Up @@ -25,18 +25,51 @@
color: var(--color-foreground-secondary);
}

::-webkit-resizer {
display: none;
}

.wrapper {
box-sizing: border-box;
display: flex;
flex-direction: column;
position: fixed;
position: absolute;
inset-block-start: var(--modal-block-start);
inset-inline-end: var(--modal-inline-end);
inset-inline-start: var(--modal-inline-start);
z-index: 1000;
padding: 25px;
padding: 10px;
border-radius: 15px;
border: 2px solid var(--color-background-quaternary);
box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.3);
overflow: hidden;
min-inline-size: 25px;
min-block-size: 200px;
resize: both;
&:after {
content: '';
cursor: se-resize;
inline-size: 1rem;
block-size: 1rem;
background-image: url('../assets/resize.svg');
background-position: center;
right: 5px;
bottom: 5px;
pointer-events: none;
position: absolute;
}
}

.inner {
padding: 10px;
cursor: grab;
box-sizing: border-box;
display: flex;
flex-direction: column;
overflow: hidden;
block-size: 100%;
& > * {
flex: 1;
}
& > .header {
flex: 0;
}
}

.header {
Expand Down

0 comments on commit 13ea206

Please sign in to comment.