This commit is contained in:
2020-12-21 18:02:53 +00:00
parent 7864ba906b
commit 1153c16ffb
2 changed files with 185 additions and 14 deletions

View File

@@ -66,7 +66,11 @@
></v-checkbox> ></v-checkbox>
</td> </td>
</template> </template>
<td v-for="c in item.columns" :key="c.key"> <td
v-for="c in item.columns"
:key="c.key"
v-bind:style="cellStyle(c)"
>
<template v-if="c.t == 1"> <template v-if="c.t == 1">
<!-- DATETIME --> <!-- DATETIME -->
{{ c.v }} {{ c.v }}
@@ -242,7 +246,7 @@
<v-list-item-title> <v-list-item-title>
{{ getHeaderText(c.key) }}</v-list-item-title {{ getHeaderText(c.key) }}</v-list-item-title
> >
<v-list-item-subtitle> <v-list-item-subtitle v-bind:style="cellStyle(c)">
<template v-if="c.t == 1"> <template v-if="c.t == 1">
<!-- DATETIME --> <!-- DATETIME -->
{{ c.v }} {{ c.v }}
@@ -575,6 +579,16 @@ export default {
//i is the actual AyaNova index of vm record so we have all we need to open vm object //i is the actual AyaNova index of vm record so we have all we need to open vm object
window.$gz.eventBus.$emit("openobject", { type: typeToOpen, id: i }); window.$gz.eventBus.$emit("openobject", { type: typeToOpen, id: i });
}, },
cellStyle(c) {
// :style="'style=background-color:#FFFFE0;color:black;border:1px solid #BDB76B;' + c.clr + ';'"
if (c.clr && c.clr.length > 3) {
if (c.clr[0] != "#") {
c.clr = "#" + c.clr;
}
return { border: `4px solid ${c.clr}` };
}
return null;
},
async getDataFromApi(deSelectAll) { async getDataFromApi(deSelectAll) {
let vm = this; let vm = this;
@@ -882,6 +896,11 @@ function buildRecords(listData, columndefinitions) {
columnObject["ot"] = column.ot; columnObject["ot"] = column.ot;
} }
//rgba color to decorate field with
if (column.clr) {
columnObject["clr"] = column.clr;
}
o.columns["c" + iColumn.toString()] = columnObject; o.columns["c" + iColumn.toString()] = columnObject;
//Is: //Is:
//Headers: [ { "text": "Name", "value": "c1" }, { "text": "Serial #", "value": "c2" }, //Headers: [ { "text": "Name", "value": "c1" }, { "text": "Serial #", "value": "c2" },

View File

@@ -1,21 +1,173 @@
<template> <template>
<UnderConstruction data-cy="underconstruction" /> <div>
<gz-report-selector ref="reportSelector"></gz-report-selector>
<gz-extensions
:ayaType="ayType"
:selectedItems="selectedItems"
ref="extensions"
>
</gz-extensions>
<gz-data-table
ref="gzdatatable"
formKey="reminder-list"
:dataListKey="dataListKey"
:dataListFilter="dataListFilter"
:dataListSort="dataListSort"
:showSelect="rights.read"
:reload="reload"
v-on:selection-change="handleSelected"
data-cy="remindersTable"
>
</gz-data-table>
</div>
</template> </template>
<script> <script>
import UnderConstruction from "../components/underconstruction.vue"; const FORM_KEY = "reminder-list";
export default { export default {
components: { created() {
UnderConstruction this.rights = window.$gz.role.getRights(window.$gz.type.Reminder);
window.$gz.eventBus.$on("menu-click", clickHandler);
generateMenu(this);
}, },
beforeCreate() { beforeDestroy() {
window.$gz.eventBus.$emit("menu-change", { window.$gz.eventBus.$off("menu-click", clickHandler);
isMain: true, },
icon: "$ayiStickyNote", data() {
title: "ReminderList", return {
helpUrl: "form-home-reminders" currentListViewId: 1,
}); dataListKey: "ReminderDataList",
dataListFilter: "",
dataListSort: "",
rights: window.$gz.role.defaultRightsObject(),
ayType: window.$gz.type.Reminder,
selectedItems: [],
reload: false
};
},
methods: {
handleSelected(selected) {
this.selectedItems = selected;
}
} }
}; };
/////////////////////////////
//
//
async function clickHandler(menuItem) {
if (!menuItem) {
return;
}
let m = window.$gz.menu.parseMenuItem(menuItem);
if (m.owner == FORM_KEY && !m.disabled) {
switch (m.key) {
case "new":
m.vm.$router.push({
name: "reminder-edit",
params: { recordid: 0 }
});
break;
case "extensions":
let res = await m.vm.$refs.extensions.open(
m.vm.$refs.gzdatatable.getDataListSelection(window.$gz.type.Reminder)
);
if (res && res.refresh == true) {
m.vm.reload = !m.vm.reload;
}
break;
case "report":
if (m.id != null) {
//last report selected is in m.id
m.vm.$router.push({
name: "ay-report",
params: { recordid: m.id, ayatype: window.$gz.type.Reminder }
});
} else {
//general report selector chosen
let res = await m.vm.$refs.reportSelector.open(
m.vm.$refs.gzdatatable.getDataListSelection(
window.$gz.type.Reminder
)
);
//if null for no selection
//just bail out
if (res == null) {
return;
}
//persist last report selected
window.$gz.form.setLastReport(FORM_KEY, res);
//Now open the report viewer...
m.vm.$router.push({
name: "ay-report",
params: { recordid: res.id, ayatype: window.$gz.type.Reminder }
});
}
break;
default:
window.$gz.eventBus.$emit(
"notify-warning",
FORM_KEY + "::context click: [" + m.key + "]"
);
}
}
}
//////////////////////
//
//
function generateMenu(vm) {
let menuOptions = {
isMain: true,
icon: "$ayiStickyNote",
title: "ReminderList",
helpUrl: "form-home-reminders",
menuItems: [],
formData: {
ayaType: window.$gz.type.Reminder
}
};
if (vm.rights.change) {
menuOptions.menuItems.push({
title: "New",
icon: "$ayiPlus",
surface: true,
key: FORM_KEY + ":new",
vm: vm
});
}
//REPORTS
//Report not Print, print is a further option
menuOptions.menuItems.push({
title: "Report",
icon: "$ayiFileAlt",
key: FORM_KEY + ":report",
vm: vm
});
//get last report selected
let lastReport = window.$gz.form.getLastReport(FORM_KEY);
if (lastReport != null) {
menuOptions.menuItems.push({
title: lastReport.name,
icon: "$ayiFileAlt",
key: FORM_KEY + ":report:" + lastReport.id,
vm: vm
});
}
menuOptions.menuItems.push({
title: "Extensions",
icon: "$ayiPuzzlePiece",
key: FORM_KEY + ":extensions",
vm: vm
});
window.$gz.eventBus.$emit("menu-change", menuOptions);
}
</script> </script>