[Seasar-user:18896] Re: [Ymir] Validate後に、該当textboxのスタイルを変更したい
西山 はじめ
[E-MAIL ADDRESS DELETED]
2009年 11月 13日 (金) 13:50:12 JST
西山(hajimeni)です。
対応ありがとうございます。
思いつきで書いただけでしたが、採用していただいてありがとうご
ざいます。
最新のSNAPSHOTで、確認いたしました。
両方の記述方法のどちらでも、class属性に追加されました。
class属性以外で利用するパターンが思いつきませんでした(今の
ところ)ので、問題はないと思います。
以上よろしくお願いいたします。
[2009/11/12 18:26] YOKOTA Takehiko さんは書きました。:
> 横田です。
>
>> いっそのこと、decorate式をnotes以外でも使用できるように、
>>
>> tal:attributes="class decorate:真偽値 with class値"
>>
>> にしてしまった方が、個人的にはしっくりきます。
>
> いいアイデアですね!早速このアイデアを元に内部で検討しました。その結果、
>
> ・このアイデアはナイスなので実装する
>
> ・Notesの状態によって装飾するための簡易記法として、元々のdecorate:の書き方を
> decorate-by-notes:として記述できるようにする
>
> ということにしました。
>
> というわけで、最新版のSNAPSHOT(freyja、ymir)を使うことで、以下の2つの書き方
> ができるようになりました。
>
> (1) tal:attributes="class decorate:notes/contains(date2) with error"
> (2) tal:attributes="class decorate-by-notes:date2 with error"
>
> ちなみにdecorate, decorate-by-notesはclass属性専用のため、tal:attributes
> 属性での、class属性のための
> 値の設定用にしか使えないようにしてあります。問題あればお知らせ下さい。
>
>
> 西山 はじめ さんは書きました:
>> 西山(hajimeni)です。
>>
>>
>>> バリデーションエラー専用(正確には、Notesにエントリがある
>>>
>> かどうか、
>>
>>> なので、バリデーションエラー以外でも画面にメッセージを出し
>>>
>> たい場合
>>
>>> には使えます)なので、いい名前がないものかと思っています。
>>>
>>
>>> 意味的には「decorate-by-notes」という感じなんですが、長い
>>>
>> かなぁと
>>
>>> 思って単に「decorate」としています。何かいいアイデアがあれ
>>>
>> ばご提案
>>
>>> いただけるとうれしいです。
>>>
>> なるほど、意味は理解いたしました。
>> 名前を考えていますが、なかなかぴったりなものが見つかりません。
>>
>> いっそのこと、decorate式をnotes以外でも使用できるように、
>>
>> tal:attributes="class decorate:真偽値 with class値"
>>
>> にしてしまった方が、個人的にはしっくりきます。
>>
>> 使うときには、
>>
>> tal:attributes="class decorate:notes/contains(date2) with error"
>>
>> と少し冗長になってしまいますが・・・
>>
>>
>>
>> 以上よろしくお願いいたします。
>>
>> [2009/11/11 18:06] YOKOTA Takehiko さんは書きました。:
>>
>>> 横田です。
>>>
>>>
>>>> decorate ですと「装飾する」という意味ですが、バリデーション
>>>> エラー以外にもこの書式は利用できるのでしょうか?
>>>>
>>>> バリデーションエラーの場合のみの仕様の場合、構文として分かり
>>>> づらいのではないかと思います。
>>>>
>>> おっしゃるとおりです。実は命名についてはかなり悩んでいました。
>>> バリデーションエラー専用(正確には、Notesにエントリがあるかどうか、
>>> なので、バリデーションエラー以外でも画面にメッセージを出したい場合
>>> には使えます)なので、いい名前がないものかと思っています。
>>>
>>> 意味的には「decorate-by-notes」という感じなんですが、長いかなぁと
>>> 思って単に「decorate」としています。何かいいアイデアがあればご提案
>>> いただけるとうれしいです。
>>>
>>>
>>> 西山 はじめ さんは書きました:
>>>
>>>> 西山(hajimeni)です。
>>>> お世話になっております。
>>>>
>>>> 横田さん、対応ありがとうございます。
>>>> 早速見させていただきました。
>>>>
>>>> 行いたいことはこれで実現できます。ありがとうございます。
>>>>
>>>> ひとつ気になる点があります。
>>>>
>>>> decorate ですと「装飾する」という意味ですが、バリデーション
>>>> エラー以外にもこの書式は利用できるのでしょうか?
>>>>
>>>> バリデーションエラーの場合のみの仕様の場合、構文として分かり
>>>> づらいのではないかと思います。
>>>>
>>>> teeda の onError のような名称の方がよいと思うのですがいかが
>>>> でしょうか。
>>>>
>>>> 以上よろしくお願いいたします。
>>>>
>>>> [2009/11/11 16:49] YOKOTA Takehiko さんは書きました。:
>>>>
>>>>> 横田です。
>>>>>
>>>>> メール遅くなりました。この件、dbflute-ymir-exampleで用いていた書式は
>>>>> 一時期動作していましたが、検討の末SNAPSHOTレベルで廃止されました。
>>>>> (久保さんごめんなさい)
>>>>>
>>>>> 代わりに、ymir-1.0.7-SNAPSHOTでは、新しい書式として以下のような記述が
>>>>> できるようになっています。
>>>>>
>>>>> tal:attributes="class decorate:パラメータ名 with class値"
>>>>>
>>>>> これは、「パラメータ名で指定されたパラメータについてバリデーションエラー
>>>>> が起きた場合に、class値で指定された値を現在のclass属性の値に追加する」
>>>>> という意味になります。(バリデーションエラーがない場合はclass属性の値
>>>>> はそのままです。)
>>>>>
>>>>> ymir-example-genericの最新版の
>>>>>
>>>>> http://localhost:8080/ymir-example-generic/text/index.html
>>>>>
>>>>> も見てみて下さい。
>>>>>
>>>>> なお、上記書式を使うには、最新のYmirの1.0.7-SNAPSHOTとFreyjaの1.0.17-SNAPSHOT
>>>>> が必要になります。両方ともmavenのsnapshotリポジトリにはデプロイ済みです。
>>>>>
>>>>> 以上よろしくお願いします。
>>>>>
>>>>>
>>>>> 西山 はじめ さんは書きました:
>>>>>
>>>>>> 西山(hajimeni)です。
>>>>>>
>>>>>> > すいません、dbflute-ymir-exampleのその部分が
>>>>>> > Ymirとある時点(SNAPSHOT)の方式でした。
>>>>>> > ちょっとちゃんとしたやり方を調べて直しますね。
>>>>>>
>>>>>> 了解いたしました。
>>>>>> よろしくお願いいたします。
>>>>>>
>>>>>>
>>>>>> [2009/11/06 17:52] kubo さんは書きました。:
>>>>>>
>>>>>>> 久保(jflute)です。
>>>>>>>
>>>>>>> 西山さん、こんにちは
>>>>>>>
>>>>>>> すいません、dbflute-ymir-exampleのその部分が
>>>>>>> Ymirとある時点(SNAPSHOT)の方式でした。
>>>>>>> ちょっとちゃんとしたやり方を調べて直しますね。
>>>>>>>
>>>>>>> 2009/11/5 西山 はじめ <[E-MAIL ADDRESS DELETED]>:
>>>>>>>
>>>>>>>> お世話になっております。
>>>>>>>> 西山(hajimeni)です。
>>>>>>>>
>>>>>>>> 最新のtrunk(https:
>>>>>>>> //www.seasar.org/svn/sandbox/dbflute/trunk/dbflute-ymir-example) に存
>>>>>>>> 在する
>>>>>>>> dbflute-ymir-example なのですが、 member/edit/input.html の
>>>>>>>> Validation後の スタイル変化が動き
>>>>>>>> ません。
>>>>>>>>
>>>>>>>> <label tal:attributes="class notes/contains(memberAccount) ?
>>>>>>>> string:label-invalid : default" class="label-normal">
>>>>>>>>
>>>>>>>> 以前は動作していたような覚えがあるのですが、ログを見ると例外 が発生し
>>>>>>>> ておりました。
>>>>>>>>
>>>>>>>> また、次のように修正すると動きます。
>>>>>>>> <style>
>>>>>>>> .label-true {
>>>>>>>> color: #DD6666;
>>>>>>>> }
>>>>>>>> </style>
>>>>>>>> <label tal:attributes="class
>>>>>>>> string:label-${notes/contains(memberAccount)}"
>>>>>>>> class="label-normal">
>>>>>>>>
>>>>>>>> ログには、以下のように出力されています。
>>>>>>>> 解決方法ありますでしょうか?
>>>>>>>> また、Ymir1.0.4 を利用したサンプルまでさかのぼって取得しても 同じ結果
>>>>>>>> でした。
>>>>>>>>
>>>>>>>> 環境は
>>>>>>>> Tomcat6.0
>>>>>>>> JDK1.6
>>>>>>>> です。
>>>>>>>>
>>>>>>>> 以上よろしくお願いいたします。
>>>>>>>> =======================================================
>>>>>>>> ここからログ
>>>>>>>> =======================================================
>>>>>>>> 2009-11-05 19:10:01,767 DEBUG http-8080-3
>>>>>>>> [YmirBeanPathResolver#resolve():42] - No Such property
>>>>>>>> (org.seasar.ymir.message.Notes/contains(memberAccount) ?
>>>>>>>> string:label-invalid : default): treated as null
>>>>>>>> java.lang.NoSuchMethodException: Unknown property 'contains'
>>>>>>>> at
>>>>>>>> org.apache.commons.beanutils.PropertyUtilsBean.getMappedProperty(PropertyUtilsBean.java:536)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.commons.beanutils.PropertyUtilsBean.getMappedProperty(PropertyUtilsBean.java:485)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.commons.beanutils.PropertyUtilsBean.getNestedProperty(PropertyUtilsBean.java:682)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.commons.beanutils.PropertyUtilsBean.getProperty(PropertyUtilsBean.java:715)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.commons.beanutils.PropertyUtils.getProperty(PropertyUtils.java:290)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.seasar.ymir.zpt.YmirBeanPathResolver.resolve(YmirBeanPathResolver.java:31)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.tales.PathTypePrefixHandler.resolveSegment(PathTypePrefixHandler.java:182)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.tales.PathTypePrefixHandler.resolvePath(PathTypePrefixHandler.java:155)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.tales.PathTypePrefixHandler.resolvePath(PathTypePrefixHandler.java:135)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.tales.PathTypePrefixHandler.handle(PathTypePrefixHandler.java:68)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.tales.TalesExpressionEvaluator.evaluateExpression(TalesExpressionEvaluator.java:144)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.tales.TalesExpressionEvaluator.evaluate(TalesExpressionEvaluator.java:116)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.seasar.ymir.zpt.YmirTalesExpressionEvaluator.evaluate(YmirTalesExpressionEvaluator.java:46)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.TalTagEvaluator.processAttributes(TalTagEvaluator.java:747)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.TalTagEvaluator.evaluate(TalTagEvaluator.java:459)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.MetalTagEvaluator.evaluate(MetalTagEvaluator.java:128)
>>>>>>>>
>>>>>>>> at net.skirnir.freyja.TagElement.evaluate(TagElement.java:49)
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.TagEvaluatorUtils.evaluateElements(TagEvaluatorUtils.java:56)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.TalTagEvaluator.evaluate(TalTagEvaluator.java:533)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.zpt.MetalTagEvaluator.evaluate(MetalTagEvaluator.java:128)
>>>>>>>>
>>>>>>>> at net.skirnir.freyja.TagElement.evaluate(TagElement.java:49)
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.impl.TemplateEvaluatorImpl.evaluate(TemplateEvaluatorImpl.java:118)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.webapp.FreyjaServlet.doProcess(FreyjaServlet.java:244)
>>>>>>>>
>>>>>>>> at
>>>>>>>> net.skirnir.freyja.webapp.FreyjaServlet.doPost(FreyjaServlet.java:163)
>>>>>>>> at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
>>>>>>>> at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.seasar.ymir.impl.YmirImpl.processResponse(YmirImpl.java:273)
>>>>>>>> at org.seasar.ymir.zpt.ZptYmir.processResponse(ZptYmir.java:47)
>>>>>>>> at org.seasar.ymir.impl.YmirImpl.process(YmirImpl.java:213)
>>>>>>>> at
>>>>>>>> org.seasar.ymir.servlet.YmirFilter.doFilter(YmirFilter.java:90)
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.seasar.cms.pluggable.servlet.PluggableFilter.doFilter(PluggableFilter.java:43)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.seasar.ymir.servlet.RequestLoggingFilter.doFilter(RequestLoggingFilter.java:96)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.seasar.ymir.servlet.MultipartRequestFilter.doFilter(MultipartRequestFilter.java:44)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.seasar.extension.filter.EncodingFilter.doFilter(EncodingFilter.java:69)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
>>>>>>>>
>>>>>>>> at
>>>>>>>> org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454)
>>>>>>>> at java.lang.Thread.run(Thread.java:619)
>>>>>>>> =======================================================
>>>>>>>>
>>>>>>>> --
>>>>>>>> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>>>>>>> 西山 はじめ
>>>>>>>> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>>>>>>>
>>>>>>>> _______________________________________________
>>>>>>>> Seasar-user mailing list
>>>>>>>> [E-MAIL ADDRESS DELETED]
>>>>>>>> https://ml.seasar.org/mailman/listinfo/seasar-user
>>>>>>>>
>>>>>>>>
>>>>>>> _______________________________________________
>>>>>>> Seasar-user mailing list
>>>>>>> [E-MAIL ADDRESS DELETED]
>>>>>>> https://ml.seasar.org/mailman/listinfo/seasar-user
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>>
>>>
>>
>>
>
>
--
++++++++++++++++++++++++++++++++++++++++++++++++++++++++
西山 はじめ
++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Seasar-user メーリングリストの案内