@processmaker/screen-builder 2.83.11 → 2.84.0
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.
- package/dist/vue-form-builder.css +1 -1
- package/dist/vue-form-builder.es.js +4502 -4042
- package/dist/vue-form-builder.es.js.map +1 -1
- package/dist/vue-form-builder.umd.js +52 -52
- package/dist/vue-form-builder.umd.js.map +1 -1
- package/package.json +18 -2
- package/src/App.vue +33 -56
- package/src/assets/css/custom.css +11 -0
- package/src/bootstrap.js +111 -0
- package/src/components/ScreenToolbar.vue +100 -0
- package/src/components/TabsBar.vue +354 -0
- package/src/components/editor/pagesDropdown.vue +125 -0
- package/src/components/inspector/color-select.vue +18 -1
- package/src/components/sortable/Sortable.vue +80 -0
- package/src/components/sortable/sortable.scss +25 -0
- package/src/components/sortable/sortableList/SortableList.vue +140 -0
- package/src/components/sortable/sortableList/sortableList.scss +73 -0
- package/src/components/vue-form-builder.vue +339 -253
- package/src/main.js +1 -2
- package/src/mixins/canOpenJsonFile.js +1 -1
- package/src/stories/ColorSelect.stories.js +79 -0
- package/src/stories/Configure.mdx +78 -0
- package/src/stories/DropdownAndPages.stories.js +112 -0
- package/src/stories/PageTabs.stories.js +338 -0
- package/src/stories/PagesDropdown.stories.js +132 -0
- package/src/stories/ScreenToolbar.stories.js +188 -0
- package/src/stories/Sortable.stories.js +225 -0
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="row mt-3">
|
|
3
|
+
<div class="col p-0 border rounded-lg sortable-list">
|
|
4
|
+
<div class="sortable-list-header">
|
|
5
|
+
<div class="sortable-item-icon"></div>
|
|
6
|
+
<div class="sortable-list-title">PAGE NAME</div>
|
|
7
|
+
</div>
|
|
8
|
+
<div class="sortable-container" @dragover="dragOver">
|
|
9
|
+
<div
|
|
10
|
+
v-for="(item, index) in sortedItems"
|
|
11
|
+
:key="index"
|
|
12
|
+
:data-order="item.order"
|
|
13
|
+
:data-test="`item-${item.order}`"
|
|
14
|
+
:title="item.name"
|
|
15
|
+
draggable="true"
|
|
16
|
+
@dragstart="(event) => dragStart(event, item.order)"
|
|
17
|
+
@dragenter="(event) => dragEnter(event, item.order)"
|
|
18
|
+
@dragend="dragEnd"
|
|
19
|
+
class="sortable-item sortable-draggable"
|
|
20
|
+
>
|
|
21
|
+
<div class="sortable-item-icon">
|
|
22
|
+
<i class="fas fa-bars"></i>
|
|
23
|
+
</div>
|
|
24
|
+
<div class="rounded sortable-item-name">
|
|
25
|
+
<b-form-input
|
|
26
|
+
v-if="editRowIndex === index"
|
|
27
|
+
v-model="item.name"
|
|
28
|
+
type="text"
|
|
29
|
+
autofocus
|
|
30
|
+
@blur.stop="onBlur()"
|
|
31
|
+
/>
|
|
32
|
+
<span v-else>{{ item.name }}</span>
|
|
33
|
+
</div>
|
|
34
|
+
<div class="border rounded-lg sortable-item-action">
|
|
35
|
+
<button class="btn" @click.stop="onClick(item, index)">
|
|
36
|
+
<i class="fas fa-edit"></i>
|
|
37
|
+
</button>
|
|
38
|
+
<div class="sortable-item-vr"></div>
|
|
39
|
+
<button class="btn" @click="$emit('item-delete', item)">
|
|
40
|
+
<i class="fas fa-trash-alt"></i>
|
|
41
|
+
</button>
|
|
42
|
+
</div>
|
|
43
|
+
</div>
|
|
44
|
+
</div>
|
|
45
|
+
</div>
|
|
46
|
+
</div>
|
|
47
|
+
</template>
|
|
48
|
+
|
|
49
|
+
<script>
|
|
50
|
+
export default {
|
|
51
|
+
name: 'SortableList',
|
|
52
|
+
props: {
|
|
53
|
+
items: { type: Array, required: true },
|
|
54
|
+
filteredItems: { type: Array, required: true },
|
|
55
|
+
},
|
|
56
|
+
data() {
|
|
57
|
+
return {
|
|
58
|
+
draggedItem: 0,
|
|
59
|
+
draggedOverItem: 0,
|
|
60
|
+
itemsClone: [],
|
|
61
|
+
editRowIndex: null,
|
|
62
|
+
};
|
|
63
|
+
},
|
|
64
|
+
computed: {
|
|
65
|
+
sortedItems() {
|
|
66
|
+
return this.filteredItems.sort((a, b) => a.order - b.order);
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
watch: {
|
|
70
|
+
items: {
|
|
71
|
+
handler(newVal) {
|
|
72
|
+
this.itemsClone = [...newVal];
|
|
73
|
+
},
|
|
74
|
+
immediate: true,
|
|
75
|
+
},
|
|
76
|
+
},
|
|
77
|
+
methods: {
|
|
78
|
+
onBlur() {
|
|
79
|
+
this.editRowIndex = -1;
|
|
80
|
+
},
|
|
81
|
+
onClick(item, index) {
|
|
82
|
+
if (this.editRowIndex === -1 || this.editRowIndex === index) {
|
|
83
|
+
this.editRowIndex = null;
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
this.editRowIndex = index;
|
|
87
|
+
this.$emit("item-edit", item);
|
|
88
|
+
},
|
|
89
|
+
dragStart(event, order) {
|
|
90
|
+
// disable edit mode
|
|
91
|
+
this.editRowIndex = null;
|
|
92
|
+
this.draggedItem = order;
|
|
93
|
+
// add dragging class to the element
|
|
94
|
+
event.target.classList.add('dragging');
|
|
95
|
+
},
|
|
96
|
+
dragEnter(event, order) {
|
|
97
|
+
this.draggedOverItem = order;
|
|
98
|
+
},
|
|
99
|
+
dragEnd(event) {
|
|
100
|
+
// remove dragging class from the element
|
|
101
|
+
event.target.classList.remove('dragging');
|
|
102
|
+
|
|
103
|
+
// get the index of the dragged item and the dragged over item
|
|
104
|
+
const draggedItemIndex = this.itemsClone.findIndex(item => item.order === this.draggedItem);
|
|
105
|
+
const draggedOverItemIndex = this.itemsClone.findIndex(item => item.order === this.draggedOverItem);
|
|
106
|
+
|
|
107
|
+
if (draggedItemIndex !== draggedOverItemIndex) {
|
|
108
|
+
// get the order of the dragged over item
|
|
109
|
+
const tempOrder = this.itemsClone[draggedOverItemIndex].order;
|
|
110
|
+
// set the increment
|
|
111
|
+
const increment = this.draggedItem > this.draggedOverItem ? 1 : -1;
|
|
112
|
+
|
|
113
|
+
// update the order of the items between the dragged item and the dragged over item
|
|
114
|
+
if (draggedItemIndex < draggedOverItemIndex) {
|
|
115
|
+
for (let i = draggedItemIndex + 1; i <= draggedOverItemIndex; i++) {
|
|
116
|
+
const orderAux = this.itemsClone[i].order;
|
|
117
|
+
this.itemsClone[i].order = orderAux + increment;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
this.itemsClone[draggedItemIndex].order = tempOrder;
|
|
121
|
+
} else if (draggedItemIndex > draggedOverItemIndex) {
|
|
122
|
+
for (let i = draggedOverItemIndex; i <= draggedItemIndex - 1; i++) {
|
|
123
|
+
const orderAux = this.itemsClone[i].order;
|
|
124
|
+
this.itemsClone[i].order = orderAux + increment;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
this.itemsClone[draggedItemIndex].order = tempOrder;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
this.$emit('ordered', this.itemsClone);
|
|
132
|
+
},
|
|
133
|
+
dragOver(event) {
|
|
134
|
+
event.preventDefault();
|
|
135
|
+
},
|
|
136
|
+
},
|
|
137
|
+
}
|
|
138
|
+
</script>
|
|
139
|
+
|
|
140
|
+
<style lang="scss" scoped src="./sortableList.scss"></style>
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
$border-color: #cdddee;
|
|
2
|
+
|
|
3
|
+
.sortable {
|
|
4
|
+
&-list {
|
|
5
|
+
display: flex;
|
|
6
|
+
flex-direction: column;
|
|
7
|
+
border: 1px solid $border-color !important;
|
|
8
|
+
|
|
9
|
+
&-header {
|
|
10
|
+
display: flex;
|
|
11
|
+
align-items: center;
|
|
12
|
+
border-bottom: 1px solid $border-color;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
&-title {
|
|
16
|
+
padding-left: 16px;
|
|
17
|
+
font-size: 14px;
|
|
18
|
+
font-weight: bold;
|
|
19
|
+
color: #566877;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
&-container {
|
|
24
|
+
display: flex;
|
|
25
|
+
flex-direction: column;
|
|
26
|
+
width: 100%;
|
|
27
|
+
height: 340px;
|
|
28
|
+
overflow-x: auto;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
&-item {
|
|
32
|
+
display: flex;
|
|
33
|
+
align-items: center;
|
|
34
|
+
height: 56px;
|
|
35
|
+
border-bottom: 1px solid $border-color;
|
|
36
|
+
cursor: move;
|
|
37
|
+
|
|
38
|
+
&-icon {
|
|
39
|
+
display: flex;
|
|
40
|
+
justify-content: center;
|
|
41
|
+
align-items: center;
|
|
42
|
+
width: 64px;
|
|
43
|
+
height: 56px;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
& .fas {
|
|
47
|
+
color: #6A7888;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
&-name {
|
|
51
|
+
flex-grow: 1;
|
|
52
|
+
padding: 8px 16px;
|
|
53
|
+
font-size: 15px;
|
|
54
|
+
color: #556271;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
&-action {
|
|
58
|
+
display: flex;
|
|
59
|
+
margin: 0 16px;
|
|
60
|
+
border-color: $border-color !important;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
&-vr {
|
|
64
|
+
height: 22px;
|
|
65
|
+
margin: 9px 0;
|
|
66
|
+
border-right: 1px solid $border-color;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
.dragging {
|
|
72
|
+
box-shadow: 0 1px 5px 0 rgba(86, 104, 119, 0.4);
|
|
73
|
+
}
|