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

Allow query title to be multiline #364

Merged
merged 3 commits into from
Jan 4, 2021
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
5 changes: 5 additions & 0 deletions datahub/webapp/components/DataDoc/DataDocCellControl.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -215,6 +215,10 @@ export const DataDocCellControl: React.FunctionComponent<IProps> = ({
/>
)
);
} else {
// In case center buttons are empty
// push an empty span to ensure the width
centerButtons.push(<span key="empty" />);
}

if (leftMenuItems.length) {
Expand Down Expand Up @@ -250,6 +254,7 @@ export const DataDocCellControl: React.FunctionComponent<IProps> = ({
</div>
) : null}
{centerButtons}
<span>&nbsp;</span>
{rightButtons.length ? (
<div className="block-right-buttons-wrapper flex-row">
{rightButtons}
Expand Down
34 changes: 14 additions & 20 deletions datahub/webapp/components/DataDoc/DataDocContentContainer.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import React, { useEffect, useState } from 'react';
import React, { useEffect, useState, useCallback } from 'react';
import { useResizeObserver } from 'hooks/useResizeObserver';

const isChrome = /chrome/.test(navigator.userAgent.toLowerCase());

Expand All @@ -12,27 +13,20 @@ export const DataDocContentContainer: React.FunctionComponent = isChrome
const [containerWidth, setContainerWidth] = useState(1200);
const selfRef = React.useRef<HTMLDivElement>(null);

useEffect(() => {
let observer;

if (selfRef.current) {
setContainerWidth(selfRef.current.offsetWidth);
observer = new ResizeObserver((entries) => {
for (const entry of entries) {
if (entry.contentRect) {
setContainerWidth(entry.contentRect.width);
}
useResizeObserver(
selfRef.current,
useCallback((entries) => {
for (const entry of entries) {
if (entry.contentRect) {
setContainerWidth(entry.contentRect.width);
}
});
observer.observe(selfRef.current);
}

return () => {
if (observer) {
observer.disconnect();
}
};
}, [selfRef.current]);
}, []),
useCallback(
() => setContainerWidth(selfRef.current.offsetWidth),
[]
)
);

return (
<div ref={selfRef} className="data-doc-content-container">
Expand Down
13 changes: 3 additions & 10 deletions datahub/webapp/components/DataDocQueryCell/DataDocQueryCell.scss
Original file line number Diff line number Diff line change
Expand Up @@ -50,19 +50,12 @@
.query-title {
flex: 1;

input.Title,
span {
.Title,
p {
font-weight: bold;
}
input.Title {
font-size: var(--large-text-size);
color: var(--dark-text-color);
text-overflow: ellipsis;
}
span {
font-size: var(--med-text-size);
color: var(--light-text-color);
margin-right: 8px;
padding: 8px;
}
}

Expand Down
12 changes: 5 additions & 7 deletions datahub/webapp/components/DataDocQueryCell/DataDocQueryCell.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ import { Modal } from 'ui/Modal/Modal';
import { Title } from 'ui/Title/Title';

import './DataDocQueryCell.scss';
import { ResizableTextArea } from 'ui/ResizableTextArea/ResizableTextArea';

const ON_CHANGE_DEBOUNCE_MS = 250;

Expand Down Expand Up @@ -539,15 +540,12 @@ class DataDocQueryCellComponent extends React.Component<IProps, IState> {
const { meta, selectedRange } = this.state;

const queryTitleDOM = isEditable ? (
<DebouncedInput
<ResizableTextArea
value={meta.title}
onChange={this.handleMetaTitleChange}
inputProps={{
placeholder: this.defaultCellTitle,
className: 'Title',
}}
transparent
flex
placeholder={this.defaultCellTitle}
className="Title"
/>
) : (
<Title size={4}>{this.dataCellTitle}</Title>
Expand Down Expand Up @@ -619,7 +617,7 @@ class DataDocQueryCellComponent extends React.Component<IProps, IState> {
);

const openSnippetDOM =
query.trim().length === 0 ? (
query.trim().length === 0 && isEditable ? (
<div className="add-snippet-wrapper flex-center">
<Button
title="Add Template"
Expand Down
23 changes: 23 additions & 0 deletions datahub/webapp/hooks/useResizeObserver.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import { useEffect } from 'react';

export function useResizeObserver(
element: HTMLElement,
onResize: (entries: ResizeObserverEntry[]) => void,
onResizeStart?: () => void
) {
useEffect(() => {
let observer: ResizeObserver | undefined;

if (element) {
onResizeStart?.();
observer = new ResizeObserver(onResize);
observer.observe(element);
}

return () => {
if (observer) {
observer.disconnect();
}
};
}, [element, onResize, onResizeStart]);
}
22 changes: 14 additions & 8 deletions datahub/webapp/ui/ResizableTextArea/ResizableTextArea.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import classNames from 'classnames';
import { bind } from 'lodash-decorators';
import { throttle } from 'lodash';
import React, { useRef, useEffect, useCallback } from 'react';
import styled from 'styled-components';
import { useResizeObserver } from 'hooks/useResizeObserver';

export interface IResizableTextareaProps
extends Omit<
Expand Down Expand Up @@ -57,17 +58,22 @@ export const ResizableTextArea: React.FC<IResizableTextareaProps> = ({
...textareaProps
}) => {
const textareaRef = useRef<HTMLTextAreaElement>();
const autoHeight = useCallback(
throttle(() => {
if (textareaRef.current && autoResize) {
const textarea = textareaRef.current;
textarea.style.height = 'auto';
textarea.style.height = `${textarea.scrollHeight}px`;
}
}, 500),
[autoResize]
);

useEffect(() => {
autoHeight();
}, [value, autoResize]);

const autoHeight = useCallback(() => {
if (textareaRef.current && autoResize) {
const textarea = textareaRef.current;
textarea.style.height = 'auto';
textarea.style.height = `${textarea.scrollHeight}px`;
}
}, [autoResize]);
useResizeObserver(textareaRef.current, autoHeight);

const handleChange = useCallback(
(evt: React.ChangeEvent<HTMLTextAreaElement>) => {
Expand Down