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

docs(widgets) Custom Widget Developer Guide #9304

Open
wants to merge 24 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
101aaf9
docs(widgets) Widget Developer Guide
chrisgervang Dec 18, 2024
ebd2b50
Update docs/developer-guide/custom-widgets/README.md
chrisgervang Dec 18, 2024
70248ce
Update docs/developer-guide/custom-widgets/universal-widgets.md
chrisgervang Dec 18, 2024
026fd27
Update docs/developer-guide/custom-widgets/README.md
chrisgervang Dec 18, 2024
41cdfb3
adding preact page and vanilla example
chrisgervang Dec 18, 2024
077ddd9
onViewportChange
chrisgervang Dec 18, 2024
775c7b8
misc react docs
chrisgervang Dec 18, 2024
e68bd41
Styling Your React Widget
chrisgervang Dec 18, 2024
5291a26
TOC
chrisgervang Dec 18, 2024
dcb07be
type cleanup
chrisgervang Dec 18, 2024
8daa0c6
Merge branch 'master' into chr/widget-dev-guide
chrisgervang Dec 18, 2024
e48c1c9
Adding required class members
chrisgervang Dec 19, 2024
98a82a4
Add reactivity to examples
chrisgervang Dec 21, 2024
5366ae2
[docs] rewrite React widget dev guide
chrisgervang Jan 2, 2025
f17de11
Merge branch 'master' into chr/widget-dev-guide
chrisgervang Jan 4, 2025
a45ba17
use type instead of interface
chrisgervang Jan 5, 2025
225cd33
Update preact-widgets.md
chrisgervang Jan 6, 2025
2548071
Fix example in preact-widgets.md
chrisgervang Jan 7, 2025
9a1ffe5
Merge branch 'master' into chr/widget-dev-guide
chrisgervang Jan 7, 2025
90e62a8
After testing react-widgets.md
chrisgervang Jan 8, 2025
afba3b8
Update react-widgets.md
chrisgervang Jan 8, 2025
5152e49
Use a portal instead of a ref
chrisgervang Jan 8, 2025
1392345
Update preact-widgets.md
chrisgervang Jan 10, 2025
06ef666
Update README.md
chrisgervang Jan 16, 2025
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
12 changes: 10 additions & 2 deletions docs/developer-guide/custom-widgets/preact-widgets.md
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,14 @@ class LayerListWidget implements Widget<LayerListWidgetProps> {
return element;
}

setProps(props: Partial<LayerListWidgetProps>) {
// Handle when props change here.
this.placement = props.placement ?? this.placement;
this.viewId = props.viewId ?? this.viewId;
this.props = {...props};
this.update();
}

onRedraw({layers}: {layers: Layer[]}) {
this.layers = layers;
this.update();
Expand All @@ -113,15 +121,15 @@ class LayerListWidget implements Widget<LayerListWidgetProps> {
this.viewports[viewport.id] = viewport
}

update() {
private update() {
const element = this.element;
if (!element) {
return;
}
let layers = this.layers
if (this.deck?.props.layerFilter) {
const ui = (
{viewports.values().map(viewport => (
{this.viewports.values().map(viewport => (
<div>
{viewport.id}
<ul>
Expand Down
9 changes: 8 additions & 1 deletion docs/developer-guide/custom-widgets/react-widgets.md
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ class RotateWidget implements Widget<RotateWidgetProps> {

constructor(props: RotateWidgetProps) {
this.id = props.id ?? this.id;
this.placement = props.placement || this.placement;
this.placement = props.placement ?? this.placement;
this.props = { ...props };
}

Expand All @@ -62,6 +62,13 @@ class RotateWidget implements Widget<RotateWidgetProps> {
return this.props.ref.current;
}

setProps(props: Partial<LayerLoadingWidgetProps>) {
// Handle when props change here.
this.placement = props.placement ?? this.placement;
this.viewId = props.viewId ?? this.viewId;
this.props = {...props};
chrisgervang marked this conversation as resolved.
Show resolved Hide resolved
}

onViewportChange(viewport) {
this.viewports[viewport.id] = viewport;
}
Expand Down
7 changes: 5 additions & 2 deletions docs/developer-guide/custom-widgets/universal-widgets.md
Original file line number Diff line number Diff line change
Expand Up @@ -287,7 +287,7 @@ interface LayerLoadingWidgetProps {
className?: string;
}

class LayerListWidget implements Widget<LayerLoadingWidgetProps> {
class LayerLoadingWidget implements Widget<LayerLoadingWidgetProps> {
id = 'layer-loading-widget';
props: LayerLoadingWidgetProps;
placement: WidgetPlacement = 'top-left';
Expand Down Expand Up @@ -318,16 +318,19 @@ class LayerListWidget implements Widget<LayerLoadingWidgetProps> {
}

setProps(props: Partial<LayerLoadingWidgetProps>) {
// Handle when props change here.
this.placement = props.placement ?? this.placement;
this.viewId = props.viewId ?? this.viewId;
this.props = {...props};
this.update();
}

onRedraw({layers}: {layers: Layer[]}) {
this.layers = layers;
this.update();
}

update() {
private update() {
const element = this.element;
if (!element) {
return;
Expand Down
Loading