ページを選択

ストブロ

Coffee's Blog.

有給休暇申請で、会社の休業日を差し引きたい!

執筆者 | 2022年10月26日 | Coffee, Kintone, ストブロ

※投稿当時「アプリ集計プラグイン」と書くべき所を「関連レコード集計プラグイン」と誤った記載をしてしまいました。
正しくは「アプリ集計プラグイン」です。

 rex0220さんはKintoneを何倍も便利にするプラグインを販売されている所で、私もいくつも利用しています。
今回は「休日申請」というアプリを作って運用していたら「あれ?日曜日とかも通算して日数計算してるじゃん」という落とし穴に気がついた所がスタート。
 「すみません、アドバイスありませんか?」とサポートに問合せしたところ、詳しくご説明頂いたのでその解説です。

 画像が7枚になってしまい、twitterに直接アップ出来なかったので自分のブログにはりました。
 rex0220 プラグインはこちら←

 rex0220 Qiitaページはこちら←

有休、振休、早退、遅刻… 会社での申請処理をkintone化したい。そこまでは自力でなんとかしました。
出力はRepotone UでPDF化して、メールの送信もKintone任せ。だいぶ効率化できた!じゃあ、有給日数の集計でもするか… あれ?
日曜日も有給になってる。例えば10月19日(水)→10月24日(月)までを休暇申請したら、土曜日、日曜日も積算されちゃう。
じゃあ、19日→21日と24日の2つに分ければ良いじゃない? いや、それは面倒。

指定した期間中が別アプリに登録された日にマッチすれば減算する

これをrex0220 さんが提供する「アプリ集計」と「計算式」プラグインで解決する方法を教えてもらいました!
また、視覚的にも分かりやすくしたいという場合には「関連テーブル」で該当する情報を表示する事も出来ました。

必要なフィールドを4つ設定してください。
開始日選択、終了日選択:日付フィールド
規定休業日、期間:数値フィールド

必要なフィールドを3つ設定してください。
日付:日付フィールド

区分や備考は使い易いように設定してください。
今回の例では「休業日カレンダーに日付があれば、それは有給の通算からは除外する」というのが目的なので、それ以上の情報は全く必要ではありません。

動作確認の為、実際にデータを入れておいてください。

Ver.38から「自動アプリ集計」という機能が追加されました。以前はボタンをクリックする必要がありましたが、このVer.38からは上記の通り指定しておけば自動で実行されます!

集計条件に「開始日選択」以後、「終了日選択」以前を指定する事で、休業日カレンダーのレコードとマッチングの条件を指定します。

集計項目では「マッチしたら1で集計」して、規定休業日に入れる。という設定になります。「1」がポイント。

「初期化0」をチェックすると、対象のレコードが無かった場合も「0」を返します。後段の計算式プラグインの際に必要になるので忘れずにチェック。

この設定だけで、規定休業日に「2」が集計されます。
簡単!!!

レコード内に休業日「2」を集計できたので、後は算数するだけです。「計算式プラグイン」はkintone標準機能よりも高度な計算が可能でExcelでやっているような「関数」が使用できるイメージです。

もし、終了選択が空欄(未選択)なら期間は空欄。終了日が選択されていれば開始日と終了日の差を求めて「+1」、その後規定休業日を差し引く。という計算です。

IF(終了日選択="", "", DATE_DIFF(開始日選択,終了日選択,"days")+1-規定休業日)

有給を1日申請する場合、開始日:「10月24日、終了日:10月24日」となり、2つの日付間の差は0になります。なので、+1します。休業日カレンダーのレコードで日付が重複しない限り、規定休業日は開始日ー終了日の差を超えませんから、その点は単純に引き算です。

※計算式プラグインで「足し算」をする場合、式の中の値に未入力(平たく言うとnull)があると計算出来なくなるそうです。
 その場合「SUM」を使って「SUM(数値A,数値B)」とすると未入力の値があっても計算出来るそうです。
 今回はアプリ集計プラグインで「初期化0」を選択したので、SUMを使わず足し算をしてもOKになります。

 詳しくは rex0220の解説ページで!

これなら休業日を間に挟むことを気にせず、休業日を差し引いた正しい期間計算ができますね♪

今回は休業日でしたが、レコード集計プラグインを使用すれば例えば、「別アプリから、期間中の出勤日数をカウントする」という様な集計が簡単にできそうです!

自動で集計できるのは嬉しいけど、「見える」っていうの大事じゃん?というそこのあなた!分かります(笑)

こんな風に、休業日カレンダーの該当レコードが、「関連レコード」っぽく表示されたら、いかにもKintoneっぽい
ですよね?(笑)「関連テーブルプラグイン」でそんな事が出来ちゃうよ!と教えて頂きました。

休暇申請アプリにスペースを追加して、一意のIDを設定してください。 

関連テーブルプラグインを休日申請アプリに導入して、設定します。
検索条件では「DATE_FORMAT」を利用する事がポイント。

表示項目は「日付」でソートするのがポイントになります。

これだけで、関連テーブルが表示出来るようになります。

必須ではありませんが、便利。

久しぶりに出勤

おはようございます。 皆様ご機嫌如何ですか? 桂 コヒ蔵です。 被災地のみなさんには心よりお見舞い申し上げます。 一日でも早く暖かく安心できる春が来る事をお祈りしております。 震災後、会社が休業となりその後初出勤です。...

震災後初めて迎える月曜日。

おはようございます。 今日は震災後初めて迎える月曜日です。 各方面、かなりの混乱が発生する可能性があります。 みなさん、どうかいつも以上に気をつけて行動してください。 被災地のみなさん、安否確認や連絡がとれないみなさん。...

こそっ

|`・ω・´)? | ) ミ  さっ

あ、間に合ったw

昨日からの雪で交通状態は最悪。 ってことで、会社に来る時間もぎりぎりになりました。...

iPhone4用スタンド&Dockケーブル

いまさらですが、 昨日iPhone4用のスタンドとDockケーブルを購入しました。 ポイントなのは「バンパー」との併用です! バンパーが大好きって訳ではないのですが、私にとっては現状最も使いやすいケースなのです。 ただ、問題なのがスリムコネクター。...

ひき始めの攻防

日曜日の朝からなんとなく喉が痛いと思っていたのですが、 どうやら風邪のひき始めの様子。 ここで風邪をひいてはなるまいと、早めの葛根湯攻撃! 「風邪VS私」 で激しい攻防戦が続いております(`・ω・´) 2年に一度位3月に大きな風邪を引きまして、...

一年前は?:電器屋新CM

一年前は何をしていたか? とブログを振り返ると、2010年の3月は既にほぼ毎日更新をスタートしていました。 2010年3月7日は日曜日、なので本来ストブロはお休みでしたが、 この日は書き込みがありましたね。...

たった一言でも・・・

たった一言でも、 ストブロを更新し続ける為に、 自分のペースを守る為に、 自分のルールを守る為に、 たった一言でも、 ブログへ投稿するべきなのだろうか? 「おはよ」だけでも、 かきこむべきなのだろうか? それは読んでくれている人を裏切る行為なのか?...

冬が戻ってきました(>_

今朝は冷え込みましたね! こちらでは、また雪が降っちゃいました。 もう三月だけど、春は遠いなぁって感じです。 出勤に時間が掛かってしまった為・・・ 本日はこれにて!ww...

ミニチュアの日

3月2日は「ミニチュア」の日なんだそうです。 3(み) 2(に) の語呂合わせでしょうね。 ・・・ん? だとすると、ミニが付くものなら何でも来いかな? ミニスカートの日 ミニ肉まんの日 ミニミニピザの日 ミニダンボーの日 ミニーマウスの日 ミニ四駆の日...

終わっちゃいますよ!

2月が終わっちゃいますよ!? あっという間に! え、今日28日? 2月最終日じゃないですかΣ( ̄。 ̄ノ)ノ 早かったですねぇ。 もう、今日は2月の余韻に浸って一杯飲みたいと思いますw...

久しぶりの雨

みなさん、雨はお好きですか? 私はINST内では無双の雨好きなのですが、「雨が好き!」っていうと だいたい理解してくれませんw 今朝は私の町では久しぶりのまとまった雨が降っています。 今日は午後まで降り続く予報です。...

0コメント


電器屋Walkerの過去配信のBGMで利用させて頂いております。

ポッドキャスト品質向上、整音テクニック 解説Live

開催のお知らせ

詳細はこちら

国際ポッドキャストの日

International Podcast Day Event

ツキイチ - 隣のポッドキャスト

まとめファンサイト