こんにちはジョージです。前回の続きやりましょ。 前回の記事はこちら ↓
data:image/s3,"s3://crabby-images/230d7/230d7a215774f4c09081b53e71a4168213585c8c" alt=""
プロジェクトのソース修正
V-Calendar と FileMaker カスタム App を双方向に操作できるように修正を加えます。いろいろ試した結果、これが一番簡単なのではないかと思う方法を紹介します。
main.js
まずは main.js のソースを書き換えます。
data:image/s3,"s3://crabby-images/86ec7/86ec73caf2498a5373cdf0923bfcfb13f175bf4e" alt="2023030901#2.001.png (366.7 kB)"
開発環境や実際のサーバ上でのテストでは問題ないのですが、カスタム App WebViewr の場合はうまくカレンダーが表示されないので、DOM が読み込まれたら強制的に出力させます。
import { createApp } from 'vue'
import { SetupCalendar, Calendar, DatePicker } from 'v-calendar';
import App from './App.vue'
import 'v-calendar/dist/style.css';
// createApp(App)
// .use(SetupCalendar, {})
// .component("Calendar", Calendar)
// .component("DatePicker", DatePicker)
// .mount("#app");
document.addEventListener("DOMContentLoaded", () => {
createApp(App)
.use(SetupCalendar, {})
// .component("Calendar", Calendar)
.component("DatePicker", DatePicker)
.mount("#app");
});
App.vue
つづいて App.vue です。
<template>
<div id="app">
<div class="container">
<Calendar />
<DatePicker v-model="date" is-inline ref="calendar" @dayclick="onDayClick" />
</div>
</div>
</template>
<script>
export default {
name: "App",
data() {
return {
date: null,
mode: "datetime",
};
},
created() {
window.move = this.move;
},
methods: {
move(){
this.$refs.calendar.move(5);
},
onDayClick(day) {
window.FileMaker.PerformScriptWithOption("return", day.date, 0);
},
},
};
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
</style>
補足説明(5 行目)
<DatePicker v-model="date" is-inline ref="calendar" @dayclick="onDayClick" />
カレンダーを「calendar」という名前でスクリプトから参照できるようにし、カレンダー日付がクリックされた後に onDayClick を実行するように登録します。
補足説明(23 行目)
methods: {
move(){
this.$refs.calendar.move(5);
},
onDayClick(day) {
window.FileMaker.PerformScriptWithOption("return", day.date, 0);
},
}
move メソッドと onDayClick メソッドを追加します。move では calendar を 5ヶ月進めるだけで特に意味はありませんが、簡単に見た目が変化するので採用しました。onDayClick では FileMaker の return スクリプトにクリックされた日付を渡しています。
補足説明(20 行目)
created() {
window.move = this.move;
}
window オブジェクト経由で move メソッドを実行できるようにします。これでカスタム App から V-Calendar を呼び出して連携できるようになります。
data:image/s3,"s3://crabby-images/6c7d1/6c7d1916e4db810bd7aa3913962e43cafcfbb90b" alt="2023030901#2.002.png (328.3 kB)"
プロジェクトのビルド
ここまでできたら一度ビルドしてみましょう。
npm run build
data:image/s3,"s3://crabby-images/ae8d5/ae8d59f38f914b770d3227723132aaa03009f912" alt="2023030901#2.003.png (262.6 kB)"
dist フォルダに html と JavaScript、CSS ファイルが出力されました。ただしファイル名にハッシュ値が含まれていて build の度にハッシュ値が変化します。これではカスタム App に取り込みにくいのでハッシュ値をなくす設定を行います。
data:image/s3,"s3://crabby-images/1d382/1d382fedd59df0b8f06c4be8611ead69001e77a4" alt="2023030901#2.004.png (356.4 kB)"
出力されたファイル名からハッシュ値を取り除く
まずは vite のバージョンが 4.0.0 以上な事を確認してください。私の VSCode の RemoteContainer から作成した環境では vite のバージョンがえらい古かったので npm から 最新の vite をインストールしてます。
data:image/s3,"s3://crabby-images/4d47f/4d47fd04ba38e2f1965babbdd21cccd1bacab2e9" alt="2023030901#2.005.png (437.9 kB)"
つづけてプラグインをインストールします。オフィシャルサイトの説明によると Vue 3 の単一ファイルコンポーネントがサポートされるようです。
npm i @vitejs/plugin-vue
data:image/s3,"s3://crabby-images/6b1a4/6b1a4cb09dcdfc81a95a44c793b944655ea1c865" alt="2023030901#2.006.png (165.8 kB)"
data:image/s3,"s3://crabby-images/cf49c/cf49c2891b0ec0073d8ed4224b9588a6da0a36d2" alt="2023030901#2.007.png (202.9 kB)"
プロジェクトフォルダに vite.config.js ファイル を新規追加します。これでファイル名にハッシュ値が含まれなくなります。
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
// https://vitejs.dev/config/
export default defineConfig({
plugins: [vue()],
build: {
rollupOptions: {
output: {
entryFileNames: `assets/[name].js`,
chunkFileNames: `assets/[name].js`,
assetFileNames: `assets/[name].[ext]`,
},
},
},
})
data:image/s3,"s3://crabby-images/1e0ce/1e0ce26188580c55d8ca63cd1aabb9d58da5c429" alt="2023030901#2.008.png (288.0 kB)"
もう一度ビルドしてみましょう。ハッシュ値がなくなりました。
npm run build
data:image/s3,"s3://crabby-images/ba3b3/ba3b3f53612da7444f69f519324e6b4bb51fdbf8" alt="2023030901#2.009.png (372.6 kB)"
dist フォルダに出力された index.html を修正します。カスタム App で置換しやすいようにダブルクォート「”」をシングルクォート「’」に変換します。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<link rel="icon" href="/favicon.ico" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Vite App</title>
<script type='module' crossorigin src='/assets/index.js'></script>
<link rel='stylesheet' href='/assets/index.css'>
</head>
<body>
<div id="app"></div>
</body>
</html>
data:image/s3,"s3://crabby-images/7c56b/7c56b11ac6f88ecbfc13c781960b5511ea943486" alt="2023030901#2.010.png (340.4 kB)"
とりあえず プロジェクトでの作業はこれで完了です。お疲れ様でした!
カスタム App を新規作成
FIleMaker でカスタム App を新規作成します。
data:image/s3,"s3://crabby-images/f16de/f16de6af6f981c5397e95c7198db75641fcdee0c" alt="2023030901#2.011.png (167.6 kB)"
フィールドと WebViewer をレイアウトに配置します。
data:image/s3,"s3://crabby-images/ddd9f/ddd9f4a41dfd1c61768a1ea894d038e7d2bb2688" alt="2023030901#2.012.png (123.8 kB)"
WebViewer の内容
"data:text/html, " &
Substitute ( main::html;
[ "<script type='module' crossorigin src='/assets/index.js'></script>"; "<script>" & main::js & "</script>" ];
[ "<link rel='stylesheet' href='/assets/index.css'>"; "<style>" & main::css & "</style>" ]
)
WebViewer にはオブジェクト名「wv」として、JavaScript による FileMaker スクリプトの実行許可オプションを有効にすることを忘れずに行ってください。
html、js、css フィールドにはそれぞれ、ビルド後に出力されたファイルの内容を挿入します。うまくいくと WebViewer にカレンダーが表示されます。
data:image/s3,"s3://crabby-images/53de9/53de95adaf179a30ecfe8b5b555752f2509c7a26" alt="2023030901#2.013.png (134.6 kB)"
ながくなったので、カスタム App との連携は次回に紹介します。お楽しみに!