Skip to content

Commit

Permalink
Refactored most modals to use CloseableModal instead
Browse files Browse the repository at this point in the history
  • Loading branch information
Daniferrito committed Sep 29, 2019
1 parent 7a994f1 commit 9959141
Show file tree
Hide file tree
Showing 10 changed files with 319 additions and 408 deletions.
102 changes: 102 additions & 0 deletions client/src/core/components/modals/closeableModal.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
<template>
<Modal ref="modal" :visible="visible" :colour="'rgba(255, 255, 255, 0.8)'" @close="close" :mask="false">
<div
class="modal-header"
slot="header"
slot-scope="m"
draggable="true"
@dragstart="m.dragStart"
@dragend="m.dragEnd"
>
<div>{{ displayTitle || title }}</div>
<div class="header-close" @click="close">
<i class="far fa-window-close"></i>
</div>
</div>
<div class="modal-body" @click="handleClick">
<slot></slot>
</div>
</Modal>
</template>

<script lang="ts">
import Vue from "vue";
import Component from "vue-class-component";
import { Prop } from "vue-property-decorator";
import InputCopyElement from "@/core/components/inputCopy.vue";
import Modal from "@/core/components/modals/modal.vue";
import { modalsStore } from "@/core/components/modals/store";
import { EventBus } from "@/game/event-bus";
@Component({
components: {
InputCopyElement,
Modal,
},
})
export default class CloseableModal extends Vue {
@Prop({ type: String, required: true }) title!: string;
@Prop({ type: String, default: undefined }) displayTitle?: string;
visible = false;
mounted() {
EventBus.$on(`${this.title}.Toggle`, () => {
if (this.visible && modalsStore.topModal === this.$refs.modal) {
this.close();
} else {
this.visible = true;
modalsStore.setTopModal(this.$refs.modal as Modal);
}
});
EventBus.$on(`${this.title}.Open`, () => {
this.visible = true;
modalsStore.setTopModal(this.$refs.modal as Modal);
});
EventBus.$on(`${this.title}.Close`, ({ fromModal = false }: { fromModal: boolean }) => {
if (!fromModal) {
this.close();
}
});
}
beforeDestroy() {
EventBus.$off(`${this.title}.Toggle`);
EventBus.$off(`${this.title}.Open`);
}
handleClick(event: { target: HTMLElement }) {
const child = event.target.firstElementChild;
if (child instanceof HTMLInputElement) {
child.click();
}
}
close() {
this.visible = false;
EventBus.$emit(`${this.title}.Close`, { fromModal: true });
modalsStore.removeFromModals(this.$refs.modal as Modal);
}
}
</script>

<style scoped>
.modal-header {
background-color: #ff7052;
padding: 10px;
font-size: 20px;
font-weight: bold;
cursor: move;
}
.header-close {
position: absolute;
top: 5px;
right: 5px;
}
.modal-body {
display: flex;
flex-direction: row;
}
</style>
4 changes: 2 additions & 2 deletions client/src/core/components/modals/modal.vue
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
@click.stop
ref="container"
:style="{ 'background-color': colour }"
@click="onClick"
@click="click"
>
<slot name="header" :dragStart="dragStart" :dragEnd="dragEnd"></slot>
<slot></slot>
Expand Down Expand Up @@ -106,7 +106,7 @@ export default class Modal extends Vue {
}
}
onClick() {
click() {
modalsStore.setTopModal(this);
}
}
Expand Down
2 changes: 2 additions & 0 deletions client/src/core/components/modals/store.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@ class ModalsStore extends VuexModule {
this.modals.forEach((element: Modal, i: number) => {
element.$data.zIndex = 8999 - i;
});
console.log({modals: this.modals});
console.trace();
}

@Mutation
Expand Down
Loading

0 comments on commit 9959141

Please sign in to comment.