update 園児台帳 for update vlookup

This commit is contained in:
2025-02-12 14:42:54 +08:00
parent 4f495f9abf
commit 4e39a1a680
10 changed files with 209 additions and 29 deletions

View File

@@ -23,5 +23,11 @@ const env = {
},
"園児台帳": {
appId: 16,
uniqueKeyFieldCode: 'ユニークキー'
},
};
const warekiStartYear = {
"平成": 1989,
"令和": 2019,
}

View File

@@ -75,4 +75,20 @@
--kuc-button-height: 42px;
margin-top: 32px;
margin-left: -8px;
}
}
.kuc--has-spinner {
position: relative;
}
div[class^='kuc-spinner'][class$='__spinner'] {
margin-top: 89px;
height: calc(100% - 89px);
position: absolute;
--kuc-spinner-text-color: #3498db;
--kuc-spinner-loader-color: #3498db;
}
div[class^='kuc-spinner'][class$='mask'] {
top: 89px;
position: absolute;
background-color: white;
}

View File

@@ -21,6 +21,7 @@ const classItems = [
const errorEl = new Kuc.Notification({
type: 'danger',
});
let loadingEl;
function getHeaderSpace(className, isDetailPage) {
const headerSpace = (isDetailPage ? kintone.app.record : kintone.app).getHeaderMenuSpaceElement();
@@ -191,4 +192,61 @@ function hideSpaceField(ids) {
function getExcelName({ excelName }, nameSuffix = '', suffix = '.xlsx') {
return excelName + (nameSuffix ? (nameSuffix.startsWith('_') ? nameSuffix : ('_' + nameSuffix)) : '') + suffix;
}
function getJapaneseEraDate(date = new Date()) {
const formatter = new Intl.DateTimeFormat('ja-JP-u-ca-japanese', {
era: 'long',
year: 'numeric',
month: 'long',
day: 'numeric'
});
const japaneseDate = formatter.format(date);
const match = japaneseDate.match(/(.+?)(元|\d+)年(\d+)月(\d+)日/);
if (!match) {
throw new Error("日付の解析に失敗しました。");
}
const era = match[1];
const year = match[2] === "元" ? 1 : parseInt(match[2], 10);
const month = parseInt(match[3], 10);
const day = parseInt(match[4], 10);
return {
japaneseDate,
era,
year,
month,
day,
westernYear: date.getFullYear()
};
}
function convertToWesternYear(year, era) {
return warekiStartYear[era] + year - 1;
}
function getFormatDateString(date) {
const year = date.getFullYear();
const month = String(date.getMonth() + 1).padStart(2, '0');
const day = String(date.getDate()).padStart(2, '0');
return `${year}-${month}-${day}`;
}
function loading(show, text) {
if (!loadingEl) {
loadingEl = new Kuc.Spinner({
container: document.querySelector('.container-gaia'),
text
});
} else {
loadingEl.close();
loadingEl.text = text;
}
if (show) {
loadingEl.open();
}
}

View File

@@ -1,8 +1,6 @@
class BatchCreateHandler {
constructor(env, headerSpace) {
BatchCreateHandler.APP_ENV = env;
constructor(headerSpace) {
const elements = createBtnGroupArea('batch-action-area', '出欠簿一括作成', this.handleCreateDate, {
btnElId: 'batch-btn',
})
@@ -12,7 +10,69 @@ class BatchCreateHandler {
headerSpace.appendChild(elements['batch-action-area']);
}
handleCreateDate(e) {
handleCreateDate = async (e) => {
loading(true, '出欠簿一括作成中...');
const api = new KintoneRestAPIClient();
let result = [];
try {
result = await api.record.getAllRecordsWithId({
app: env["園児台帳"].appId,
fields: ["$id", "ユニークキー", "和暦_退園年月日", "年_退園年月日", "月_退園年月日", "日_退園年月日"],
});
} catch (error) {
// TODO
loading(false);
return;
}
const today = new Date();
const todayString = getFormatDateString(today)
const records = [];
for (const record of result) {
if (!this.needCreateData(record, today)) {
continue;
}
records.push(this.createRecord(record, todayString))
}
console.log(records);
try {
const addResult = await api.record.addAllRecords({
app: env["園児別出欠簿入力"].appId,
records
});
location.reload();
} catch (error) {
// TODO
} finally {
loading(false);
}
}
needCreateData = (record, today) => {
const era = record["和暦_退園年月日"].value;
const lastYear = record["年_退園年月日"].value;
const lastMonth = record["月_退園年月日"].value;
const lastDate = record["日_退園年月日"].value;
if (!era || !lastYear || !lastMonth || !lastDate) {
return true;
}
const todayObj = new Date(today);
todayObj.setHours(0, 0, 0, 0);
const lastDateObj = new Date(convertToWesternYear(Number(lastYear), era), Number(lastMonth) - 1, Number(lastDate));
lastDateObj.setHours(0, 0, 0, 0);
return todayObj.getTime() <= lastDateObj.getTime();
}
createRecord = (record, todayString) => {
return {
'登園日': { 'value': todayString },
'園児ユニークキー': { 'value': record["ユニークキー"].value },
// '学年': { 'value': record["学年"].value },
// 'クラス': { 'value': record["クラス"].value },
// '出席番号': { 'value': record["出席番号"].value },
}
}
static getInstance(env, headerSpace) {

View File

@@ -1,7 +1,5 @@
class ExtractHandler {
constructor(env, headerSpace) {
ExtractHandler.APP_ENV = env;
constructor(headerSpace) {
const elements = createBtnGroupArea('extract-action-area', '出欠集計表出力', this.handleExtractData, {
btnElId: 'extract-btn',
yearElId: 'extract-year',
@@ -15,13 +13,13 @@ class ExtractHandler {
}
handleExtractData(e, { year, month, className }) {
const fileName = getExcelName(ExtractHandler.APP_ENV, year + month + '_' + className + '組');
const fileName = getExcelName(env["園児別出欠簿入力"], year + month + '_' + className + '組');
console.log(fileName);
}
static getInstance(env, headerSpace) {
static getInstance(headerSpace) {
if (!ExtractHandler.instance) {
ExtractHandler.instance = new ExtractHandler(env, headerSpace);
ExtractHandler.instance = new ExtractHandler(headerSpace);
}
return ExtractHandler.instance;
}

View File

@@ -1,8 +1,6 @@
class Link1Handler {
constructor(env, headerSpace) {
Link1Handler.APP_ENV = env;
constructor(headerSpace) {
const elements = createBtnGroupArea('link-1-action-area', '0,1歳日誌データ連携', this.handleLink, {
btnElId: 'link-1-btn',
yearElId: 'link-1-year',
@@ -17,9 +15,9 @@ class Link1Handler {
handleLink(e, { year, month }) {
}
static getInstance(env, headerSpace) {
static getInstance(headerSpace) {
if (!Link1Handler.instance) {
Link1Handler.instance = new Link1Handler(env, headerSpace);
Link1Handler.instance = new Link1Handler(headerSpace);
}
return Link1Handler.instance;
}

View File

@@ -1,8 +1,6 @@
class Link2Handler {
constructor(env, headerSpace) {
Link2Handler.APP_ENV = env;
constructor(headerSpace) {
const elements = createBtnGroupArea('link-2-action-area', '2歳以上日誌データ連携', this.handleLink, {
btnElId: 'link-2-btn',
yearElId: 'link-2-year',
@@ -20,9 +18,9 @@ class Link2Handler {
handleLink(e, { year, month, date }) {
}
static getInstance(env, headerSpace) {
static getInstance(headerSpace) {
if (!Link2Handler.instance) {
Link2Handler.instance = new Link2Handler(env, headerSpace);
Link2Handler.instance = new Link2Handler(headerSpace);
}
return Link2Handler.instance;
}

View File

@@ -12,10 +12,7 @@
area.appendChild(clockOut);
hideSpaceField(['clock-in-btn-area', 'clock-out-btn-area']);
});
kintone.events.on('app.record.print.show', (event) => {
hideSpaceField(['clock-in-btn-area', 'clock-out-btn-area']);
return event;
});
function dateToFieldInDetail(fieldCode) {
@@ -33,12 +30,19 @@
}
}
// ------------------- 印刷画面表示時の処理 -------------------
kintone.events.on('app.record.print.show', (event) => {
hideSpaceField(['clock-in-btn-area', 'clock-out-btn-area']);
return event;
});
// ------------------- 編集画面表示時の処理 -------------------
kintone.events.on(['app.record.create.show', 'app.record.edit.show'], function (event) {
const clockIn = createBtn('clock-in', '登園', dateToFieldInEdit('登園時刻'));
kintone.app.record.getSpaceElement('clock-in-btn-area').appendChild(clockIn);
const clockOut = createBtn('clock-out', '帰園', dateToFieldInEdit('帰園時刻'));
kintone.app.record.getSpaceElement('clock-out-btn-area').appendChild(clockOut);
return event;
});
function dateToFieldInEdit(fieldCode) {

View File

@@ -6,17 +6,17 @@
const headerSpace = getHeaderSpace('single-label-line');
if (event.viewId === APP_ENV.view["0,1歳日誌データ連携用途"]) {
Link1Handler.getInstance(APP_ENV, headerSpace);
Link1Handler.getInstance(headerSpace);
return event;
}
if (event.viewId === APP_ENV.view["2歳以上日誌データ連携用途"]) {
Link2Handler.getInstance(APP_ENV, headerSpace);
Link2Handler.getInstance(headerSpace);
return event;
}
BatchCreateHandler.getInstance(APP_ENV, headerSpace);
ExtractHandler.getInstance(APP_ENV, headerSpace);
BatchCreateHandler.getInstance(headerSpace);
ExtractHandler.getInstance(headerSpace);
});
})();

42
src/園児台帳/main.js Normal file
View File

@@ -0,0 +1,42 @@
(function () {
"use strict";
const APP_ENV = env["園児台帳"];
const FIELD_CODE = APP_ENV.uniqueKeyFieldCode;
// ------------------- 詳細/印刷/編集画面表示時の処理 -------------------
kintone.events.on(['app.record.detail.show', 'app.record.print.show'], function (event) {
hideField(FIELD_CODE);
return event;
});
// ------------------- 編集画面表示時の処理 -------------------
kintone.events.on(['app.record.edit.show', 'app.record.create.show'], function (event) {
const targetFieldEl = kintone.app.record.getSpaceElement("before-unique-key").parentElement.nextSibling;
targetFieldEl.querySelector('.input-constraints-cybozu').style.display = 'none';
event.record[FIELD_CODE]['value'] = "<自動計算:出席番号+学年+クラス+名前>";
disableField(event.record, FIELD_CODE);
return event;
});
function hideField(fieldCode) {
kintone.app.record.setFieldShown(fieldCode, false);
}
function disableField(record, fieldCode) {
record[fieldCode]['disabled'] = true;
}
// ------------------- 編集画面保存時の処理 -------------------
kintone.events.on(['app.record.create.submit', 'app.record.edit.submit'], function (event) {
event.record[FIELD_CODE]['value'] = getUniqueKey(event.record);
return event;
});
function getUniqueKey(record) {
return (record['出席番号']['value'] + '_' + record['学年']['value'] + '_' + record['クラス']['value'] + '_' + record['名前']['value']).substring(0, 64);
}
})();