Skip to content

Commit

Permalink
fix: alignment edge cases
Browse files Browse the repository at this point in the history
  • Loading branch information
unimu-cic committed Dec 3, 2023
1 parent 42c3c68 commit 8c42642
Show file tree
Hide file tree
Showing 9 changed files with 130 additions and 73 deletions.
47 changes: 31 additions & 16 deletions src/components/DiagramFrame/SeqDiagram/LifeLineLayer/LifeLine.vue
Original file line number Diff line number Diff line change
Expand Up @@ -4,31 +4,31 @@
class="lifeline absolute flex flex-col mx-2 transform -translate-x-1/2 h-full"
:style="{ paddingTop: top + 'px', left: left + 'px' }"
>
<div v-show="debug">{{centerOf(entity.name)}}</div>
<div v-show="debug">{{ centerOf(entity.name) }}</div>
<participant v-if="renderParticipants" :entity="entity" :offsetTop="top" />
<div v-else class="line w0 mx-auto flex-grow w-px"></div>
<div v-else class="line absolute inset-0 w0 mx-auto flex-grow w-px"></div>
</div>
</template>

<script>
import parentLogger from '../../../../logger/logger';
import EventBus from '../../../../EventBus';
import { mapGetters, mapState } from 'vuex';
import Participant from './Participant.vue';
const logger = parentLogger.child({ name: 'LifeLine' });
import parentLogger from "../../../../logger/logger";
import EventBus from "../../../../EventBus";
import { mapGetters, mapState } from "vuex";
import Participant from "./Participant.vue";
const logger = parentLogger.child({ name: "LifeLine" });
export default {
name: 'life-line',
name: "life-line",
components: { Participant },
props: ['entity', 'context', 'groupLeft', 'inGroup', 'renderParticipants'],
props: ["entity", "context", "groupLeft", "inGroup", "renderParticipants"],
data: () => {
return {
translateX: 0,
top: 0,
};
},
computed: {
...mapGetters(['centerOf']),
...mapState(['scale']),
...mapGetters(["centerOf"]),
...mapState(["scale"]),
debug() {
return !!localStorage.zenumlDebug;
},
Expand All @@ -43,7 +43,10 @@ export default {
logger.debug(`nextTick after updated for ${this.entity.name}`);
});
EventBus.$on('participant_set_top', () => this.$nextTick(() => this.setTop()));
EventBus.$on(
"participant_set_top",
this.$nextTick(() => this.setTop()),
);
// setTimeout( () => {
// this.setTop()
Expand All @@ -65,15 +68,23 @@ export default {
},
methods: {
onSelect() {
this.$store.commit('onSelect', this.entity.name);
this.$store.commit("onSelect", this.entity.name);
},
setTop() {
// escape entity name to avoid 'not a valid selector' error.
const escapedName = this.entity.name.replace(/([ #;&,.+*~\':"!^$[\]()=>|\/@])/g, '\\$1');
/* eslint-disable no-useless-escape */
const escapedName = this.entity.name.replace(

Check failure

Code scanning / CodeQL

Incomplete string escaping or encoding High

This does not escape backslash characters in the input.
/([ #;&,.+*~\':"!^$[\]()=>|\/@])/g,
"\\$1",
);
const $el = this.$store.getters.diagramElement;
const firstMessage = $el?.querySelector(`[data-to="${escapedName}"]`);
const isVisible = firstMessage?.offsetParent != null;
if (firstMessage && firstMessage.attributes['data-type'].value === 'creation' && isVisible) {
if (
firstMessage &&
firstMessage.attributes["data-type"].value === "creation" &&
isVisible
) {
logger.debug(`First message to ${this.entity.name} is creation`);
const rootY = this.$el.getBoundingClientRect().y;
const messageY = firstMessage.getBoundingClientRect().y;
Expand All @@ -89,7 +100,11 @@ export default {
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.lifeline .line {
background: linear-gradient(to bottom, transparent 50%, var(--color-border-base) 50%);
background: linear-gradient(
to bottom,
transparent 50%,
var(--color-border-base) 50%
);
background-size: 1px 10px;
}
</style>
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
:key="index"
>
<Statement
:inheritFromOccurrence="inheritFromOccurrence"
:fromOccurrence="fromOccurrence"
:context="stat"
:collapsed="collapsed"
:selfCallIndent="selfCallIndent"
Expand All @@ -27,7 +27,7 @@ const props = defineProps<{
number?: string;
incremental?: boolean;
collapsed?: boolean;
inheritFromOccurrence?: boolean;
fromOccurrence?: boolean;
}>();
const statements = computed(() => props.context?.stat() || []);
const getNumber = (index: number) => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,15 @@
class="interaction sync inline-block"
v-on:click.stop="onClick"
:data-to="to"
:data-from="origin"
data-type="interaction"
:data-signature="signature"
:class="{
highlight: isCurrent,
self: isSelf,
'inited-from-occurrence': inheritFromOccurrence,
'from-occurrence': fromOccurrence,
'from-no-occurrence': providedFrom && providedFrom !== origin,
'inited-from-occurrence': isInitedFromOccurrence,
'right-to-left': rightToLeft,
}"
:style="{
Expand Down Expand Up @@ -74,7 +77,7 @@ export default {
"selfCallIndent",
"commentObj",
"number",
"inheritFromOccurrence",
"fromOccurrence",
],
computed: {
// add tracker to the mapGetters
Expand Down Expand Up @@ -164,7 +167,7 @@ export default {
return this.isSelf ? "SelfInvocation" : "Message";
},
isInitedFromOccurrence: function () {
return this.message?.isInitedFromOccurrence(this.from);
return this.message?.isInitedFromOccurrence(this.context);
},
},
methods: {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,14 @@
:collapsed="collapsed"
@click="this.toggle"
/>
<!-- TODO: use util function instead of the `fromOccurrence` prop -->
<block
v-if="this.context.braceBlock()"
:context="context.braceBlock().block()"
:selfCallIndent="selfCallIndent"
:number="number"
:collapsed="collapsed"
:inheritFromOccurrence="true"
:fromOccurrence="true"
></block>
</div>
</template>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,10 @@
v-on:click.stop="onClick"
:data-signature="signature"
:class="{
'to-occurrence': isToOccurrence,
'right-to-left': rightToLeft,
highlight: isCurrent,
'from-occurrence': fromOccurrence,
'self-invocation': isSelf,
}"
:style="{
Expand Down Expand Up @@ -40,7 +42,14 @@ function isNullOrUndefined(value) {
export default {
name: "interaction-async",
props: ["context", "comment", "commentObj", "selfCallIndent", "number"],
props: [
"context",
"comment",
"commentObj",
"selfCallIndent",
"number",
"fromOccurrence",
],
computed: {
...mapGetters(["distance", "cursor", "onElementClick"]),
from: function () {
Expand Down Expand Up @@ -101,6 +110,9 @@ export default {
messageClassNames() {
return this.commentObj?.classNames;
},
isToOccurrence() {
return this.asyncMessage.isToOccurrence(this.asyncMessage);
},
},
methods: {
onClick() {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,11 @@
<template>
<div
class="message border-skin-message-arrow border-b-2 flex items-end"
:data-from="providedFrom"
:data-origin="origin"
:data-to="to"
:class="{
hasParent: hasParent,
'flex-row-reverse': rtl,
return: type === 'return',
'right-to-left': rtl,
Expand All @@ -19,17 +23,26 @@
<div :style="textStyle" :class="classNames">
{{ content }}
</div>
<div class="absolute right-[100%] top-0 pr-1 group-hover:hidden text-gray-500" v-if="numbering">{{ number }}</div>
<div
class="absolute right-[100%] top-0 pr-1 group-hover:hidden text-gray-500"
v-if="numbering"
>
{{ number }}
</div>
</div>
</div>
<point class="flex-shrink-0 transform translate-y-1/2 -my-px" :fill="fill" :rtl="rtl" />
<point
class="flex-shrink-0 transform translate-y-1/2 -my-px"
:fill="fill"
:rtl="rtl"
/>
</div>
</template>

<script setup lang="ts">
import { useStore } from 'vuex';
import Point from './Point/Point.vue';
import { computed, toRefs, ref } from 'vue';
import { useStore } from "vuex";
import Point from "./Point/Point.vue";
import { computed, toRefs, ref } from "vue";
const props = defineProps<{
context?: any;
content: string;
Expand All @@ -38,35 +51,40 @@ const props = defineProps<{
textStyle?: Record<string, string | number>;
classNames?: any;
number?: string;
}>()
const { context, content, rtl, type, textStyle, classNames, number } = toRefs(props)
const store = useStore()
const messageRef = ref()
const numbering = computed(() => store.state.numbering)
const isAsync = computed(() => type?.value === 'async')
}>();
const { context, content, rtl, type, textStyle, classNames, number } =
toRefs(props);
const store = useStore();
const messageRef = ref();
const numbering = computed(() => store.state.numbering);
const isAsync = computed(() => type?.value === "async");
const origin = computed(() => props.context?.Origin());
const providedFrom = computed(() => props.context?.From());
const to = computed(() => props.context?.Owner());
const borderStyle = computed(() => {
switch (type?.value) {
case 'sync':
case 'async':
return 'solid'
case 'creation':
case 'return':
return 'dashed'
case "sync":
case "async":
return "solid";
case "creation":
case "return":
return "dashed";
}
return ''
})
return "";
});
const fill = computed(() => {
switch (type?.value) {
case 'sync':
case 'async':
return true
case 'creation':
case 'return':
return false
case "sync":
case "async":
return true;
case "creation":
case "return":
return false;
}
return false
})
return false;
});
const onClick = () => {
store.getters.onMessageClick(context, messageRef.value)
}
</script>
store.getters.onMessageClick(context, messageRef.value);
};
</script>
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
:commentObj="commentObj"
:selfCallIndent="selfCallIndent"
:number="number"
:inheritFromOccurrence="inheritFromOccurrence"
:fromOccurrence="fromOccurrence"
></component>
</template>

Expand All @@ -29,13 +29,7 @@ import Comment from "../../../../../Comment/Comment";
export default {
name: "statement",
props: [
"context",
"selfCallIndent",
"number",
"collapsed",
"inheritFromOccurrence",
],
props: ["context", "selfCallIndent", "number", "collapsed", "fromOccurrence"],
computed: {
comment: function () {
return this.context.getComment() ? this.context.getComment() : "";
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -66,14 +66,6 @@ onUpdated(() => {
border-right-width: 7px;
}

.alt,
.fragment {
.interaction.sync {
border-left-width: 7px;
//border-right-width: 0;
}
}

.occurrence {
.occurrence {
.interaction.sync,
Expand All @@ -86,17 +78,26 @@ onUpdated(() => {
.occurrence {
.interaction.sync,
.interaction.async {
border-left-width: 7px;
border-left-width: 8px;
}

.interaction.sync.from-no-occurrence {
border-left-width: 0;
}
.interaction.sync.right-to-left {
border-right-width: 7px;
}
.interaction.async.right-to-left {
border-right-width: 7px;
border-left-width: 7px;
}
.interaction.async.right-to-left.from-occurrence {
border-left-width: 0;
}
.interaction.async.right-to-left.to-occurrence {
border-left-width: 7px;
}
}

.interaction.sync.right-to-left {
/* This border width configuration make sure the content width is
the same as from the source occurrence's right border to target
Expand Down
Loading

0 comments on commit 8c42642

Please sign in to comment.