popup widget
自定义类名?
需求
设置弹窗的高/宽
思路
.esri-popup__main-container {
    width: 600px !important;
    min-height: 400px !important;
}
会污染全局。
- 自定义类名
pop.container = div
实现1
const pop = new Popup()
const containerEl = document.createElement('div')
containerEl.className = 'xixi-popup'
pop.container = containerEl
.xixi-popup .esri-popup__main-container {
    width: 600px !important;
    min-height: 400px !important;
}
实现2
实现1 会有bug。hhhhh
如果折叠弹窗,因为设置了min-height: 400px; 会导致弹窗无法折叠.
应该用max-height
.xixi-popup .esri-popup__main-container {
    width: 600px !important;
    max-height: 400px !important;
}
wait cursor
需求:
点击图斑, 弹出弹窗。 中间等待的时间希望有一个loading。
思 路:
用 arcgis/core 里的Spinner
实现:
import Spinner from '@arcgis/core/widgets/Spinner.js';
this.spinner = new Spinner({
    view,
});
view.ui.add(this.spinner);
async query(qGeom, mapPoint) {
    this._showSpinner(mapPoint);
}
this.watchHandler = this.view.popup.watch('visible', (newValue, oldValue, name) => {
    if (!newValue) {
        // ...
    }
    this._hideSpinner();
});
/**
 * helper
 */
_showSpinner(location) {
    this.spinner.show({
        location: location,
    });
}
_hideSpinner() {
    this.spinner.hide();
}
注意
如果loading图斑不显示,控制台报错404找不到。
把base/theme/light/main.css本地化。
参考:arcigs/core 4 本地化
修改样式
TODO:
需求:
我不想要它自带的样式,我要修改!!
思路:
具难改!
拖拽弹窗
思路
翻了翻 互联网 3.x 可以通过dojo/Movable来实现拖拽功能
参考: 例子
4.x 已经找不到这个类了
网上看到的方法都是用interact库的
参考:例子1
参考:interactjs库 参考:interactjs库 github 参考:interactjs库 destroy api
实现
vue + vite + arcgis/core 4.x
安装 npm install interactjs
import { createVNode, render } from 'vue';
import PopupContentConstructor from './popupTemplate.vue';
import Popup from '@arcgis/core/widgets/Popup.js';
import * as reactiveUtils from '@arcgis/core/core/reactiveUtils.js';
import interact from 'interactjs';
class Test{
    constructor(mapView){
        this.view = mapView;
        this.popupContainer = document.createElement('div');
        this.popupClassName = 'aha-esri-popup';
        this.popupTargetStr = '.aha-esri-popup.esri-component';
        this.popupTitle = `
            <div class="custom-esri-popup-title">
                <span>属性信息</span>
            </div>
        `;
        this.watchHandler = null;
    }
}
initInstance(props) {
    // container.style.height = '500px';
    const vnode = createVNode(PopupContentConstructor, {
        ...props,
        // onDestroy: () => {
        //     render(null, this.popupContainer);
        // },
    });
    render(vnode, this.popupContainer);
    return this.popupContainer;
}
showPopup(payload, mapPoint) {
    const popup = new Popup();
    const container = document.createElement('div');
    container.className = this.popupClassName;
    popup.container = container;
    popup.location = mapPoint;
    popup.title = this.popupTitle;
    this.view.popup = popup;
    popup.content = this.initInstance({
        payload,
        view2: this.view,
    });
    // this.view.popup.open();
    this.view.popup.dockEnabled = true;
    this.view.popup.dockOptions = {
        breakpoint: false,
        position: 'top-right',
    };
    // this.view.popup.dockOptions = null;
    this.view.popup.dockOptions.buttonEnabled = false;
    this.view.popup.viewModel.includeDefaultActions = false;
    this.watchHandler = this.view.popup.watch('visible', (newValue, oldValue, name) => {
        if (!newValue) {
            this.hlLayer?.removeAll();
            this.watchHandler?.remove();
            this.watchHandler = null;
            render(null, this.popupContainer);
            this.view.popup.content = null;
        }
        // this._hideSpinner();
    });
    this.view.popup.visible = true;
    setTimeout(() => {
        popup.reposition();
    }, 10);
    //
    reactiveUtils
        .whenOnce(() => this.view.popup?.visible)
        .then(() => {
            // draggle
            this.setupDraggle();
            // style
            // ...
        });
}
// popup draggle
destroyDraggle(target) {
    interact(target)?.unset();
}
setupDraggle() {
    const targetStr = this.popupTargetStr;
    this.destroyDraggle(targetStr);
    // setup the new listener:
    const position = { x: 0, y: 0 };
    interact(targetStr).draggable({
        listeners: {
            // start(event) {
            //   console.log(event.type, event.target);
            // },
            move(event) {
                // console.log(event.type, event.target);
                // hide the popup pointer:
                // const elements = document.querySelectorAll(".esri-popup__pointer");
                // elements[0].style.display = "none";
                // calculate the position and update:
                position.x += event.dx;
                position.y += event.dy;
                event.target.style.transform = `translate(${position.x}px, ${position.y}px)`;
            },
        },
    });
}