@humandialog/forms.svelte 1.7.28 → 1.8.1

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 (258) hide show
  1. package/components/Fab.25.svelte +473 -0
  2. package/components/Fab.25.svelte.d.ts +18 -0
  3. package/components/Fab.svelte +51 -170
  4. package/components/Floating_container.25.svelte +178 -0
  5. package/components/Floating_container.25.svelte.d.ts +23 -0
  6. package/components/Floating_container.svelte +18 -6
  7. package/components/Grid.menu.svelte +15 -16
  8. package/components/Grid.menu.svelte.d.ts +2 -2
  9. package/components/breadcrumb.svelte +27 -27
  10. package/components/checkbox.svelte +1 -1
  11. package/components/combo/combo.svelte +60 -79
  12. package/components/combo/combo.svelte.d.ts +1 -0
  13. package/components/contextmenu-25.svelte +518 -0
  14. package/components/contextmenu-25.svelte.d.ts +26 -0
  15. package/components/contextmenu.svelte +179 -65
  16. package/components/contextmenu.svelte.d.ts +2 -2
  17. package/components/date.svelte +42 -21
  18. package/components/date.svelte.d.ts +1 -0
  19. package/components/delayed.spinner.svelte +2 -1
  20. package/components/document/editor.svelte +21 -31
  21. package/components/document/editor.svelte.d.ts +0 -2
  22. package/components/document/internal/palette.row.svelte +10 -8
  23. package/components/document/internal/palette.svelte +7 -8
  24. package/components/document/rich.edit.svelte +10 -10
  25. package/components/edit.field.svelte +1 -1
  26. package/components/input.text.svelte.d.ts +2 -2
  27. package/components/inputbox.ltop.svelte +1 -1
  28. package/components/inputbox.ltop.svelte.d.ts +12 -12
  29. package/components/kanban/internal/kanban.card.svelte +27 -47
  30. package/components/kanban/internal/kanban.column.svelte +44 -24
  31. package/components/kanban/internal/kanban.inserter.svelte +11 -14
  32. package/components/kanban/internal/kanban.move.menu.svelte +12 -12
  33. package/components/kanban/internal/kanban.props.svelte +24 -9
  34. package/components/kanban/kanban.svelte +24 -77
  35. package/components/kanban/kanban.svelte.d.ts +2 -0
  36. package/components/kanban copy.zip +0 -0
  37. package/components/list/List.d.ts +1 -0
  38. package/components/list/List.js +1 -0
  39. package/components/list/internal/list.element copy.svelte +530 -0
  40. package/components/list/internal/list.element copy.svelte.d.ts +35 -0
  41. package/components/list/internal/list.element.svelte +311 -279
  42. package/components/list/internal/list.element.svelte.d.ts +5 -7
  43. package/components/list/internal/list.inserter.svelte +38 -6
  44. package/components/list/internal/note.txt +5 -0
  45. package/components/list/list.svelte +32 -11
  46. package/components/list/list.svelte.d.ts +5 -3
  47. package/components/list/list.title.svelte +2 -0
  48. package/components/list/list.title.svelte.d.ts +1 -0
  49. package/components/menu.d.ts +1 -1
  50. package/components/menu.js +3 -3
  51. package/components/paginator.svelte +79 -9
  52. package/components/prose.editable.p.svelte.d.ts +2 -2
  53. package/components/prose.editable.span.svelte.d.ts +2 -2
  54. package/components/r.edit.svelte +9 -0
  55. package/components/r.edit.svelte.d.ts +23 -0
  56. package/components/r.editable.svelte +75 -0
  57. package/components/r.editable.svelte.d.ts +31 -0
  58. package/components/r.figcaption.svelte +5 -0
  59. package/components/r.figcaption.svelte.d.ts +27 -0
  60. package/components/r.figure.svelte +25 -0
  61. package/components/r.figure.svelte.d.ts +29 -0
  62. package/components/r.icon.svelte +229 -0
  63. package/components/r.icon.svelte.d.ts +33 -0
  64. package/components/radio.svelte +1 -1
  65. package/components/ricons/arrow-up.svelte +11 -0
  66. package/components/ricons/arrow-up.svelte.d.ts +27 -0
  67. package/components/ricons/barcode.svelte +14 -0
  68. package/components/ricons/barcode.svelte.d.ts +27 -0
  69. package/components/ricons/bold.svelte +10 -0
  70. package/components/ricons/bold.svelte.d.ts +27 -0
  71. package/components/ricons/calendar.svelte +13 -0
  72. package/components/ricons/calendar.svelte.d.ts +27 -0
  73. package/components/ricons/calendars.svelte +16 -0
  74. package/components/ricons/calendars.svelte.d.ts +27 -0
  75. package/components/ricons/cat.svelte +14 -0
  76. package/components/ricons/cat.svelte.d.ts +27 -0
  77. package/components/ricons/check-check.svelte +12 -0
  78. package/components/ricons/check-check.svelte.d.ts +27 -0
  79. package/components/ricons/check.svelte +18 -0
  80. package/components/ricons/check.svelte.d.ts +27 -0
  81. package/components/ricons/chess-rook.svelte +17 -0
  82. package/components/ricons/chess-rook.svelte.d.ts +27 -0
  83. package/components/ricons/chevron-down.svelte +11 -0
  84. package/components/ricons/chevron-down.svelte.d.ts +27 -0
  85. package/components/ricons/chevron-left.svelte +11 -0
  86. package/components/ricons/chevron-left.svelte.d.ts +27 -0
  87. package/components/ricons/chevron-right.svelte +11 -0
  88. package/components/ricons/chevron-right.svelte.d.ts +27 -0
  89. package/components/ricons/chevron-up.svelte +11 -0
  90. package/components/ricons/chevron-up.svelte.d.ts +27 -0
  91. package/components/ricons/chevrons-down.svelte +12 -0
  92. package/components/ricons/chevrons-down.svelte.d.ts +27 -0
  93. package/components/ricons/chevrons-left-right.svelte +12 -0
  94. package/components/ricons/chevrons-left-right.svelte.d.ts +27 -0
  95. package/components/ricons/chevrons-left.svelte +12 -0
  96. package/components/ricons/chevrons-left.svelte.d.ts +27 -0
  97. package/components/ricons/chevrons-right.svelte +12 -0
  98. package/components/ricons/chevrons-right.svelte.d.ts +27 -0
  99. package/components/ricons/chevrons-up-down.svelte +12 -0
  100. package/components/ricons/chevrons-up-down.svelte.d.ts +27 -0
  101. package/components/ricons/chevrons-up.svelte +12 -0
  102. package/components/ricons/chevrons-up.svelte.d.ts +27 -0
  103. package/components/ricons/circle-check.svelte +28 -0
  104. package/components/ricons/circle-check.svelte.d.ts +23 -0
  105. package/components/ricons/circle-dashed.svelte +19 -0
  106. package/components/ricons/circle-dashed.svelte.d.ts +27 -0
  107. package/components/ricons/circle-dot-dashed.svelte +20 -0
  108. package/components/ricons/circle-dot-dashed.svelte.d.ts +27 -0
  109. package/components/ricons/circle.svelte +30 -0
  110. package/components/ricons/circle.svelte.d.ts +23 -0
  111. package/components/ricons/clipboard-list.svelte +17 -0
  112. package/components/ricons/clipboard-list.svelte.d.ts +27 -0
  113. package/components/ricons/clipboard-minus.svelte +9 -0
  114. package/components/ricons/clipboard-minus.svelte.d.ts +23 -0
  115. package/components/ricons/clipboard-pen-line.svelte +18 -0
  116. package/components/ricons/clipboard-pen-line.svelte.d.ts +27 -0
  117. package/components/ricons/code-xml.svelte +12 -0
  118. package/components/ricons/code-xml.svelte.d.ts +27 -0
  119. package/components/ricons/download.svelte +13 -0
  120. package/components/ricons/download.svelte.d.ts +27 -0
  121. package/components/ricons/ellipsis-vertical.svelte +14 -0
  122. package/components/ricons/ellipsis-vertical.svelte.d.ts +27 -0
  123. package/components/ricons/file-archive.svelte +18 -0
  124. package/components/ricons/file-archive.svelte.d.ts +27 -0
  125. package/components/ricons/file-text.svelte +17 -0
  126. package/components/ricons/file-text.svelte.d.ts +27 -0
  127. package/components/ricons/folder.svelte +12 -0
  128. package/components/ricons/folder.svelte.d.ts +27 -0
  129. package/components/ricons/heading-1.svelte +13 -0
  130. package/components/ricons/heading-1.svelte.d.ts +27 -0
  131. package/components/ricons/heading-2.svelte +13 -0
  132. package/components/ricons/heading-2.svelte.d.ts +27 -0
  133. package/components/ricons/heading-3.svelte +14 -0
  134. package/components/ricons/heading-3.svelte.d.ts +27 -0
  135. package/components/ricons/heading-4.svelte +14 -0
  136. package/components/ricons/heading-4.svelte.d.ts +27 -0
  137. package/components/ricons/heading-5.svelte +14 -0
  138. package/components/ricons/heading-5.svelte.d.ts +27 -0
  139. package/components/ricons/image.svelte +12 -0
  140. package/components/ricons/image.svelte.d.ts +27 -0
  141. package/components/ricons/italic.svelte +12 -0
  142. package/components/ricons/italic.svelte.d.ts +27 -0
  143. package/components/ricons/languages.svelte +15 -0
  144. package/components/ricons/languages.svelte.d.ts +27 -0
  145. package/components/ricons/list-checks.svelte +15 -0
  146. package/components/ricons/list-checks.svelte.d.ts +27 -0
  147. package/components/ricons/list-minus.svelte +14 -0
  148. package/components/ricons/list-minus.svelte.d.ts +27 -0
  149. package/components/ricons/list-ordered.svelte +16 -0
  150. package/components/ricons/list-ordered.svelte.d.ts +27 -0
  151. package/components/ricons/list-plus.svelte +14 -0
  152. package/components/ricons/list-plus.svelte.d.ts +27 -0
  153. package/components/ricons/list.svelte +15 -0
  154. package/components/ricons/list.svelte.d.ts +27 -0
  155. package/components/ricons/loader-circle.svelte +19 -0
  156. package/components/ricons/loader-circle.svelte.d.ts +27 -0
  157. package/components/ricons/log-in.svelte +12 -0
  158. package/components/ricons/log-in.svelte.d.ts +27 -0
  159. package/components/ricons/log-out.svelte +12 -0
  160. package/components/ricons/log-out.svelte.d.ts +27 -0
  161. package/components/ricons/message-square.svelte +12 -0
  162. package/components/ricons/message-square.svelte.d.ts +27 -0
  163. package/components/ricons/messages-square.svelte +15 -0
  164. package/components/ricons/messages-square.svelte.d.ts +27 -0
  165. package/components/ricons/minus.svelte +10 -0
  166. package/components/ricons/minus.svelte.d.ts +27 -0
  167. package/components/ricons/notebook-tabs.svelte +19 -0
  168. package/components/ricons/notebook-tabs.svelte.d.ts +27 -0
  169. package/components/ricons/notebook.svelte +16 -0
  170. package/components/ricons/notebook.svelte.d.ts +27 -0
  171. package/components/ricons/package.svelte +22 -0
  172. package/components/ricons/package.svelte.d.ts +27 -0
  173. package/components/ricons/paperclip.svelte +12 -0
  174. package/components/ricons/paperclip.svelte.d.ts +27 -0
  175. package/components/ricons/pencil.svelte +12 -0
  176. package/components/ricons/pencil.svelte.d.ts +27 -0
  177. package/components/ricons/pilcrow.svelte +12 -0
  178. package/components/ricons/pilcrow.svelte.d.ts +27 -0
  179. package/components/ricons/save.svelte +12 -0
  180. package/components/ricons/save.svelte.d.ts +27 -0
  181. package/components/ricons/square-check-big.svelte +13 -0
  182. package/components/ricons/square-check-big.svelte.d.ts +27 -0
  183. package/components/ricons/square-pen.svelte +14 -0
  184. package/components/ricons/square-pen.svelte.d.ts +27 -0
  185. package/components/ricons/square.svelte +10 -0
  186. package/components/ricons/square.svelte.d.ts +27 -0
  187. package/components/ricons/strikethrough.svelte +13 -0
  188. package/components/ricons/strikethrough.svelte.d.ts +27 -0
  189. package/components/ricons/sun-moon.svelte +15 -0
  190. package/components/ricons/sun-moon.svelte.d.ts +27 -0
  191. package/components/ricons/table.svelte +13 -0
  192. package/components/ricons/table.svelte.d.ts +27 -0
  193. package/components/ricons/tag.svelte +12 -0
  194. package/components/ricons/tag.svelte.d.ts +27 -0
  195. package/components/ricons/text-quote.svelte +14 -0
  196. package/components/ricons/text-quote.svelte.d.ts +27 -0
  197. package/components/ricons/turtle.svelte +13 -0
  198. package/components/ricons/turtle.svelte.d.ts +27 -0
  199. package/components/ricons/underline.svelte +11 -0
  200. package/components/ricons/underline.svelte.d.ts +27 -0
  201. package/components/ricons/upload.svelte +13 -0
  202. package/components/ricons/upload.svelte.d.ts +27 -0
  203. package/components/ricons/user.svelte +12 -0
  204. package/components/ricons/user.svelte.d.ts +27 -0
  205. package/components/ricons/users.svelte +14 -0
  206. package/components/ricons/users.svelte.d.ts +27 -0
  207. package/components/ricons/x.svelte +11 -0
  208. package/components/ricons/x.svelte.d.ts +27 -0
  209. package/components/sidebar/sidebar.brand.svelte +14 -13
  210. package/components/sidebar/sidebar.brand.svelte.d.ts +2 -2
  211. package/components/sidebar/sidebar.group.svelte +52 -30
  212. package/components/sidebar/sidebar.item.svelte +35 -141
  213. package/components/sidebar/sidebar.item.svelte.d.ts +2 -5
  214. package/components/sidebar/sidebar.list.svelte +8 -8
  215. package/components/sidebar/sidebar.svelte +19 -2
  216. package/components/simple.table.svelte.d.ts +4 -4
  217. package/components/table/_template.table.svelte.d.ts +4 -4
  218. package/components/tags.svelte +10 -3
  219. package/components/tags.svelte.d.ts +1 -0
  220. package/components/textarea.ltop.svelte.d.ts +2 -2
  221. package/components/tile.title.svelte.d.ts +2 -2
  222. package/desk.svelte +139 -144
  223. package/dialog.svelte +17 -7
  224. package/form.box.svelte.d.ts +4 -4
  225. package/horizontal.nav.tabs.svelte +197 -23
  226. package/horizontal.nav.tabs.svelte.d.ts +2 -2
  227. package/horizontal.toolbar.svelte +25 -18
  228. package/horizontal.toolbar.svelte.d.ts +2 -2
  229. package/index.d.ts +10 -3
  230. package/index.js +10 -3
  231. package/operations.svelte +51 -22
  232. package/package.json +89 -1
  233. package/page.row.svelte.d.ts +2 -2
  234. package/page.svelte +17 -7
  235. package/page.svelte.d.ts +10 -10
  236. package/paper.header.svelte +4 -0
  237. package/paper.header.svelte.d.ts +27 -0
  238. package/paper.nav.svelte +8 -0
  239. package/paper.nav.svelte.d.ts +27 -0
  240. package/paper.svelte +22 -6
  241. package/paper.svelte.d.ts +2 -0
  242. package/paper.table.svelte +27 -0
  243. package/paper.table.svelte.d.ts +27 -0
  244. package/paper.top.margin.svelte +5 -0
  245. package/paper.top.margin.svelte.d.ts +27 -0
  246. package/stores.d.ts +1 -1
  247. package/tenant.create.svelte +93 -0
  248. package/tenant.create.svelte.d.ts +29 -0
  249. package/tenant.members.svelte +116 -93
  250. package/tile.svelte.d.ts +4 -4
  251. package/tiles.row.svelte.d.ts +2 -2
  252. package/tiles.vertical.row.svelte.d.ts +2 -2
  253. package/updates.d.ts +4 -0
  254. package/updates.js +56 -14
  255. package/utils.d.ts +16 -4
  256. package/utils.js +214 -99
  257. package/vertical.toolbar.svelte +62 -47
  258. package/vertical.toolbar.svelte.d.ts +2 -2
@@ -5,6 +5,7 @@ import Card from "./kanban.card.svelte";
5
5
  import { KanbanColumnTop, KanbanColumnBottom } from "../Kanban";
6
6
  import Inserter from "./kanban.inserter.svelte";
7
7
  import { FaPlus, FaCheck } from "svelte-icons/fa";
8
+ import Icon from "../../r.icon.svelte";
8
9
  export let currentColumnIdx;
9
10
  export let onInsert;
10
11
  let column_element;
@@ -227,22 +228,38 @@ async function dblclick(e) {
227
228
 
228
229
  {#if (columnDef.state >=0) || ((column_items && column_items.length > 0))}
229
230
 
230
- <section class=" snap-center
231
- sm:snap-align-none
232
- flex-none sm:flex-1
233
- sm:min-h-[calc(100vh-8rem)]
234
- min-h-[calc(100vh-5rem)]
235
- rounded-md border border-transparent
236
- {selected_class} {focused_class}"
237
-
238
- bind:this={columnContainerElement}
239
- style={styleWidth}
231
+ <div class=" snap-center
232
+ sm:snap-start
233
+
234
+ w-full
235
+ sm:px-4
236
+ sm:w-1/2
237
+ md:w-1/3
238
+ xl:w-1/4
239
+ sm:min-w-[300px]
240
+
241
+ flex-none
242
+ sm:flex-1
243
+
244
+ {selected_class} {focused_class}"
245
+
246
+ bind:this={columnContainerElement}
247
+
240
248
  use:selectable={columnDef}
241
249
  on:click={activate}
242
250
  on:dblclick={dblclick}>
243
- <header class:cursor-pointer={!is_row_active && columnDef.operations} bind:this={headerElement}>
244
- <h2 class="mt-2 mb-2 text-base sm:text-base uppercase w-full min-h-[1rem] text-center whitespace-nowrap relative">
245
- <span
251
+ <figure bind:this={headerElement}>
252
+ <figcaption class = "text-right">
253
+ <div class="w-full flex flex-row justify-between">
254
+ <span></span>
255
+ <span></span>
256
+ <div class="flex flex-row text-orange-800 dark:text-orange-200"><span><Icon icon="barcode" s/></span><span>4.32</span></div>
257
+
258
+ </div>
259
+ </figcaption>
260
+
261
+ <h3 class=" text-center whitespace-nowrap relative">
262
+ <span
246
263
  use:editable={{
247
264
  action: (text) => onTitleChanged(text),
248
265
  active: false
@@ -250,19 +267,22 @@ async function dblclick(e) {
250
267
  bind:this={titleElement}>
251
268
  {columnDef.title}
252
269
  </span>
253
-
270
+
254
271
  {#if columnDef.finishing}
255
- <div class="inline-block text-green-600 h-3 w-3 ml-2">
256
- <FaCheck/>
272
+ <div class="inline-block text-green-600">
273
+ <Icon icon="check" s/>
257
274
  </div>
258
275
  {/if}
276
+
277
+
278
+
259
279
  <!--button class="absolute right-2 w-4 sm:w-2.5"
260
280
  on:click|stopPropagation={(e) => add(KanbanColumnTop)}>
261
281
  <FaPlus/>
262
282
  </button-->
263
- </h2>
264
- </header>
265
- <ul class="w-full border-stone-400 dark:border-stone-700 pb-20" bind:this={column_element}>
283
+ </h3>
284
+ </figure>
285
+ <div class="w-full pb-0" bind:this={column_element}>
266
286
  {#if showInserterAfterId === KanbanColumnTop}
267
287
  <Inserter onInsert={async (title, summary) => {await onInsert(currentColumnIdx, title, summary, KanbanColumnTop)}}
268
288
  bind:this={inserter} />
@@ -270,16 +290,16 @@ async function dblclick(e) {
270
290
 
271
291
  {#if column_items && column_items.length > 0}
272
292
  {#each column_items as element, item_idx (getItemKey(element))}
273
- <Card item={element}
293
+ <Card item={element}
274
294
  bind:this={cards[item_idx]}>
275
295
  <svelte:fragment slot="kanbanCardTopProps" let:element>
276
296
  <slot name="kanbanCardTopProps" {element}/>
277
297
  </svelte:fragment>
278
-
298
+
279
299
  <svelte:fragment slot="kanbanCardMiddleProps" let:element>
280
300
  <slot name="kanbanCardMiddleProps" {element}/>
281
301
  </svelte:fragment>
282
-
302
+
283
303
  <svelte:fragment slot="kanbanCardBottomProps" let:element>
284
304
  <slot name="kanbanCardBottomProps" {element}/>
285
305
  </svelte:fragment>
@@ -297,6 +317,6 @@ async function dblclick(e) {
297
317
  bind:this={inserter} />
298
318
  {/if}
299
319
 
300
- </ul>
301
- </section>
320
+ </div>
321
+ </div>
302
322
  {/if}
@@ -28,35 +28,32 @@ async function onSummaryChanged(text) {
28
28
 
29
29
  <!-- svelte-ignore a11y-click-events-have-key-events -->
30
30
 
31
- <li class=" mx-2 pt-2 pb-4 px-1 rounded-md border border-transparent
32
- bg-stone-100 dark:bg-stone-700">
31
+ <figure class=" bg-stone-200 dark:bg-stone-700 outline outline-8 outline-stone-200 dark:outline-stone-700 ring-1 ring-offset-8 ring-stone-300 dark:ring-stone-700">
33
32
 
34
33
  <!-- whitespace-nowrap overflow-clip -->
35
- <h3 class=" text-base font-semibold min-h-[1.75rem]
34
+ <h4 class=" font-semibold min-h-[1.75rem]
36
35
  sm:min-h-[1.25rem]
37
- w-full sm:flex-none "
36
+ "
38
37
  use:editable={{
39
38
  action: (text) => onInsert(text, ''),
40
39
  active: false,
41
40
  onSoftEnter: softEnter
42
41
  }}
43
42
  bind:this={titleElement}>
44
- </h3>
43
+ </h4>
45
44
 
46
45
  {#if editSummary}
47
- <p class=" text-sm min-h-[1.25rem]
48
- text-stone-400
49
- max-h-[75px]
50
- overflow-hidden"
46
+ <figcaption class="
47
+ max-h-[75px]"
51
48
  use:editable={{
52
- action: (text) => onSummaryChanged(text),
49
+ action: (text) => onSummaryChanged(text),
53
50
  active: false,
54
51
  onFinish: (d) => {editSummary = false}}}
55
52
  bind:this={summaryElement}>
56
53
  {summary}
57
- </p>
54
+ </figcaption>
58
55
  {/if}
59
-
60
-
61
56
 
62
- </li>
57
+
58
+
59
+ </figure>
@@ -21,7 +21,7 @@ function replaceMenu() {
21
21
  <p class="text-xs h-4 w-[100px] truncate"></p>
22
22
  <button class=" h-8 w-full
23
23
  text-xs font-medium text-stone-900 dark:text-stone-400 dark:hover:text-white
24
- bg-stone-100 hover:bg-stone-200 dark:bg-stone-800 dark:hover:bg-stone-700 active:bg-stone-300 dark:active:bg-stone-600
24
+ bg-stone-100 hover:bg-stone-200 dark:bg-stone-800 dark:hover:bg-stone-700 active:bg-stone-200 dark:active:bg-stone-600
25
25
  border rounded border-stone-200 dark:border-stone-600 focus:outline-none
26
26
  inline-flex items-center justify-center"
27
27
  on:click={(e) => { onMoveUp(item); replaceMenu()}}>
@@ -30,7 +30,7 @@ function replaceMenu() {
30
30
 
31
31
  <button class=" h-8 w-full
32
32
  text-xs font-medium text-stone-900 dark:text-stone-400 dark:hover:text-white
33
- bg-stone-100 hover:bg-stone-200 dark:bg-stone-800 dark:hover:bg-stone-700 active:bg-stone-300 dark:active:bg-stone-600
33
+ bg-stone-100 hover:bg-stone-200 dark:bg-stone-800 dark:hover:bg-stone-700 active:bg-stone-200 dark:active:bg-stone-600
34
34
  border rounded border-stone-200 dark:border-stone-600 focus:outline-none
35
35
  inline-flex items-center justify-center"
36
36
  on:click={(e) => { onMoveDown(item); replaceMenu()}}>
@@ -44,7 +44,7 @@ function replaceMenu() {
44
44
  <p class="text-xs h-4 w-[100px] ml-1 truncate">{column.title}</p>
45
45
  <button class=" h-8 w-full
46
46
  text-base font-medium text-stone-900 dark:text-stone-400 dark:hover:text-white
47
- bg-stone-100 hover:bg-stone-200 dark:bg-stone-800 dark:hover:bg-stone-700 active:bg-stone-300 dark:active:bg-stone-600
47
+ bg-stone-100 hover:bg-stone-200 dark:bg-stone-800 dark:hover:bg-stone-700 active:bg-stone-200 dark:active:bg-stone-600
48
48
  border rounded border-stone-200 dark:border-stone-600 focus:outline-none
49
49
  inline-flex items-center justify-center"
50
50
  on:click={(e) => { onReplace(item, idx, KanbanColumnTop); replaceMenu()}}>
@@ -53,7 +53,7 @@ function replaceMenu() {
53
53
 
54
54
  <button class=" h-8 w-full
55
55
  text-base font-medium text-stone-900 dark:text-stone-400 dark:hover:text-white
56
- bg-stone-100 hover:bg-stone-200 dark:bg-stone-800 dark:hover:bg-stone-700 active:bg-stone-300 dark:active:bg-stone-600
56
+ bg-stone-100 hover:bg-stone-200 dark:bg-stone-800 dark:hover:bg-stone-700 active:bg-stone-200 dark:active:bg-stone-600
57
57
  border rounded border-stone-200 dark:border-stone-600 focus:outline-none
58
58
  inline-flex items-center justify-center"
59
59
  on:click={(e) => { onReplace(item, idx, KanbanColumnBottom); replaceMenu()}}>
@@ -69,13 +69,13 @@ function replaceMenu() {
69
69
  <p class="text-base truncate "></p>
70
70
  <div class="flex flex-row ml-auto gap-3">
71
71
  <button class=" bg-transparent
72
- w-[55px] h-[55px]
72
+ w-[55px] h-[55px]
73
73
  m-0
74
74
  flex items-center justify-center
75
75
  disable-dbl-tap-zoom"
76
76
  on:click={(e) => { onMoveUp(item); replaceMenu()}}>
77
77
  <div class=" w-10 h-10
78
- text-white bg-zinc-500 hover:bg-zinc-500
78
+ text-white bg-zinc-500 hover:bg-zinc-500
79
79
  font-medium rounded-full text-sm text-center shadow-md
80
80
  dark:bg-zinc-500 dark:hover:bg-zinc-500
81
81
  flex items-center justify-center">
@@ -86,13 +86,13 @@ function replaceMenu() {
86
86
  </button>
87
87
 
88
88
  <button class=" bg-transparent
89
- w-[55px] h-[55px]
89
+ w-[55px] h-[55px]
90
90
  m-0
91
91
  flex items-center justify-center
92
92
  disable-dbl-tap-zoom"
93
93
  on:click={(e) => { onMoveDown(item); replaceMenu()}}>
94
94
  <div class=" w-10 h-10
95
- text-white bg-zinc-500 hover:bg-zinc-500
95
+ text-white bg-zinc-500 hover:bg-zinc-500
96
96
  font-medium rounded-full text-sm text-center shadow-md
97
97
  dark:bg-zinc-500 dark:hover:bg-zinc-500
98
98
  flex items-center justify-center">
@@ -110,13 +110,13 @@ function replaceMenu() {
110
110
  <p class="text-base mt-4 truncate w-[120px]">{column.title}</p>
111
111
  <div class="flex flex-row ml-auto gap-3">
112
112
  <button class=" bg-transparent
113
- w-[55px] h-[55px]
113
+ w-[55px] h-[55px]
114
114
  m-0
115
115
  flex items-center justify-center
116
116
  disable-dbl-tap-zoom"
117
117
  on:click={(e) => { onReplace(item, idx, KanbanColumnTop); replaceMenu()}}>
118
118
  <div class=" w-10 h-10
119
- text-white bg-zinc-500 hover:bg-zinc-500
119
+ text-white bg-zinc-500 hover:bg-zinc-500
120
120
  font-medium rounded-full text-sm text-center shadow-md
121
121
  dark:bg-zinc-500 dark:hover:bg-zinc-500
122
122
  flex items-center justify-center">
@@ -127,13 +127,13 @@ function replaceMenu() {
127
127
  </button>
128
128
 
129
129
  <button class=" bg-transparent
130
- w-[55px] h-[55px]
130
+ w-[55px] h-[55px]
131
131
  m-0
132
132
  flex items-center justify-center
133
133
  disable-dbl-tap-zoom"
134
134
  on:click={(e) => { onReplace(item, idx, KanbanColumnBottom); replaceMenu()}}>
135
135
  <div class=" w-10 h-10
136
- text-white bg-zinc-500 hover:bg-zinc-500
136
+ text-white bg-zinc-500 hover:bg-zinc-500
137
137
  font-medium rounded-full text-sm text-center shadow-md
138
138
  dark:bg-zinc-500 dark:hover:bg-zinc-500
139
139
  flex items-center justify-center">
@@ -9,6 +9,7 @@ let definition = getContext("rKanban-definition");
9
9
  let properties = definition.properties.filter((p) => p.position == position);
10
10
  let propElements = [];
11
11
  let placeholder = "";
12
+ let properties_no = count_properties();
12
13
  export function editProperty(field) {
13
14
  let propIdx = properties.findIndex((p) => p.name == field);
14
15
  if (propIdx < 0)
@@ -26,6 +27,15 @@ export function editProperty(field) {
26
27
  break;
27
28
  }
28
29
  }
30
+ function count_properties() {
31
+ let count = 0;
32
+ for (let i = 0; i < properties.length; i++) {
33
+ let property = properties[i];
34
+ if (item[property.a])
35
+ count++;
36
+ }
37
+ return count;
38
+ }
29
39
  function on_date_changed(value, a) {
30
40
  if (!value)
31
41
  item[a] = "";
@@ -88,13 +98,18 @@ async function editTags(field, propIdx) {
88
98
  }
89
99
  </script>
90
100
 
91
- <section class="flex flex-row justify-between">
101
+ <!-- svelte-ignore a11y-click-events-have-key-events -->
102
+ <!-- svelte-ignore a11y-structure -->
103
+ {#if properties && properties_no > 0}
104
+ <figcaption class = "kanban-prooperties">
105
+ <div class="flex flex-row justify-between">
92
106
  {#each properties as prop, idx}
93
107
  {#if true}
94
108
  {@const notEmpty = item[prop.a] || placeholder==prop.name}
95
109
  {#if prop.type == rList_property_type.Date && notEmpty}
96
110
  <DatePicker
97
111
  self={item}
112
+ typo = {true}
98
113
  a={prop.a}
99
114
  compact={true}
100
115
  s="sm"
@@ -103,6 +118,7 @@ async function editTags(field, propIdx) {
103
118
  {:else if prop.type == rList_property_type.Combo && notEmpty}
104
119
  <Combo
105
120
  compact={true}
121
+ typo
106
122
  inContext="props"
107
123
  self={item}
108
124
  a={prop.a}
@@ -112,18 +128,15 @@ async function editTags(field, propIdx) {
112
128
  icon={false}
113
129
  definition={prop.combo_definition}
114
130
  s="sm"
115
- changed={(k,n) => { /*fake assignment for component rer-ender*/ item[prop.a] = item[prop.a]; }}
131
+ changed={(k,n) => { /*fake assignment for component rer-ender*/ item[prop.a] = item[prop.a]; }}
116
132
  bind:this={propElements[idx]}/>
117
133
  {:else if prop.type == rList_property_type.Static}
118
- <p
119
- class=" h-6
120
- text-sm sm:min-h-[1rem]
121
- text-base-sm min-h-[1.5rem]
122
- text-stone-600 dark:text-stone-400
134
+ <span
135
+ class=" text-stone-600 dark:text-stone-400
123
136
  text-right"
124
137
  bind:this={propElements[idx]}>
125
138
  {item[prop.a]}
126
- </p>
139
+ </span>
127
140
  {:else if prop.type == rList_property_type.Tags && notEmpty}
128
141
  <Tags
129
142
  class="mt-1"
@@ -141,4 +154,6 @@ async function editTags(field, propIdx) {
141
154
  {/if}
142
155
  {/if}
143
156
  {/each}
144
- </section>
157
+ </div>
158
+ </figcaption>
159
+ {/if}
@@ -2,9 +2,12 @@
2
2
  import { KanbanColumnBottom, KanbanColumnTop, rKanban_definition } from "./Kanban";
3
3
  import { parseWidthDirective, clearActiveItem, getPrev, getNext, remove, insertAt, insertAfter, swapElements, getActive } from "../../utils";
4
4
  import { contextItemsStore, contextTypesStore, data_tick_store } from "../../stores";
5
- import Column from "./internal/kanban.column.svelte";
5
+ import KanbanColumn from "./internal/kanban.column.svelte";
6
6
  import { informModification, pushChanges } from "../../updates";
7
+ import { Editable } from "../..";
8
+ export let self = null;
7
9
  export let title = "";
10
+ export let summary = "";
8
11
  export let c = "";
9
12
  export const CLEAR_SELECTION = 0;
10
13
  export const KEEP_SELECTION = -1;
@@ -142,21 +145,6 @@ export function edit(item, field) {
142
145
  }
143
146
  }
144
147
  let columns = [];
145
- afterUpdate(() => {
146
- for (let i = 1; i < columns.length; i++) {
147
- let left_column = columns[i - 1];
148
- let right_column = columns[i];
149
- const left_column_height = left_column?.getHeight();
150
- const right_column_height = right_column?.getHeight();
151
- if (left_column_height > right_column_height) {
152
- left_column?.setBorder(left_column.SET_RIGHT);
153
- right_column?.setBorder(right_column.CLEAR_LEFT);
154
- } else {
155
- left_column?.setBorder(left_column.CLEAR_RIGHT);
156
- right_column?.setBorder(right_column.SET_LEFT);
157
- }
158
- }
159
- });
160
148
  export function scrollViewToCard(item) {
161
149
  columns.forEach((c2) => {
162
150
  const card = c2.findCardByItem(item);
@@ -320,7 +308,7 @@ export async function replace(item, toColumnIdx, afterElement) {
320
308
  toColumn.reload();
321
309
  }
322
310
  }
323
- async function onInsert(columnIdx, title2, summary, afterId) {
311
+ async function onInsert(columnIdx, title2, summary2, afterId) {
324
312
  const columnState = definition.columns[columnIdx].state;
325
313
  const oa = definition.orderAttrib;
326
314
  const sa = definition.stateAttrib;
@@ -329,7 +317,7 @@ async function onInsert(columnIdx, title2, summary, afterId) {
329
317
  const columnBottom = allItems.findLast((e) => e[sa] == columnState);
330
318
  let newElement = {
331
319
  [definition.titleAttrib]: title2,
332
- [definition.summaryAttrib]: summary,
320
+ [definition.summaryAttrib]: summary2,
333
321
  [sa]: columnState
334
322
  };
335
323
  if (afterId == KanbanColumnTop) {
@@ -444,81 +432,40 @@ export function add(item, columnIdx = -1) {
444
432
  {#key renderToken}
445
433
  <slot/> <!-- Launch definition settings -->
446
434
 
447
- {#if title}
448
- <p class="hidden sm:block mt-3 ml-3 pb-5 text-lg text-left">{title}</p>
435
+ <figure class="px-0 sm:px-4">
436
+ <h1><Editable self={self} a={title}/></h1>
437
+ <figcaption><Editable self={self} a={summary}/></figcaption>
438
+ </figure>
439
+
449
440
  <!--hr class="hidden sm:block w-full"-->
450
- {/if}
451
441
 
452
442
  <section id="__hd_svelte_kanban_columns_container"
453
- class="h-full mt-5 flex flex-row no-wrap
454
- overflow-x-auto snap-x snap-mandatory sm:snap-none
455
- {user_class}"> <!--sm:justify-center -->
443
+ class="h-full flex flex-row no-wrap
444
+ overflow-x-auto snap-x snap-mandatory
445
+ sm: space-x-0
446
+ sm:divide-x
447
+ divide-stone-500 dark:divide-stone-700
448
+ pb-20
449
+ "> <!--sm:justify-center -->
456
450
  {#each definition.columns as column, idx (column.id)}
457
- <Column currentColumnIdx={idx}
451
+ <KanbanColumn currentColumnIdx={idx}
458
452
  {onInsert}
459
453
  bind:this={columns[idx]}>
460
454
 
461
-
455
+
462
456
  <svelte:fragment slot="kanbanCardTopProps" let:element>
463
457
  <slot name="kanbanCardTopProps" {element}/>
464
458
  </svelte:fragment>
465
-
459
+
466
460
  <svelte:fragment slot="kanbanCardMiddleProps" let:element>
467
461
  <slot name="kanbanCardMiddleProps" {element}/>
468
462
  </svelte:fragment>
469
-
463
+
470
464
  <svelte:fragment slot="kanbanCardBottomProps" let:element>
471
465
  <slot name="kanbanCardBottomProps" {element}/>
472
466
  </svelte:fragment>
473
-
474
- </Column>
467
+
468
+ </KanbanColumn>
475
469
  {/each}
476
470
  </section>
477
471
  {/key}
478
-
479
- <style>
480
- .grid-1
481
- {
482
- display: grid;
483
- grid-template-columns: 100%;
484
- }
485
-
486
- .grid-2
487
- {
488
- display: grid;
489
- grid-template-columns: 50% 50%;
490
- }
491
-
492
- .grid-3
493
- {
494
- display: grid;
495
- grid-template-columns: 33% 33% 33%;
496
- }
497
-
498
- .grid-4
499
- {
500
- display: grid;
501
- grid-template-columns: 25% 25% 25% 25%;
502
- }
503
- .grid-5
504
- {
505
- display: grid;
506
- grid-template-columns: 20% 20% 20% 20% 20%;
507
- }
508
- .grid-6
509
- {
510
- display: grid;
511
- grid-template-columns: 16.6% 16.6% 16.6% 16.6% 16.6% 16.6;
512
- }
513
- .grid-7
514
- {
515
- display: grid;
516
- grid-template-columns: 14.3% 14.3% 14.3% 14.3% 14.3% 14.3% 14.3%;
517
- }
518
- .grid-8
519
- {
520
- display: grid;
521
- grid-template-columns: 12.5% 12.5% 12.5% 12.5% 12.5% 12.5% 12.5% 12.5%;
522
- }
523
-
524
- </style>
@@ -2,7 +2,9 @@ import { SvelteComponentTyped } from "svelte";
2
2
  declare const __propDef: {
3
3
  props: {
4
4
  [x: string]: any;
5
+ self?: null | undefined;
5
6
  title?: string | undefined;
7
+ summary?: string | undefined;
6
8
  c?: string | undefined;
7
9
  CLEAR_SELECTION?: 0 | undefined;
8
10
  KEEP_SELECTION?: -1 | undefined;
Binary file
@@ -34,6 +34,7 @@ export declare class rList_property_tags extends rList_property {
34
34
  }
35
35
  export declare class rList_definition {
36
36
  name: string;
37
+ icon: string;
37
38
  title: string;
38
39
  title_editable: boolean;
39
40
  on_title_changed: Function | undefined;
@@ -42,6 +42,7 @@ export class rList_property_tags extends rList_property {
42
42
  }
43
43
  export class rList_definition {
44
44
  name = '';
45
+ icon = '';
45
46
  title = '';
46
47
  title_editable = false;
47
48
  on_title_changed = undefined;