チケットのカスタムフィールドの選択肢を、プロジェクトのカスタムフィールドで制御(Redmine View Customize Plugin)

下記問い合わせに対応して、チケットのカスタムフィールドの選択肢を、プロジェクトのカスタムフィールドで制御するサンプルを作成しました。

動作イメージ

チケットとプロジェクトで同じ選択肢を持つカスタムフィールドを用意しておいて、それぞれを連動させるイメージです。

https://github.com/onozaty/redmine-view-customize-scripts/raw/master/examples/0058.control_issue_custom_field_with_project/result.gif

コード内容は下記にまとめています。

JSONをCSVに変換するツール json2csvを作りました

JSONをCSVに変換するツールjson2csvを作りました。

マッピング情報を元に、JSONからCSVに変換します。

$ json2csv -i input.json -m mapping.json -o output.csv
Usage: json2csv [flags]

Flags
  -i, --input string     JSON input file path or directory or url
  -m, --mapping string   JSON to CSV mapping file path or url
  -o, --output string    CSV output file path
  -b, --bom              CSV with BOM
  -h, --help             Help

マッピング情報は下記のように書きます。
XPathを使って行の一覧と各カラムを指定するようなイメージです。

{
    "rowsPath": "//items/*",
    "columns": [
        {
            "header": "title",
            "valuePath": "/title"
        },
        {
            "header": "link",
            "valuePath": "/link"
        },
        {
            "header": "description",
            "valuePath": "/description"
        }
    ]
}

JSONからXPathで取得する部分は、antchfx/jsonquery を使っています。JSONとXPathの対応は下記を見るとわかりやすいと思います。

Goで書いているので、Windows/Linux/Macに対応しています。実行ファイルは下記からダウンロードしてください。

ShortcutKey2URLでシークレット(プライベート)ウインドウで開くアクションを追加しました(Chrome版v1.5.0、Firefox版v4.4.0)

要望を受けて、ShortcutKey2URLでIncognitoウインドウで開くアクションを追加しました。(Chromeだとシークレットウインドウ、Firefoxだとプライベートウインドウと呼ばれるもの)

下記の2つのアクションを追加しています。

  • Open url in incognito window シークレットウインドウでURLを開く。
  • Open current tab in incognito window シークレットウインドウで現在のタブを開く。

Firefoxだと、拡張機能の詳細から、「プライベートウィンドウでの実行」を「許可する」に設定しないと実行できないのでご注意ください。

社内勉強会で「40歳過ぎてもエンジニアでいるためにやっていること」というタイトルでLTしました

社内勉強会で「40歳過ぎてもエンジニアでいるためにやっていること」というタイトルで、今まで継続してきたことを発表しました。

定年までエンジニアとしてやっていきたいと思っているので、今後も今までやってきたことを継続出来れば、、と思っています。

Web APIを利用して郵便番号から住所を取得して設定(Redmine View Customize Plugin)

下記問い合わせに対応して、Web APIを利用して郵便番号から住所を取得して設定するサンプルを作成しました。

動作イメージ

下記APIを利用して住所を設定しています。

https://github.com/onozaty/redmine-view-customize-scripts/raw/master/examples/0056.get_address_from_zipcode_with_webapi/result.gif

コード内容は下記にまとめています。

Power Apps+Power Automateを学ぶのに、MICUGの「Power Platform Onboarding Center アプリ開発コース」が良かった

MICUG(マイカグ)で「Power Platform Onboarding Center」というオンラインのハンズオンが定期的に開催されています。

MICUG(マイカグ)は、Microsoft Cloud を話題に相互に交流する事を目的として構成されたエンタープライズコミュニティです。
日々のMicrosoft Cloudを利用する中でより高度な活用、お客様、パートナー企業の相互交流を深め、それぞれの企業が持つ経験やノウハウを共有し、開発者、市民開発者、IT Pro、インフラエンジニア、データサイエンティスト、CCoE(Cloud Center of Excellence)などのクラウド導入管理・展開計画者のコミュニケーションを支えることを大きな目的としています。
MICUG(マイカグ)

アプリ開発コース(Power Apps + Power Automate)を受けたのですが、とっても良かったのでここでも紹介したいと思います。(検索してもあまりヒットしなかった情報で、私も勧められて知ったので)
私が受けたのは第4回で、現在は第5回が開催中です。(1ヵ月周期で開催されています)

Teamsのライブイベントになっていて、事前にTeamsに招待されるような形で参加します。
全部で6回のイベントがスケジュールされており、プラスで最終課題が出されて自主学習を行うような流れになっていました。

  1. キックオフ : 45分
  2. Power Apps 初級ハンズオン : 180分
  3. Power Automate 初級ハンズオン : 180分
  4. Power BI 初級ハンズオン : 180分
  5. Power Apps・Power Automate 中級ハンズオン : 180分
  6. アプリ開発の為の論理思考トレーニング : 180分

ハンズオンは録画されているので、後から観たり、途中で止めたりといったことが可能です。
自分は結局リアルタイムで受けたのは初回だけで、その後は遅れて観るような形にしました。
再生速度は1.75にして、わからなかったところがあったら止めて確認する、、といった感じで、ちょうど実際の時間と同じくらいになる感じでした。

ハンズオンとしてわかりやすいのと、「Power AppsやPower Automateだとこうする/こう考える」といった、考え方が学べたのが良かったです。
CRUD操作が出来る画面や承認フローは簡単に作れるようになったのと、応用も効かせられるようになったかなと思います。