ketekny-ui-kit 1.0.61 → 1.0.62

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/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "ketekny-ui-kit",
3
3
  "type": "module",
4
- "version": "1.0.61",
4
+ "version": "1.0.62",
5
5
  "description": "A Vue 3 UI component library with Tailwind CSS styling",
6
6
  "main": "index.js",
7
7
  "files": [
package/src/ui/kTree.vue CHANGED
@@ -1,6 +1,6 @@
1
1
  <template>
2
2
  <div class="k-tree text-primary/90" :class="disabled ? 'k-tree--disabled' : ''">
3
- <TreeBranch
3
+ <kTreeBranch
4
4
  :nodes="treeData"
5
5
  :indent="indent"
6
6
  :disabled="disabled"
@@ -17,112 +17,16 @@
17
17
  {{ resolveNodeLabel(node) }}
18
18
  </slot>
19
19
  </template>
20
- </TreeBranch>
20
+ </kTreeBranch>
21
21
  </div>
22
22
  </template>
23
23
 
24
24
  <script>
25
- import { ChevronRight } from 'lucide-vue-next'
26
-
27
- const TreeBranch = {
28
- name: 'TreeBranch',
29
- components: { ChevronRight },
30
- props: {
31
- nodes: { type: Array, default: () => [] },
32
- indent: { type: Number, default: 20 },
33
- disabled: { type: Boolean, default: false },
34
- draggable: { type: [Boolean, Function], default: false },
35
- droppable: { type: [Boolean, Function], default: false },
36
- selectedKeys: { type: Object, default: () => ({}) },
37
- resolveNodeLabel: { type: Function, required: true },
38
- },
39
- emits: ['node-click', 'toggle', 'drag-start', 'node-drop'],
40
- methods: {
41
- hasChildren(node) {
42
- return Array.isArray(node?.children) && node.children.length > 0
43
- },
44
- canDrag(node) {
45
- return this.draggable === true || (typeof this.draggable === 'function' && this.draggable(node.__raw || node))
46
- },
47
- canDrop(node) {
48
- return this.droppable === true || (typeof this.droppable === 'function' && this.droppable(node.__raw || node))
49
- },
50
- isSelected(key) {
51
- return this.selectedKeys?.[String(key)] === true
52
- },
53
- onDragStart(event, node) {
54
- if (!this.canDrag(node)) {
55
- event.preventDefault()
56
- return
57
- }
58
- event.dataTransfer.effectAllowed = 'move'
59
- event.dataTransfer.setData('text/plain', String(node.key))
60
- this.$emit('drag-start', node)
61
- },
62
- onDrop(event, node) {
63
- if (!this.canDrop(node)) return
64
- event.preventDefault()
65
- this.$emit('node-drop', node)
66
- },
67
- },
68
- template: `
69
- <ul class="k-tree-branch">
70
- <li v-for="node in nodes" :key="node.key" class="k-tree-node">
71
- <div
72
- class="k-tree-node-content"
73
- :class="[
74
- isSelected(node.key) ? 'k-tree-node-content--selected' : '',
75
- canDrop(node) ? 'k-tree-node-content--droppable' : '',
76
- ]"
77
- :style="{ paddingLeft: node.__level ? (node.__level * indent + 7) + 'px' : undefined }"
78
- :draggable="canDrag(node)"
79
- @dragstart="onDragStart($event, node)"
80
- @dragover.prevent="canDrop(node)"
81
- @drop="onDrop($event, node)"
82
- @click="$emit('node-click', $event, node)">
83
- <button
84
- v-if="hasChildren(node)"
85
- type="button"
86
- class="k-tree-node-toggler"
87
- :aria-label="node.$folded ? 'Expand node' : 'Collapse node'"
88
- @click.stop="$emit('toggle', node)">
89
- <ChevronRight class="k-tree-node-toggler-icon" :class="node.$folded ? '' : 'k-tree-node-toggler-icon--open'" />
90
- </button>
91
-
92
- <span v-else class="k-tree-node-toggler k-tree-node-toggler--empty"></span>
93
-
94
- <div class="k-tree-node-label">
95
- <slot :node="node.__raw || node" :path="node.__path">
96
- {{ resolveNodeLabel(node.__raw || node) }}
97
- </slot>
98
- </div>
99
- </div>
100
-
101
- <TreeBranch
102
- v-if="hasChildren(node) && !node.$folded"
103
- :nodes="node.children"
104
- :indent="indent"
105
- :disabled="disabled"
106
- :draggable="draggable"
107
- :droppable="droppable"
108
- :selected-keys="selectedKeys"
109
- :resolve-node-label="resolveNodeLabel"
110
- @node-click="(...args) => $emit('node-click', ...args)"
111
- @toggle="(...args) => $emit('toggle', ...args)"
112
- @drag-start="(...args) => $emit('drag-start', ...args)"
113
- @node-drop="(...args) => $emit('node-drop', ...args)">
114
- <template #default="slotProps">
115
- <slot v-bind="slotProps" />
116
- </template>
117
- </TreeBranch>
118
- </li>
119
- </ul>
120
- `,
121
- }
25
+ import kTreeBranch from './kTreeBranch.vue'
122
26
 
123
27
  export default {
124
28
  name: 'kTree',
125
- components: { TreeBranch },
29
+ components: { kTreeBranch },
126
30
  props: {
127
31
  value: { type: Array, default: () => [] },
128
32
  selectionKeys: { type: [Object, null], default: null },
@@ -0,0 +1,100 @@
1
+ <template>
2
+ <ul class="k-tree-branch">
3
+ <li v-for="node in nodes" :key="node.key" class="k-tree-node">
4
+ <div
5
+ class="k-tree-node-content"
6
+ :class="[
7
+ isSelected(node.key) ? 'k-tree-node-content--selected' : '',
8
+ canDrop(node) ? 'k-tree-node-content--droppable' : '',
9
+ ]"
10
+ :style="{ paddingLeft: node.__level ? (node.__level * indent + 7) + 'px' : undefined }"
11
+ :draggable="canDrag(node)"
12
+ @dragstart="onDragStart($event, node)"
13
+ @dragover.prevent="canDrop(node)"
14
+ @drop="onDrop($event, node)"
15
+ @click="$emit('node-click', $event, node)">
16
+ <button
17
+ v-if="hasChildren(node)"
18
+ type="button"
19
+ class="k-tree-node-toggler"
20
+ :aria-label="node.$folded ? 'Expand node' : 'Collapse node'"
21
+ @click.stop="$emit('toggle', node)">
22
+ <ChevronRight class="k-tree-node-toggler-icon" :class="node.$folded ? '' : 'k-tree-node-toggler-icon--open'" />
23
+ </button>
24
+
25
+ <span v-else class="k-tree-node-toggler k-tree-node-toggler--empty"></span>
26
+
27
+ <div class="k-tree-node-label">
28
+ <slot :node="node.__raw || node" :path="node.__path">
29
+ {{ resolveNodeLabel(node.__raw || node) }}
30
+ </slot>
31
+ </div>
32
+ </div>
33
+
34
+ <kTreeBranch
35
+ v-if="hasChildren(node) && !node.$folded"
36
+ :nodes="node.children"
37
+ :indent="indent"
38
+ :disabled="disabled"
39
+ :draggable="draggable"
40
+ :droppable="droppable"
41
+ :selected-keys="selectedKeys"
42
+ :resolve-node-label="resolveNodeLabel"
43
+ @node-click="(...args) => $emit('node-click', ...args)"
44
+ @toggle="(...args) => $emit('toggle', ...args)"
45
+ @drag-start="(...args) => $emit('drag-start', ...args)"
46
+ @node-drop="(...args) => $emit('node-drop', ...args)">
47
+ <template #default="slotProps">
48
+ <slot v-bind="slotProps" />
49
+ </template>
50
+ </kTreeBranch>
51
+ </li>
52
+ </ul>
53
+ </template>
54
+
55
+ <script>
56
+ import { ChevronRight } from 'lucide-vue-next'
57
+
58
+ export default {
59
+ name: 'kTreeBranch',
60
+ components: { ChevronRight },
61
+ props: {
62
+ nodes: { type: Array, default: () => [] },
63
+ indent: { type: Number, default: 20 },
64
+ disabled: { type: Boolean, default: false },
65
+ draggable: { type: [Boolean, Function], default: false },
66
+ droppable: { type: [Boolean, Function], default: false },
67
+ selectedKeys: { type: Object, default: () => ({}) },
68
+ resolveNodeLabel: { type: Function, required: true },
69
+ },
70
+ emits: ['node-click', 'toggle', 'drag-start', 'node-drop'],
71
+ methods: {
72
+ hasChildren(node) {
73
+ return Array.isArray(node?.children) && node.children.length > 0
74
+ },
75
+ canDrag(node) {
76
+ return this.draggable === true || (typeof this.draggable === 'function' && this.draggable(node.__raw || node))
77
+ },
78
+ canDrop(node) {
79
+ return this.droppable === true || (typeof this.droppable === 'function' && this.droppable(node.__raw || node))
80
+ },
81
+ isSelected(key) {
82
+ return this.selectedKeys?.[String(key)] === true
83
+ },
84
+ onDragStart(event, node) {
85
+ if (!this.canDrag(node)) {
86
+ event.preventDefault()
87
+ return
88
+ }
89
+ event.dataTransfer.effectAllowed = 'move'
90
+ event.dataTransfer.setData('text/plain', String(node.key))
91
+ this.$emit('drag-start', node)
92
+ },
93
+ onDrop(event, node) {
94
+ if (!this.canDrop(node)) return
95
+ event.preventDefault()
96
+ this.$emit('node-drop', node)
97
+ },
98
+ },
99
+ }
100
+ </script>