@operato/board 0.2.45 → 0.2.46

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 (138) hide show
  1. package/@types/global/index.d.ts +1 -0
  2. package/CHANGELOG.md +19 -0
  3. package/assets/images/components/no-image.png +0 -0
  4. package/custom-elements.json +4419 -365
  5. package/dist/src/index.d.ts +1 -0
  6. package/dist/src/index.js +1 -0
  7. package/dist/src/index.js.map +1 -1
  8. package/dist/src/modeller/component-toolbar/component-menu.d.ts +4 -0
  9. package/dist/src/modeller/component-toolbar/component-menu.js +148 -0
  10. package/dist/src/modeller/component-toolbar/component-menu.js.map +1 -0
  11. package/dist/src/modeller/component-toolbar/component-toolbar.d.ts +4 -0
  12. package/dist/src/modeller/component-toolbar/component-toolbar.js +176 -0
  13. package/dist/src/modeller/component-toolbar/component-toolbar.js.map +1 -0
  14. package/dist/src/modeller/edit-toolbar-style.d.ts +4 -0
  15. package/dist/src/modeller/edit-toolbar-style.js +227 -0
  16. package/dist/src/modeller/edit-toolbar-style.js.map +1 -0
  17. package/dist/src/modeller/edit-toolbar.d.ts +61 -0
  18. package/dist/src/modeller/edit-toolbar.js +644 -0
  19. package/dist/src/modeller/edit-toolbar.js.map +1 -0
  20. package/dist/src/modeller/property-sidebar/abstract-property.d.ts +10 -0
  21. package/dist/src/modeller/property-sidebar/abstract-property.js +58 -0
  22. package/dist/src/modeller/property-sidebar/abstract-property.js.map +1 -0
  23. package/dist/src/modeller/property-sidebar/data-binding/data-binding-mapper.d.ts +49 -0
  24. package/dist/src/modeller/property-sidebar/data-binding/data-binding-mapper.js +348 -0
  25. package/dist/src/modeller/property-sidebar/data-binding/data-binding-mapper.js.map +1 -0
  26. package/dist/src/modeller/property-sidebar/data-binding/data-binding.d.ts +8 -0
  27. package/dist/src/modeller/property-sidebar/data-binding/data-binding.js +428 -0
  28. package/dist/src/modeller/property-sidebar/data-binding/data-binding.js.map +1 -0
  29. package/dist/src/modeller/property-sidebar/effects/effects-shared-style.d.ts +4 -0
  30. package/dist/src/modeller/property-sidebar/effects/effects-shared-style.js +57 -0
  31. package/dist/src/modeller/property-sidebar/effects/effects-shared-style.js.map +1 -0
  32. package/dist/src/modeller/property-sidebar/effects/effects.d.ts +7 -0
  33. package/dist/src/modeller/property-sidebar/effects/effects.js +59 -0
  34. package/dist/src/modeller/property-sidebar/effects/effects.js.map +1 -0
  35. package/dist/src/modeller/property-sidebar/effects/property-animation.d.ts +23 -0
  36. package/dist/src/modeller/property-sidebar/effects/property-animation.js +131 -0
  37. package/dist/src/modeller/property-sidebar/effects/property-animation.js.map +1 -0
  38. package/dist/src/modeller/property-sidebar/effects/property-animations.d.ts +6 -0
  39. package/dist/src/modeller/property-sidebar/effects/property-animations.js +84 -0
  40. package/dist/src/modeller/property-sidebar/effects/property-animations.js.map +1 -0
  41. package/dist/src/modeller/property-sidebar/effects/property-event-hover.d.ts +4 -0
  42. package/dist/src/modeller/property-sidebar/effects/property-event-hover.js +128 -0
  43. package/dist/src/modeller/property-sidebar/effects/property-event-hover.js.map +1 -0
  44. package/dist/src/modeller/property-sidebar/effects/property-event-tap.d.ts +4 -0
  45. package/dist/src/modeller/property-sidebar/effects/property-event-tap.js +124 -0
  46. package/dist/src/modeller/property-sidebar/effects/property-event-tap.js.map +1 -0
  47. package/dist/src/modeller/property-sidebar/effects/property-event.d.ts +6 -0
  48. package/dist/src/modeller/property-sidebar/effects/property-event.js +63 -0
  49. package/dist/src/modeller/property-sidebar/effects/property-event.js.map +1 -0
  50. package/dist/src/modeller/property-sidebar/effects/property-shadow.d.ts +23 -0
  51. package/dist/src/modeller/property-sidebar/effects/property-shadow.js +110 -0
  52. package/dist/src/modeller/property-sidebar/effects/property-shadow.js.map +1 -0
  53. package/dist/src/modeller/property-sidebar/effects/value-converter.d.ts +1 -0
  54. package/dist/src/modeller/property-sidebar/effects/value-converter.js +23 -0
  55. package/dist/src/modeller/property-sidebar/effects/value-converter.js.map +1 -0
  56. package/dist/src/modeller/property-sidebar/inspector/inspector.d.ts +24 -0
  57. package/dist/src/modeller/property-sidebar/inspector/inspector.js +290 -0
  58. package/dist/src/modeller/property-sidebar/inspector/inspector.js.map +1 -0
  59. package/dist/src/modeller/property-sidebar/property-shared-style.d.ts +4 -0
  60. package/dist/src/modeller/property-sidebar/property-shared-style.js +131 -0
  61. package/dist/src/modeller/property-sidebar/property-shared-style.js.map +1 -0
  62. package/dist/src/modeller/property-sidebar/property-sidebar.d.ts +10 -0
  63. package/dist/src/modeller/property-sidebar/property-sidebar.js +313 -0
  64. package/dist/src/modeller/property-sidebar/property-sidebar.js.map +1 -0
  65. package/dist/src/modeller/property-sidebar/shapes/box-padding-editor-styles.d.ts +1 -0
  66. package/dist/src/modeller/property-sidebar/shapes/box-padding-editor-styles.js +94 -0
  67. package/dist/src/modeller/property-sidebar/shapes/box-padding-editor-styles.js.map +1 -0
  68. package/dist/src/modeller/property-sidebar/shapes/shapes.d.ts +7 -0
  69. package/dist/src/modeller/property-sidebar/shapes/shapes.js +409 -0
  70. package/dist/src/modeller/property-sidebar/shapes/shapes.js.map +1 -0
  71. package/dist/src/modeller/property-sidebar/specifics/specific-properties-builder.d.ts +4 -0
  72. package/dist/src/modeller/property-sidebar/specifics/specific-properties-builder.js +127 -0
  73. package/dist/src/modeller/property-sidebar/specifics/specific-properties-builder.js.map +1 -0
  74. package/dist/src/modeller/property-sidebar/specifics/specifics.d.ts +5 -0
  75. package/dist/src/modeller/property-sidebar/specifics/specifics.js +78 -0
  76. package/dist/src/modeller/property-sidebar/specifics/specifics.js.map +1 -0
  77. package/dist/src/modeller/property-sidebar/styles/styles.d.ts +9 -0
  78. package/dist/src/modeller/property-sidebar/styles/styles.js +563 -0
  79. package/dist/src/modeller/property-sidebar/styles/styles.js.map +1 -0
  80. package/dist/src/modeller/scene-viewer/confidential-overlay.d.ts +4 -0
  81. package/dist/src/modeller/scene-viewer/confidential-overlay.js +14 -0
  82. package/dist/src/modeller/scene-viewer/confidential-overlay.js.map +1 -0
  83. package/dist/src/modeller/scene-viewer/ox-scene-handler.d.ts +11 -0
  84. package/dist/src/modeller/scene-viewer/ox-scene-handler.js +36 -0
  85. package/dist/src/modeller/scene-viewer/ox-scene-handler.js.map +1 -0
  86. package/dist/src/modeller/scene-viewer/ox-scene-layer.d.ts +10 -0
  87. package/dist/src/modeller/scene-viewer/ox-scene-layer.js +42 -0
  88. package/dist/src/modeller/scene-viewer/ox-scene-layer.js.map +1 -0
  89. package/dist/src/modeller/scene-viewer/ox-scene-player.d.ts +1 -0
  90. package/dist/src/modeller/scene-viewer/ox-scene-player.js +99 -0
  91. package/dist/src/modeller/scene-viewer/ox-scene-player.js.map +1 -0
  92. package/dist/src/modeller/scene-viewer/ox-scene-property.d.ts +6 -0
  93. package/dist/src/modeller/scene-viewer/ox-scene-property.js +19 -0
  94. package/dist/src/modeller/scene-viewer/ox-scene-property.js.map +1 -0
  95. package/dist/src/modeller/scene-viewer/ox-scene-viewer.d.ts +39 -0
  96. package/dist/src/modeller/scene-viewer/ox-scene-viewer.js +245 -0
  97. package/dist/src/modeller/scene-viewer/ox-scene-viewer.js.map +1 -0
  98. package/dist/src/ox-board-modeller.d.ts +12 -3
  99. package/dist/src/ox-board-modeller.js +128 -39
  100. package/dist/src/ox-board-modeller.js.map +1 -1
  101. package/dist/src/types.d.ts +12 -0
  102. package/dist/src/types.js +2 -0
  103. package/dist/src/types.js.map +1 -0
  104. package/dist/tsconfig.tsbuildinfo +1 -1
  105. package/package.json +26 -5
  106. package/src/index.ts +1 -0
  107. package/src/modeller/component-toolbar/component-menu.ts +142 -0
  108. package/src/modeller/component-toolbar/component-toolbar.ts +169 -0
  109. package/src/modeller/edit-toolbar-style.ts +228 -0
  110. package/src/modeller/edit-toolbar.ts +640 -0
  111. package/src/modeller/property-sidebar/abstract-property.ts +73 -0
  112. package/src/modeller/property-sidebar/data-binding/data-binding-mapper.ts +368 -0
  113. package/src/modeller/property-sidebar/data-binding/data-binding.ts +447 -0
  114. package/src/modeller/property-sidebar/effects/effects-shared-style.ts +58 -0
  115. package/src/modeller/property-sidebar/effects/effects.ts +55 -0
  116. package/src/modeller/property-sidebar/effects/property-animation.ts +131 -0
  117. package/src/modeller/property-sidebar/effects/property-animations.ts +82 -0
  118. package/src/modeller/property-sidebar/effects/property-event-hover.ts +133 -0
  119. package/src/modeller/property-sidebar/effects/property-event-tap.ts +129 -0
  120. package/src/modeller/property-sidebar/effects/property-event.ts +63 -0
  121. package/src/modeller/property-sidebar/effects/property-shadow.ts +112 -0
  122. package/src/modeller/property-sidebar/effects/value-converter.ts +26 -0
  123. package/src/modeller/property-sidebar/inspector/inspector.ts +327 -0
  124. package/src/modeller/property-sidebar/property-shared-style.ts +132 -0
  125. package/src/modeller/property-sidebar/property-sidebar.ts +308 -0
  126. package/src/modeller/property-sidebar/shapes/box-padding-editor-styles.ts +94 -0
  127. package/src/modeller/property-sidebar/shapes/shapes.ts +411 -0
  128. package/src/modeller/property-sidebar/specifics/specific-properties-builder.ts +135 -0
  129. package/src/modeller/property-sidebar/specifics/specifics.ts +72 -0
  130. package/src/modeller/property-sidebar/styles/styles.ts +578 -0
  131. package/src/modeller/scene-viewer/confidential-overlay.ts +18 -0
  132. package/src/modeller/scene-viewer/ox-scene-handler.ts +40 -0
  133. package/src/modeller/scene-viewer/ox-scene-layer.ts +42 -0
  134. package/src/modeller/scene-viewer/ox-scene-player.ts +104 -0
  135. package/src/modeller/scene-viewer/ox-scene-property.ts +10 -0
  136. package/src/modeller/scene-viewer/ox-scene-viewer.ts +248 -0
  137. package/src/ox-board-modeller.ts +134 -39
  138. package/src/types.ts +26 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@operato/board",
3
- "version": "0.2.45",
3
+ "version": "0.2.46",
4
4
  "description": "Webcomponent for board following open-wc recommendations",
5
5
  "author": "heartyoh",
6
6
  "license": "MIT",
@@ -16,8 +16,22 @@
16
16
  "directory": "webcomponents/board"
17
17
  },
18
18
  "exports": {
19
- "./ox-board-viewer.js": "./dist/src/ox-board-viewer.js",
20
- "./ox-board-player.js": "./dist/src/ox-board-player.js"
19
+ "./ox-board-viewer": "./dist/src/ox-board-viewer.js",
20
+ "./ox-board-player": "./dist/src/ox-board-player.js",
21
+ "./ox-board-modeller": "./dist/src/ox-board-modeller.js"
22
+ },
23
+ "typesVersions": {
24
+ "*": {
25
+ "ox-board-viewer": [
26
+ "./dist/src/ox-board-viewer.d.ts"
27
+ ],
28
+ "ox-board-player": [
29
+ "./dist/src/ox-board-player.d.ts"
30
+ ],
31
+ "ox-board-modeller": [
32
+ "./dist/src/ox-board-modeller.d.ts"
33
+ ]
34
+ }
21
35
  },
22
36
  "scripts": {
23
37
  "analyze": "cem analyze --litelement",
@@ -32,13 +46,20 @@
32
46
  "storybook:build": "tsc && npm run analyze -- --exclude dist && build-storybook"
33
47
  },
34
48
  "dependencies": {
49
+ "@operato/input": "^0.2.46",
50
+ "@operato/layout": "^0.2.46",
51
+ "@types/file-saver": "^2.0.4",
52
+ "@types/sortablejs": "^1.10.7",
53
+ "file-saver": "^2.0.5",
35
54
  "lit": "^2.0.2",
55
+ "lodash": "^4.17.21",
56
+ "sortablejs": "^1.14.0",
36
57
  "swipe-listener": "^1.3.0"
37
58
  },
38
59
  "devDependencies": {
39
60
  "@custom-elements-manifest/analyzer": "^0.4.17",
40
61
  "@hatiolab/prettier-config": "^1.0.0",
41
- "@hatiolab/things-scene": "^2.7.26",
62
+ "@hatiolab/things-scene": "^2.7.27",
42
63
  "@material/mwc-fab": "^0.25.3",
43
64
  "@material/mwc-icon": "^0.25.3",
44
65
  "@open-wc/eslint-config": "^4.3.0",
@@ -72,5 +93,5 @@
72
93
  "prettier --write"
73
94
  ]
74
95
  },
75
- "gitHead": "443daca83ed888a12671bc35f8298c400eaa8a43"
96
+ "gitHead": "70591a39c0b794a2a7765e9fcddb3e716ae95ecf"
76
97
  }
package/src/index.ts CHANGED
@@ -1,2 +1,3 @@
1
1
  export * from './ox-board-viewer'
2
2
  export * from './ox-board-player'
3
+ export * from './ox-board-modeller'
@@ -0,0 +1,142 @@
1
+ /**
2
+ * @license Copyright © HatioLab Inc. All rights reserved.
3
+ */
4
+
5
+ import { LitElement, PropertyValues, css, html } from 'lit'
6
+ import { Pallet, PalletItem } from '../../types'
7
+ import { customElement, property, query } from 'lit/decorators.js'
8
+
9
+ import { Scene } from '@hatiolab/things-scene'
10
+ import { ScrollbarStyles } from '@operato/styles'
11
+ import noImage from '../../../../assets/images/components/no-image.png'
12
+
13
+ @customElement('component-menu')
14
+ class ComponentMenu extends LitElement {
15
+ static styles = [
16
+ ScrollbarStyles,
17
+ css`
18
+ :host {
19
+ display: flex;
20
+ flex-direction: column;
21
+ align-content: stretch;
22
+
23
+ background-color: var(--component-menu-background-color);
24
+ margin: 0px;
25
+ padding: 0px;
26
+
27
+ width: 180px;
28
+ height: 100%;
29
+
30
+ overflow: hidden;
31
+
32
+ border: 2px solid var(--component-menu-border-color);
33
+ box-sizing: border-box;
34
+
35
+ position: absolute;
36
+ top: 0px;
37
+
38
+ z-index: 1;
39
+ }
40
+
41
+ h2 {
42
+ background-color: var(--component-menu-border-color);
43
+ padding: 1px 5px;
44
+ margin: 0;
45
+ font: var(--component-menu-title);
46
+ color: #fff;
47
+ text-transform: capitalize;
48
+ }
49
+
50
+ [templates] {
51
+ flex: 1;
52
+
53
+ display: block;
54
+ margin: 0;
55
+ padding: 0;
56
+ overflow-y: auto;
57
+
58
+ background-color: var(--component-menu-background-color);
59
+ }
60
+
61
+ [template] {
62
+ display: flex;
63
+ align-items: center;
64
+ min-height: var(--component-menu-item-icon-size);
65
+ padding: 0 5px 0 0;
66
+ border-bottom: 1px solid rgba(0, 0, 0, 0.1);
67
+ font-size: 11px;
68
+ color: var(--component-menu-item-color);
69
+ }
70
+
71
+ [template]:hover,
72
+ [template]:focus {
73
+ color: var(--component-menu-item-hover-color);
74
+ font-weight: bold;
75
+ cursor: pointer;
76
+ }
77
+
78
+ [template] img {
79
+ margin: 5px;
80
+ width: var(--component-menu-item-icon-size);
81
+ height: var(--component-menu-item-icon-size);
82
+ }
83
+ `
84
+ ]
85
+
86
+ @property({ type: Object }) groups: Pallet[] = []
87
+ @property({ type: Object }) scene: Scene | null = null
88
+ @property({ type: String }) group: string | null = ''
89
+ @property({ type: Array }) templates: PalletItem[] = []
90
+
91
+ render() {
92
+ return this.group
93
+ ? html`
94
+ <h2 onclick=${(e: MouseEvent) => e.stopPropagation()}>${this.group} list</h2>
95
+
96
+ <div templates>
97
+ ${(this.templates || []).map(
98
+ template => html`
99
+ <div @click=${this.onClickTemplate} data-type=${template.type} template>
100
+ <img src=${this.templateIcon(template)} />${template.type}
101
+ </div>
102
+ `
103
+ )}
104
+ </div>
105
+ `
106
+ : html``
107
+ }
108
+
109
+ updated(changes: PropertyValues<this>) {
110
+ if (changes.has('group')) {
111
+ if (!this.group) {
112
+ this.style.display = 'none'
113
+ this.templates = []
114
+ } else {
115
+ this.style.display = 'flex'
116
+ this.templates = this.groups.find((g: Pallet) => g.name === this.group)?.templates || []
117
+ }
118
+ }
119
+ }
120
+
121
+ onClickTemplate(e: MouseEvent) {
122
+ var item = e.target as HTMLElement
123
+ var type = item.closest('[data-type]')?.getAttribute('data-type')
124
+
125
+ if (!type) {
126
+ return
127
+ }
128
+
129
+ var group = this.groups.find(g => g.name == this.group)
130
+
131
+ if (this.scene && group) {
132
+ var template = group.templates.find(template => template.type == type)
133
+ template && this.scene.add(JSON.parse(JSON.stringify(template.model)), { cx: 200, cy: 200 })
134
+ }
135
+
136
+ this.group = null
137
+ }
138
+
139
+ templateIcon(template: PalletItem) {
140
+ return template.icon || noImage
141
+ }
142
+ }
@@ -0,0 +1,169 @@
1
+ /**
2
+ * @license Copyright © HatioLab Inc. All rights reserved.
3
+ */
4
+
5
+ import './component-menu'
6
+
7
+ import { LitElement, css, html } from 'lit'
8
+ import { SCENE_MODE, Scene } from '@hatiolab/things-scene'
9
+ import { customElement, property, query } from 'lit/decorators.js'
10
+
11
+ @customElement('component-toolbar')
12
+ class ComponentToolbar extends LitElement {
13
+ static styles = [
14
+ css`
15
+ :host {
16
+ left: 0;
17
+ display: block;
18
+ position: relative;
19
+
20
+ width: var(--component-toolbar-icon-size);
21
+ background-color: var(--component-toolbar-background-color);
22
+ }
23
+
24
+ span {
25
+ display: flex;
26
+ flex-direction: row;
27
+
28
+ width: var(--component-toolbar-icon-size);
29
+ height: var(--component-toolbar-icon-size);
30
+ min-width: 50%;
31
+
32
+ border-bottom: var(--component-toolbar-border);
33
+ margin: 0;
34
+ background: url(/assets/images/icon-vtoolbar.png) -1px 0 no-repeat;
35
+ }
36
+
37
+ span[data-group='line'] {
38
+ background-position: 50% -186px;
39
+ }
40
+
41
+ span[data-group='shape'] {
42
+ background-position: 0px -284px;
43
+ }
44
+
45
+ span[data-group='textAndMedia'] {
46
+ background-position: 50% -385px;
47
+ }
48
+
49
+ span[data-group='chartAndGauge'] {
50
+ background-position: 50% -488px;
51
+ }
52
+
53
+ span[data-group='table'] {
54
+ background-position: 50% -585px;
55
+ }
56
+
57
+ span[data-group='container'] {
58
+ background-position: 50% -685px;
59
+ }
60
+
61
+ span[data-group='dataSource'] {
62
+ background-position: 50% -888px;
63
+ }
64
+
65
+ span[data-group='IoT'] {
66
+ background-position: -3px -788px;
67
+ }
68
+
69
+ span[data-group='3D'] {
70
+ background-position: 50% -992px;
71
+ }
72
+
73
+ span[data-group='warehouse'] {
74
+ background-position: -2px -1089px;
75
+ }
76
+
77
+ span[data-group='form'] {
78
+ background-position: -2px -1287px;
79
+ }
80
+
81
+ span[data-group='etc'] {
82
+ background-position: -1px -1189px;
83
+ }
84
+
85
+ .pressed {
86
+ background-position: 0 15px;
87
+ }
88
+
89
+ .pressed[pressed],
90
+ .pressed[active] {
91
+ background-position: -3px -88px;
92
+ background-color: #beb9b3;
93
+ }
94
+
95
+ component-menu {
96
+ display: none;
97
+ position: absolute;
98
+ top: 0;
99
+ left: var(--component-toolbar-icon-size);
100
+ height: 100%;
101
+ outline: none;
102
+ }
103
+ `
104
+ ]
105
+
106
+ @property({ type: Array }) componentGroupList: any[] = []
107
+ @property({ type: String }) group?: string | null
108
+ @property({ type: Object }) scene!: Scene
109
+ @property({ type: Number }) mode: SCENE_MODE = SCENE_MODE.VIEW
110
+
111
+ @query('#menu') private menu!: HTMLElement
112
+
113
+ render() {
114
+ return html`
115
+ <span id="shift" class="pressed" @click=${() => this._onClickShift()}> </span>
116
+
117
+ ${this.componentGroupList
118
+ .filter(group => group.templates?.length > 0)
119
+ .map(item => html` <span data-group=${item.name} @click=${(e: MouseEvent) => this._onClickGroup(e)}> </span> `)}
120
+
121
+ <component-menu
122
+ tabindex="-1"
123
+ @focusout=${() => {
124
+ this.group = null
125
+ }}
126
+ id="menu"
127
+ .scene=${this.scene}
128
+ .group=${this.group}
129
+ .groups=${this.componentGroupList}
130
+ class="shadow"
131
+ >
132
+ </component-menu>
133
+ `
134
+ }
135
+
136
+ _setMode(mode: SCENE_MODE) {
137
+ this.mode = mode
138
+ this.dispatchEvent(
139
+ new CustomEvent('mode-changed', {
140
+ bubbles: true,
141
+ composed: true,
142
+ detail: { value: mode }
143
+ })
144
+ )
145
+ }
146
+
147
+ _onClickShift() {
148
+ var shift = this.renderRoot.querySelector('#shift')
149
+ if (shift?.hasAttribute('active')) {
150
+ shift.removeAttribute('active')
151
+ this._setMode(SCENE_MODE.EDIT)
152
+ } else {
153
+ shift!.setAttribute('active', '')
154
+ this._setMode(SCENE_MODE.SHIFT)
155
+ }
156
+ }
157
+
158
+ async _onClickGroup(e: MouseEvent) {
159
+ var button = e.target as HTMLElement
160
+
161
+ this.group = button!.closest('[data-group]')?.getAttribute('data-group')
162
+
163
+ if (!this.group) return
164
+
165
+ await this.updateComplete
166
+
167
+ this.menu?.focus()
168
+ }
169
+ }
@@ -0,0 +1,228 @@
1
+ /**
2
+ * @license Copyright © HatioLab Inc. All rights reserved.
3
+ */
4
+
5
+ import { css } from 'lit'
6
+
7
+ export const style = css`
8
+ :host {
9
+ background-color: var(--edit-toolbar-background-color, #394e64);
10
+
11
+ overflow-x: hidden;
12
+ }
13
+
14
+ [tools] {
15
+ display: flex;
16
+ align-items: center;
17
+ overflow: none;
18
+ padding: 0px 10px;
19
+ }
20
+
21
+ [tools] > * {
22
+ padding: 0px;
23
+ }
24
+
25
+ [tools] > span[button] {
26
+ min-width: 30px;
27
+ }
28
+
29
+ [tools] > span[padding] {
30
+ flex: 1;
31
+ }
32
+
33
+ [tools] > .vline {
34
+ display: block;
35
+ flex: none;
36
+ border-left: 1px solid rgba(255, 255, 255, 0.2);
37
+ border-right: 1px solid rgba(0, 0, 0, 0.15);
38
+ width: 0px;
39
+ height: 18px;
40
+ margin: 0 3px;
41
+ }
42
+
43
+ span[button] {
44
+ min-height: 35px;
45
+
46
+ background: url('/assets/images/icon-htoolbar.png') no-repeat;
47
+ background-position-x: 50%;
48
+ opacity: 0.8;
49
+ }
50
+ span[button]:hover {
51
+ opacity: 1;
52
+ background-color: rgba(0, 0, 0, 0.1);
53
+ cursor: pointer;
54
+ }
55
+
56
+ #fullscreen,
57
+ #toggle-property {
58
+ flex: none;
59
+ }
60
+
61
+ #align-left {
62
+ background-position-y: 8px;
63
+ }
64
+
65
+ #align-center {
66
+ background-position-y: -42px;
67
+ }
68
+
69
+ #align-right {
70
+ background-position-y: -92px;
71
+ }
72
+
73
+ #align-top {
74
+ background-position-y: -142px;
75
+ }
76
+
77
+ #align-middle {
78
+ background-position-y: -192px;
79
+ }
80
+
81
+ #align-bottom {
82
+ background-position-y: -242px;
83
+ }
84
+
85
+ #undo {
86
+ background-position-y: -592px;
87
+ }
88
+
89
+ #redo {
90
+ background-position-y: -642px;
91
+ }
92
+
93
+ #front {
94
+ background-position-y: -292px;
95
+ }
96
+
97
+ #back {
98
+ background-position-y: -342px;
99
+ }
100
+
101
+ #forward {
102
+ background-position-y: -392px;
103
+ }
104
+
105
+ #backward {
106
+ background-position-y: -442px;
107
+ }
108
+
109
+ #symmetry-x {
110
+ background-position-y: -492px;
111
+ }
112
+
113
+ #symmetry-y {
114
+ background-position-y: -542px;
115
+ }
116
+
117
+ #group {
118
+ background-position-y: -492px;
119
+ }
120
+
121
+ #ungroup {
122
+ background-position-y: -542px;
123
+ }
124
+
125
+ #fullscreen {
126
+ background-position-y: -692px;
127
+ }
128
+
129
+ #toggle-property {
130
+ background-position-y: -692px;
131
+ float: right;
132
+ }
133
+
134
+ #zoomin {
135
+ background-position-y: -742px;
136
+ }
137
+
138
+ #zoomout {
139
+ background-position-y: -792px;
140
+ }
141
+
142
+ #fit-scene {
143
+ background-position-y: -1492px;
144
+ }
145
+
146
+ #cut {
147
+ background-position-y: -842px;
148
+ }
149
+
150
+ #copy {
151
+ background-position-y: -892px;
152
+ }
153
+
154
+ #paste {
155
+ background-position-y: -942px;
156
+ }
157
+
158
+ #delete {
159
+ background-position-y: -992px;
160
+ }
161
+
162
+ #font-increase {
163
+ background-position-y: -1042px;
164
+ }
165
+
166
+ #font-decrease {
167
+ background-position-y: -1092px;
168
+ }
169
+
170
+ #style-copy {
171
+ background-position-y: -1142px;
172
+ }
173
+
174
+ #context-menu {
175
+ background-position-y: -692px;
176
+ }
177
+
178
+ #symmetry-x {
179
+ background-position-y: -1192px;
180
+ }
181
+
182
+ #symmetry-y {
183
+ background-position-y: -1242px;
184
+ }
185
+
186
+ #rotate-cw {
187
+ background-position-y: -1292px;
188
+ }
189
+
190
+ #rotate-ccw {
191
+ background-position-y: -1342px;
192
+ }
193
+
194
+ #distribute-horizontal {
195
+ background-position-y: -1542px;
196
+ }
197
+
198
+ #distribute-vertical {
199
+ background-position-y: -1593px;
200
+ }
201
+
202
+ #toggle-property {
203
+ background-position-y: -1392px;
204
+ }
205
+
206
+ #preview {
207
+ background-position-y: -1640px;
208
+ }
209
+
210
+ /* bigger buttons */
211
+ #fullscreen {
212
+ background: url('/assets/images/icon-fullscreen.png') 50% 10px no-repeat;
213
+ width: var(--edit-toolbar-bigger-icon-size);
214
+ height: var(--edit-toolbar-bigger-icon-size);
215
+ border-left: var(--edit-toolbar-bigger-icon-line);
216
+ }
217
+
218
+ #toggle-property {
219
+ background: url('/assets/images/icon-collapse.png') 80% 10px no-repeat;
220
+ width: var(--edit-toolbar-bigger-icon-size);
221
+ height: var(--edit-toolbar-bigger-icon-size);
222
+ border-left: var(--edit-toolbar-bigger-icon-line);
223
+ }
224
+
225
+ #toggle-property[active] {
226
+ background: url(/assets/images/icon-collapse-active.png) 80% 10px no-repeat;
227
+ }
228
+ `