@vcmap/ui 5.0.0-rc.25 → 5.0.0-rc.27

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (110) hide show
  1. package/build/buildCesium.js +7 -0
  2. package/config/dev.config.json +4 -0
  3. package/dist/assets/cesium/ThirdParty/Workers/basis_transcoder.js +21 -0
  4. package/dist/assets/cesium/ThirdParty/Workers/draco_decoder_nodejs.js +117 -0
  5. package/dist/assets/cesium/ThirdParty/Workers/package.json +1 -0
  6. package/dist/assets/cesium/ThirdParty/Workers/pako_deflate.min.js +2 -0
  7. package/dist/assets/cesium/ThirdParty/Workers/pako_inflate.min.js +2 -0
  8. package/dist/assets/cesium/ThirdParty/Workers/z-worker-pako.js +1 -0
  9. package/dist/assets/cesium/ThirdParty/basis_transcoder.wasm +0 -0
  10. package/dist/assets/cesium/ThirdParty/draco_decoder.wasm +0 -0
  11. package/dist/assets/cesium/ThirdParty/google-earth-dbroot-parser.js +8337 -0
  12. package/dist/assets/{cesium.1457fa.js → cesium.82fdbe.js} +4 -4
  13. package/dist/assets/cesium.js +1 -1
  14. package/dist/assets/{core.47836f.js → core.df069a.js} +2 -2
  15. package/dist/assets/core.js +1 -1
  16. package/dist/assets/index-1cff371d.js +1 -0
  17. package/dist/assets/ol.js +1 -1
  18. package/dist/assets/style/icon-marker-blue.534e37.png +0 -0
  19. package/dist/assets/style/icon-marker-green.0b6a92.png +0 -0
  20. package/dist/assets/style/icon-marker-o-blue.7b6d62.png +0 -0
  21. package/dist/assets/style/icon-marker-o-green.c863c0.png +0 -0
  22. package/dist/assets/style/icon-marker-o-red.93ff58.png +0 -0
  23. package/dist/assets/style/icon-marker-o.036477.png +0 -0
  24. package/dist/assets/style/icon-marker-red.313d03.png +0 -0
  25. package/dist/assets/style/icon-marker.70960f.png +0 -0
  26. package/dist/assets/style/icon-pin-blue.7be369.png +0 -0
  27. package/dist/assets/style/icon-pin-green.cbb935.png +0 -0
  28. package/dist/assets/style/icon-pin-red.3f25b2.png +0 -0
  29. package/dist/assets/style/icon-pin.b7ce77.png +0 -0
  30. package/dist/assets/{ui.6ed89d.css → ui.3ed7ff.css} +2 -2
  31. package/dist/assets/ui.3ed7ff.js +14763 -0
  32. package/dist/assets/ui.js +1 -1
  33. package/dist/assets/vue.js +2 -2
  34. package/dist/assets/{vuetify.d2131d.js → vuetify.614278.js} +1 -1
  35. package/dist/assets/vuetify.js +2 -2
  36. package/dist/index.html +1 -1
  37. package/index.js +19 -1
  38. package/package.json +1 -1
  39. package/plugins/@vcmap/create-link/index.js +8 -8
  40. package/plugins/@vcmap-show-case/collection-manager-example/index.js +6 -1
  41. package/plugins/@vcmap-show-case/form-inputs-example/FormInputsExample.vue +36 -8
  42. package/plugins/@vcmap-show-case/form-inputs-example/exampleActions.js +0 -19
  43. package/plugins/@vcmap-show-case/form-inputs-example/index.js +1 -2
  44. package/plugins/@vcmap-show-case/style-input-example/README.md +4 -0
  45. package/plugins/@vcmap-show-case/style-input-example/index.js +42 -0
  46. package/plugins/@vcmap-show-case/style-input-example/package.json +5 -0
  47. package/plugins/@vcmap-show-case/style-input-example/styleExample.vue +191 -0
  48. package/plugins/@vcmap-show-case/window-tester/WindowExample.vue +12 -13
  49. package/plugins/@vcmap-show-case/window-tester/windowExampleToggleChild.vue +44 -0
  50. package/public/assets/style/icon-marker-blue.png +0 -0
  51. package/public/assets/style/icon-marker-green.png +0 -0
  52. package/public/assets/style/icon-marker-o-blue.png +0 -0
  53. package/public/assets/style/icon-marker-o-green.png +0 -0
  54. package/public/assets/style/icon-marker-o-red.png +0 -0
  55. package/public/assets/style/icon-marker-o.png +0 -0
  56. package/public/assets/style/icon-marker-red.png +0 -0
  57. package/public/assets/style/icon-marker.png +0 -0
  58. package/public/assets/style/icon-pin-blue.png +0 -0
  59. package/public/assets/style/icon-pin-green.png +0 -0
  60. package/public/assets/style/icon-pin-red.png +0 -0
  61. package/public/assets/style/icon-pin.png +0 -0
  62. package/src/actions/actionHelper.js +1 -0
  63. package/src/application/VcsApp.vue +11 -4
  64. package/src/application/VcsNavbar.vue +11 -9
  65. package/src/components/buttons/VcsActionButtonList.vue +1 -0
  66. package/src/components/form-inputs-controls/VcsCheckbox.vue +3 -2
  67. package/src/components/form-inputs-controls/VcsFormSection.vue +59 -9
  68. package/src/components/form-inputs-controls/VcsLabel.vue +10 -0
  69. package/src/components/form-inputs-controls/VcsRadioGrid.vue +175 -0
  70. package/src/components/form-inputs-controls/VcsSelect.vue +3 -0
  71. package/src/components/form-inputs-controls/VcsTextField.vue +12 -0
  72. package/src/components/icons/+all.js +4 -0
  73. package/src/components/icons/EditVerticesIcon.vue +39 -0
  74. package/src/components/lists/VcsActionList.vue +2 -0
  75. package/src/components/style/MenuWrapper.vue +138 -0
  76. package/src/components/style/VcsFillMenu.vue +61 -0
  77. package/src/components/style/VcsFillSelector.vue +45 -0
  78. package/src/components/style/VcsImageMenu.vue +84 -0
  79. package/src/components/style/VcsImageSelector.vue +609 -0
  80. package/src/components/style/VcsStrokeMenu.vue +73 -0
  81. package/src/components/style/VcsStrokeSelector.vue +87 -0
  82. package/src/components/style/VcsTextMenu.vue +81 -0
  83. package/src/components/style/VcsTextSelector.vue +271 -0
  84. package/src/components/style/VcsVectorStyleComponent.vue +119 -0
  85. package/src/components/style/composables.js +84 -0
  86. package/src/components/tables/VcsDataTable.vue +3 -1
  87. package/src/components/tables/VcsTable.vue +1 -1
  88. package/src/contentTree/contentTreeCollection.js +1 -0
  89. package/src/i18n/de.js +51 -17
  90. package/src/i18n/en.js +56 -22
  91. package/src/legend/vcsLegend.vue +7 -5
  92. package/src/manager/collectionManager/CollectionComponent.vue +9 -17
  93. package/src/manager/collectionManager/CollectionComponentList.vue +22 -9
  94. package/src/manager/collectionManager/CollectionManager.vue +20 -1
  95. package/src/manager/collectionManager/collectionComponent.js +11 -0
  96. package/src/manager/window/WindowComponent.vue +2 -1
  97. package/src/manager/window/WindowManager.vue +45 -14
  98. package/src/manager/window/windowHelper.js +76 -4
  99. package/src/manager/window/windowManager.js +38 -6
  100. package/src/styles/_theming.scss +0 -16
  101. package/src/vcsUiApp.js +1 -0
  102. package/dist/assets/index-bb372634.js +0 -1
  103. package/dist/assets/logo-mobile.2d10a6.svg +0 -9
  104. package/dist/assets/logo.27089a.svg +0 -26
  105. package/dist/assets/ui.6ed89d.js +0 -13461
  106. /package/dist/assets/{ol.9e4d23.js → ol.90a5d0.js} +0 -0
  107. /package/dist/assets/{vue.7327e4.js → vue.537ff3.js} +0 -0
  108. /package/dist/assets/{vuetify.d2131d.css → vuetify.614278.css} +0 -0
  109. /package/{public/assets → src}/logo-mobile.svg +0 -0
  110. /package/{public/assets → src}/logo.svg +0 -0
@@ -0,0 +1,138 @@
1
+ <template>
2
+ <v-sheet>
3
+ <div class="d-flex align-center py-1">
4
+ <VcsCheckbox
5
+ :value="!!value"
6
+ @change="handleCheckbox"
7
+ :disabled="disabled"
8
+ />
9
+ <v-menu
10
+ :close-on-content-click="false"
11
+ :close-on-click="false"
12
+ v-model="isMenuOpen"
13
+ :absolute="true"
14
+ :disabled="!value || disabled"
15
+ min-width="300"
16
+ max-width="300"
17
+ >
18
+ <template #activator="{ on, attrs }">
19
+ <VcsTooltip :tooltip="name">
20
+ <template #activator="{ on: tooltipOn, attrs: tooltipAttrs }">
21
+ <v-card
22
+ rounded
23
+ height="24px"
24
+ width="32px"
25
+ v-bind="{ ...attrs, ...tooltipAttrs }"
26
+ v-on="{ ...on, ...tooltipOn }"
27
+ class="tiled-background"
28
+ >
29
+ <slot name="preview" />
30
+ </v-card>
31
+ </template>
32
+ </VcsTooltip>
33
+ </template>
34
+ <VcsFormSection
35
+ :heading="name"
36
+ :header-actions="[
37
+ {
38
+ name: 'reset',
39
+ title: 'components.style.reset',
40
+ icon: '$vcsReturn',
41
+ callback: () => {
42
+ reset();
43
+ },
44
+ },
45
+ {
46
+ name: 'close',
47
+ title: 'components.close',
48
+ icon: 'mdi-close-thick',
49
+ callback: () => {
50
+ close();
51
+ },
52
+ },
53
+ ]"
54
+ >
55
+ <slot name="content" />
56
+ </VcsFormSection>
57
+ </v-menu>
58
+ <span class="ml-2">{{ $t(name) }}</span>
59
+ </div>
60
+ </v-sheet>
61
+ </template>
62
+
63
+ <script>
64
+ import { ref } from 'vue';
65
+ import { VSheet, VMenu, VCard } from 'vuetify/lib';
66
+ import { VcsFormSection, VcsTooltip, VcsCheckbox } from '@vcmap/ui';
67
+
68
+ /**
69
+ * @description A wrapper for style components, that provides:
70
+ * - a 32 x 24 px preview
71
+ * - a checkbox that emits null when unchecked and the value of the valueDefault prop when checked again. If the vauleDefault is undefined or null, the valueFallback will be emitted.
72
+ * - a menu that pops up when clicking the preview. It has also a reset button that emits the value of the valueDefault prop when clicked
73
+ * @vue-prop {Object} [value] - Style options that are modelled by the checkbox.
74
+ * @vue-prop {string} name - The name that is displayed in the header of the menu and in the tooltip of the preview.
75
+ * @vue-prop {Object} [valueDefault] - The default Options, that are applied when clicking reset or setting the checkbox from null to true.
76
+ * @vue-prop {Object} valueFallback - The fallback Options, in case the valueDefault is null or undefined. These are applied when the checkbox is checked again and the default value is null. The fallback value must not be null or undefined.
77
+ */
78
+ export default {
79
+ name: 'MenuWrapper',
80
+ components: {
81
+ VSheet,
82
+ VMenu,
83
+ VCard,
84
+ VcsFormSection,
85
+ VcsTooltip,
86
+ VcsCheckbox,
87
+ },
88
+ props: {
89
+ value: {
90
+ default: undefined,
91
+ required: false,
92
+ type: Object,
93
+ },
94
+ valueDefault: {
95
+ default: undefined,
96
+ type: Object,
97
+ },
98
+ valueFallback: {
99
+ required: true,
100
+ type: Object,
101
+ },
102
+ name: {
103
+ required: true,
104
+ type: String,
105
+ },
106
+ disabled: {
107
+ default: false,
108
+ type: Boolean,
109
+ },
110
+ },
111
+ setup(props, { emit }) {
112
+ const isMenuOpen = ref(false);
113
+
114
+ return {
115
+ isMenuOpen,
116
+ reset() {
117
+ emit('input', props.valueDefault);
118
+ },
119
+ close() {
120
+ isMenuOpen.value = false;
121
+ },
122
+ handleCheckbox(value) {
123
+ emit(
124
+ 'input',
125
+ value ? props.valueDefault || props.valueFallback : null,
126
+ );
127
+ },
128
+ };
129
+ },
130
+ };
131
+ </script>
132
+
133
+ <style scoped>
134
+ .tiled-background {
135
+ background: url()
136
+ repeat;
137
+ }
138
+ </style>
@@ -0,0 +1,61 @@
1
+ <template>
2
+ <MenuWrapper
3
+ v-bind="{ value, valueDefault, disabled }"
4
+ :value-fallback="{ color: [255, 255, 255, 1] }"
5
+ v-on="$listeners"
6
+ name="components.style.fill"
7
+ >
8
+ <template #preview>
9
+ <v-sheet :color="rgbaString" width="100%" height="100%" />
10
+ </template>
11
+ <template #content>
12
+ <VcsFillSelector :value="value" v-on="$listeners" />
13
+ </template>
14
+ </MenuWrapper>
15
+ </template>
16
+
17
+ <script>
18
+ import { computed } from 'vue';
19
+ import { VSheet } from 'vuetify/lib';
20
+ import { VcsFillSelector } from '@vcmap/ui';
21
+ import MenuWrapper from './MenuWrapper.vue';
22
+ import { useColorObject, rgbaObjectToString } from './composables.js';
23
+
24
+ /**
25
+ * @description A wrapper for the VcsFillSelector, that has a small color preview and a menu that pops up when clicking the preview, containing the fill selector.
26
+ * When clicking the reset button, the valueDefault is emitted, when unchecking the checkbox in front of the preview, null is emitted. If it is checked again, valueDefault is emitted. If the valueDefault is undefined or null, { color: [255, 255, 255, 1] } is emitted.
27
+ * @vue-prop {import("ol/style/Fill").Options} [value] - The Fill Options
28
+ * @vue-prop {import("ol/style/Fill").Options} [valueDefault] - The default Fill Options
29
+ * @vue-prop {boolean} [disabled=false] - Disable the input
30
+ */
31
+ export default {
32
+ name: 'VcsFillMenu',
33
+ components: {
34
+ VSheet,
35
+ VcsFillSelector,
36
+ MenuWrapper,
37
+ },
38
+ props: {
39
+ value: {
40
+ type: Object,
41
+ default: undefined,
42
+ },
43
+ valueDefault: {
44
+ type: Object,
45
+ default: undefined,
46
+ },
47
+ disabled: {
48
+ type: Boolean,
49
+ default: false,
50
+ },
51
+ },
52
+ setup(props) {
53
+ const rgbaObject = useColorObject(() => props.value?.color);
54
+ return {
55
+ rgbaString: computed(() => rgbaObjectToString(rgbaObject.value)),
56
+ };
57
+ },
58
+ };
59
+ </script>
60
+
61
+ <style scoped></style>
@@ -0,0 +1,45 @@
1
+ <template>
2
+ <v-sheet>
3
+ <v-color-picker
4
+ :value="rgbaObject"
5
+ @input="updateColor"
6
+ mode="rgba"
7
+ :hide-mode-switch="true"
8
+ :disabled="!value"
9
+ />
10
+ </v-sheet>
11
+ </template>
12
+
13
+ <script>
14
+ import { VSheet, VColorPicker } from 'vuetify/lib';
15
+ import { useColorObject } from './composables.js';
16
+
17
+ /**
18
+ * @description Allows to model a JSON representation of ol/Fill vector style with a vuetify VColorPicker.
19
+ * @vue-prop {import("ol/style/Fill").Options} value - The Fill Options
20
+ */
21
+ export default {
22
+ name: 'VcsFillSelector',
23
+ components: {
24
+ VSheet,
25
+ VColorPicker,
26
+ },
27
+ props: {
28
+ value: {
29
+ type: Object,
30
+ default: undefined,
31
+ },
32
+ },
33
+ setup(props, { emit }) {
34
+ return {
35
+ rgbaObject: useColorObject(() => props.value?.color),
36
+ updateColor(rgba) {
37
+ const fill = {
38
+ color: [rgba.r, rgba.g, rgba.b, rgba.a],
39
+ };
40
+ emit('input', fill);
41
+ },
42
+ };
43
+ },
44
+ };
45
+ </script>
@@ -0,0 +1,84 @@
1
+ <template>
2
+ <MenuWrapper
3
+ v-bind="{ value, valueDefault }"
4
+ :value-fallback="{
5
+ radius: 10,
6
+ fill: { color: [255, 255, 255, 1] },
7
+ stroke: { color: [0, 0, 0, 1], width: 2 },
8
+ }"
9
+ v-on="$listeners"
10
+ name="components.style.image"
11
+ >
12
+ <template #preview>
13
+ <canvas ref="canvas" width="32" height="24" />
14
+ </template>
15
+ <template #content>
16
+ <VcsImageSelector
17
+ v-bind="{ value, valueDefault, iconOptions, extendedShapeSettings }"
18
+ v-on="$listeners"
19
+ class="pb-2"
20
+ />
21
+ </template>
22
+ </MenuWrapper>
23
+ </template>
24
+
25
+ <script>
26
+ import { onMounted, ref, watch } from 'vue';
27
+ import { VcsImageSelector } from '@vcmap/ui';
28
+ import MenuWrapper from './MenuWrapper.vue';
29
+ import { drawImageStyle } from './VcsImageSelector.vue';
30
+
31
+ /**
32
+ * @description A wrapper for the VcsImageSelector, that has a small shape/icon preview and a menu that pops up when clicking the preview, containing the image selector.
33
+ * @vue-prop {import("ol/style/RegularShape").Options | import("ol/style/Circle").Options | import("ol/style/Icon").Options} value - The Image options
34
+ * @vue-prop {import("ol/style/RegularShape").Options | import("ol/style/Circle").Options | import("ol/style/Icon").Options} valueDefault - The default image options
35
+ * @vue-prop {import("ol/style/Icon").Options} iconOptions - The icon options too choose from. Scale and opacity are ignored.
36
+ * @vue-prop {boolean} [extendedShapeSettings=false] - If true, there are all the input fields needed to create arbitrary ol RegularShapes.
37
+ */
38
+ export default {
39
+ name: 'VcsImageMenu',
40
+ components: {
41
+ MenuWrapper,
42
+ VcsImageSelector,
43
+ },
44
+ props: {
45
+ value: {
46
+ type: Object,
47
+ default: undefined,
48
+ },
49
+ valueDefault: {
50
+ type: Object,
51
+ default: undefined,
52
+ },
53
+ iconOptions: {
54
+ type: Array,
55
+ default: undefined,
56
+ },
57
+ extendedShapeSettings: {
58
+ type: Boolean,
59
+ default: false,
60
+ },
61
+ },
62
+ setup(props) {
63
+ const canvas = ref(null);
64
+
65
+ onMounted(() => {
66
+ drawImageStyle(canvas.value, props.value, true);
67
+ watch(
68
+ () => props.value,
69
+ () => {
70
+ // XXX Maybe add some sort of timeout funciton, so it draws only once when user stops using the slider
71
+ drawImageStyle(canvas.value, props.value, true);
72
+ },
73
+ { deep: true },
74
+ );
75
+ });
76
+
77
+ return {
78
+ canvas,
79
+ };
80
+ },
81
+ };
82
+ </script>
83
+
84
+ <style scoped></style>