123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307 |
- import defined from "../../Core/defined.js";
- import destroyObject from "../../Core/destroyObject.js";
- import DeveloperError from "../../Core/DeveloperError.js";
- import FeatureDetection from "../../Core/FeatureDetection.js";
- import knockout from "../../ThirdParty/knockout.js";
- import getElement from "../getElement.js";
- import BaseLayerPickerViewModel from "./BaseLayerPickerViewModel.js";
- function BaseLayerPicker(container, options) {
-
- if (!defined(container)) {
- throw new DeveloperError("container is required.");
- }
-
- container = getElement(container);
- var viewModel = new BaseLayerPickerViewModel(options);
- var element = document.createElement("button");
- element.type = "button";
- element.className = "cesium-button cesium-toolbar-button";
- element.setAttribute(
- "data-bind",
- "\
- attr: { title: buttonTooltip },\
- click: toggleDropDown"
- );
- container.appendChild(element);
- var imgElement = document.createElement("img");
- imgElement.setAttribute("draggable", "false");
- imgElement.className = "cesium-baseLayerPicker-selected";
- imgElement.setAttribute(
- "data-bind",
- "\
- attr: { src: buttonImageUrl }, visible: !!buttonImageUrl"
- );
- element.appendChild(imgElement);
- var dropPanel = document.createElement("div");
- dropPanel.className = "cesium-baseLayerPicker-dropDown";
- dropPanel.setAttribute(
- "data-bind",
- '\
- css: { "cesium-baseLayerPicker-dropDown-visible" : dropDownVisible }'
- );
- container.appendChild(dropPanel);
- var imageryTitle = document.createElement("div");
- imageryTitle.className = "cesium-baseLayerPicker-sectionTitle";
- imageryTitle.setAttribute(
- "data-bind",
- "visible: imageryProviderViewModels.length > 0"
- );
- imageryTitle.innerHTML = "Imagery";
- dropPanel.appendChild(imageryTitle);
- var imagerySection = document.createElement("div");
- imagerySection.className = "cesium-baseLayerPicker-section";
- imagerySection.setAttribute("data-bind", "foreach: _imageryProviders");
- dropPanel.appendChild(imagerySection);
- var imageryCategories = document.createElement("div");
- imageryCategories.className = "cesium-baseLayerPicker-category";
- imagerySection.appendChild(imageryCategories);
- var categoryTitle = document.createElement("div");
- categoryTitle.className = "cesium-baseLayerPicker-categoryTitle";
- categoryTitle.setAttribute("data-bind", "text: name");
- imageryCategories.appendChild(categoryTitle);
- var imageryChoices = document.createElement("div");
- imageryChoices.className = "cesium-baseLayerPicker-choices";
- imageryChoices.setAttribute("data-bind", "foreach: providers");
- imageryCategories.appendChild(imageryChoices);
- var imageryProvider = document.createElement("div");
- imageryProvider.className = "cesium-baseLayerPicker-item";
- imageryProvider.setAttribute(
- "data-bind",
- '\
- css: { "cesium-baseLayerPicker-selectedItem" : $data === $parents[1].selectedImagery },\
- attr: { title: tooltip },\
- visible: creationCommand.canExecute,\
- click: function($data) { $parents[1].selectedImagery = $data; }'
- );
- imageryChoices.appendChild(imageryProvider);
- var providerIcon = document.createElement("img");
- providerIcon.className = "cesium-baseLayerPicker-itemIcon";
- providerIcon.setAttribute("data-bind", "attr: { src: iconUrl }");
- providerIcon.setAttribute("draggable", "false");
- imageryProvider.appendChild(providerIcon);
- var providerLabel = document.createElement("div");
- providerLabel.className = "cesium-baseLayerPicker-itemLabel";
- providerLabel.setAttribute("data-bind", "text: name");
- imageryProvider.appendChild(providerLabel);
- var terrainTitle = document.createElement("div");
- terrainTitle.className = "cesium-baseLayerPicker-sectionTitle";
- terrainTitle.setAttribute(
- "data-bind",
- "visible: terrainProviderViewModels.length > 0"
- );
- terrainTitle.innerHTML = "Terrain";
- dropPanel.appendChild(terrainTitle);
- var terrainSection = document.createElement("div");
- terrainSection.className = "cesium-baseLayerPicker-section";
- terrainSection.setAttribute("data-bind", "foreach: _terrainProviders");
- dropPanel.appendChild(terrainSection);
- var terrainCategories = document.createElement("div");
- terrainCategories.className = "cesium-baseLayerPicker-category";
- terrainSection.appendChild(terrainCategories);
- var terrainCategoryTitle = document.createElement("div");
- terrainCategoryTitle.className = "cesium-baseLayerPicker-categoryTitle";
- terrainCategoryTitle.setAttribute("data-bind", "text: name");
- terrainCategories.appendChild(terrainCategoryTitle);
- var terrainChoices = document.createElement("div");
- terrainChoices.className = "cesium-baseLayerPicker-choices";
- terrainChoices.setAttribute("data-bind", "foreach: providers");
- terrainCategories.appendChild(terrainChoices);
- var terrainProvider = document.createElement("div");
- terrainProvider.className = "cesium-baseLayerPicker-item";
- terrainProvider.setAttribute(
- "data-bind",
- '\
- css: { "cesium-baseLayerPicker-selectedItem" : $data === $parents[1].selectedTerrain },\
- attr: { title: tooltip },\
- visible: creationCommand.canExecute,\
- click: function($data) { $parents[1].selectedTerrain = $data; }'
- );
- terrainChoices.appendChild(terrainProvider);
- var terrainProviderIcon = document.createElement("img");
- terrainProviderIcon.className = "cesium-baseLayerPicker-itemIcon";
- terrainProviderIcon.setAttribute("data-bind", "attr: { src: iconUrl }");
- terrainProviderIcon.setAttribute("draggable", "false");
- terrainProvider.appendChild(terrainProviderIcon);
- var terrainProviderLabel = document.createElement("div");
- terrainProviderLabel.className = "cesium-baseLayerPicker-itemLabel";
- terrainProviderLabel.setAttribute("data-bind", "text: name");
- terrainProvider.appendChild(terrainProviderLabel);
- knockout.applyBindings(viewModel, element);
- knockout.applyBindings(viewModel, dropPanel);
- this._viewModel = viewModel;
- this._container = container;
- this._element = element;
- this._dropPanel = dropPanel;
- this._closeDropDown = function (e) {
- if (!(element.contains(e.target) || dropPanel.contains(e.target))) {
- viewModel.dropDownVisible = false;
- }
- };
- if (FeatureDetection.supportsPointerEvents()) {
- document.addEventListener("pointerdown", this._closeDropDown, true);
- } else {
- document.addEventListener("mousedown", this._closeDropDown, true);
- document.addEventListener("touchstart", this._closeDropDown, true);
- }
- }
- Object.defineProperties(BaseLayerPicker.prototype, {
-
- container: {
- get: function () {
- return this._container;
- },
- },
-
- viewModel: {
- get: function () {
- return this._viewModel;
- },
- },
- });
- BaseLayerPicker.prototype.isDestroyed = function () {
- return false;
- };
- BaseLayerPicker.prototype.destroy = function () {
- if (FeatureDetection.supportsPointerEvents()) {
- document.removeEventListener("pointerdown", this._closeDropDown, true);
- } else {
- document.removeEventListener("mousedown", this._closeDropDown, true);
- document.removeEventListener("touchstart", this._closeDropDown, true);
- }
- knockout.cleanNode(this._element);
- knockout.cleanNode(this._dropPanel);
- this._container.removeChild(this._element);
- this._container.removeChild(this._dropPanel);
- return destroyObject(this);
- };
- export default BaseLayerPicker;
|