|
Lift Framework example source code file (EnumField.scala)
The Lift Framework EnumField.scala source code/* * Copyright 2007-2011 WorldWide Conferencing, LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package net.liftweb package record package field import reflect.Manifest import xml._ import common._ import Box.option2Box import json._ import util._ import Helpers._ import http.js._ import http.{S, SHtml} import S._ import JE._ trait EnumTypedField[EnumType <: Enumeration] extends TypedField[EnumType#Value] { protected val enum: EnumType protected val valueManifest: Manifest[EnumType#Value] def toInt: Box[Int] = valueBox.map(_.id) def fromInt(in: Int): Box[EnumType#Value] = tryo(enum(in)) def setFromAny(in: Any): Box[EnumType#Value] = in match { case (value: Int) => setBox(fromInt(value)) case Some(value: Int) => setBox(fromInt(value)) case Full(value: Int) => setBox(fromInt(value)) case (value: Int)::_ => setBox(fromInt(value)) case (value: Number) => setBox(fromInt(value.intValue)) case Some(value: Number) => setBox(fromInt(value.intValue)) case Full(value: Number) => setBox(fromInt(value.intValue)) case (value: Number)::_ => setBox(fromInt(value.intValue)) case _ => genericSetFromAny(in)(valueManifest) } def setFromString(s: String): Box[EnumType#Value] = setBox(asInt(s).flatMap(fromInt)) /** Label for the selection item representing Empty, show when this field is optional. Defaults to the empty string. */ def emptyOptionLabel: String = "" /** * Build a list of (value, label) options for a select list. Return a tuple of (Box[String], String) where the first string * is the value of the field and the second string is the Text name of the Value. */ def buildDisplayList: List[(Box[EnumType#Value], String)] = { val options = enum.values.map(a => (Full(a), a.toString)).toList if (optional_?) (Empty, emptyOptionLabel)::options else options } private def elem = SHtml.selectObj[Box[EnumType#Value]](buildDisplayList, Full(valueBox), setBox(_)) % ("tabindex" -> tabIndex.toString) def toForm: Box[NodeSeq] = uniqueFieldId match { case Full(id) => Full(elem % ("id" -> id)) case _ => Full(elem) } def defaultValue: EnumType#Value = enum.values.iterator.next def asJs = valueBox.map(_ => Str(toString)) openOr JsNull def asJIntOrdinal: JValue = toInt.map(i => JInt(BigInt(i))) openOr (JNothing: JValue) def setFromJIntOrdinal(jvalue: JValue): Box[EnumType#Value] = jvalue match { case JNothing|JNull if optional_? => setBox(Empty) case JInt(i) => setBox(fromInt(i.intValue)) case other => setBox(FieldHelpers.expectedA("JInt", other)) } def asJStringName: JValue = valueBox.map(v => JString(v.toString)) openOr (JNothing: JValue) def setFromJStringName(jvalue: JValue): Box[EnumType#Value] = jvalue match { case JNothing|JNull if optional_? => setBox(Empty) case JString(s) => setBox(Option(enum.withName(s)) ?~ ("Unknown value \"" + s + "\"")) case other => setBox(FieldHelpers.expectedA("JString", other)) } def asJValue: JValue = asJIntOrdinal def setFromJValue(jvalue: JValue): Box[EnumType#Value] = setFromJIntOrdinal(jvalue) } class EnumField[OwnerType <: Record[OwnerType], EnumType <: Enumeration](rec: OwnerType, protected val enum: EnumType)(implicit m: Manifest[EnumType#Value]) extends Field[EnumType#Value, OwnerType] with MandatoryTypedField[EnumType#Value] with EnumTypedField[EnumType] { def this(rec: OwnerType, enum: EnumType, value: EnumType#Value)(implicit m: Manifest[EnumType#Value]) = { this(rec, enum) set(value) } def owner = rec protected val valueManifest = m } class OptionalEnumField[OwnerType <: Record[OwnerType], EnumType <: Enumeration](rec: OwnerType, protected val enum: EnumType)(implicit m: Manifest[EnumType#Value]) extends Field[EnumType#Value, OwnerType] with OptionalTypedField[EnumType#Value] with EnumTypedField[EnumType] { def this(rec: OwnerType, enum: EnumType, value: Box[EnumType#Value])(implicit m: Manifest[EnumType#Value]) = { this(rec, enum) setBox(value) } def owner = rec protected val valueManifest = m } Other Lift Framework examples (source code examples)Here is a short list of links related to this Lift Framework EnumField.scala source code file: |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.