All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sourceforge.plantuml.chronology.TaskChronology Maven / Gradle / Ivy

There is a newer version: 1.2024.8
Show newest version
// THIS FILE HAS BEEN GENERATED BY A PREPROCESSOR.
/* +=======================================================================
 * |
 * |      PlantUML : a free UML diagram generator
 * |
 * +=======================================================================
 *
 * (C) Copyright 2009-2024, Arnaud Roques
 *
 * Project Info:  https://plantuml.com
 *
 * If you like this project or if you find it useful, you can support us at:
 *
 * https://plantuml.com/patreon (only 1$ per month!)
 * https://plantuml.com/liberapay (only 1€ per month!)
 * https://plantuml.com/paypal
 *
 *
 * PlantUML is free software; you can redistribute it and/or modify it
 * under the terms of the MIT License.
 *
 * See http://opensource.org/licenses/MIT
 *
 * Permission is hereby granted, free of charge, to any person obtaining
 * a copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included
 * in all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR
 * IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 *
 * PlantUML can occasionally display sponsored or advertising messages. Those
 * messages are usually generated on welcome or error images and never on
 * functional diagrams.
 * See https://plantuml.com/professional if you want to remove them
 *
 * Images (whatever their format : PNG, SVG, EPS...) generated by running PlantUML
 * are owned by the author of their corresponding sources code (that is, their
 * textual description in PlantUML language). Those images are not covered by
 * this MIT license.
 *
 * The generated images can then be used without any reference to the MIT license.
 * It is not even necessary to stipulate that they have been generated with PlantUML,
 * although this will be appreciated by the PlantUML team.
 *
 * There is an exception : if the textual description in PlantUML language is also covered
 * by any license, then the generated images are logically covered
 * by the very same license.
 *
 * This is the IGY distribution (Install GraphViz by Yourself).
 * You have to install GraphViz and to setup the GRAPHVIZ_DOT environment variable
 * (see https://plantuml.com/graphviz-dot )
 *
 * Icons provided by OpenIconic :  https://useiconic.com/open
 * Archimate sprites provided by Archi :  http://www.archimatetool.com
 * Stdlib AWS provided by https://github.com/milo-minderbinder/AWS-PlantUML
 * Stdlib Icons provided https://github.com/tupadr3/plantuml-icon-font-sprites
 * ASCIIMathML (c) Peter Jipsen http://www.chapman.edu/~jipsen
 * ASCIIMathML (c) David Lippman http://www.pierce.ctc.edu/dlippman
 * CafeUndZopfli ported by Eugene Klyuchnikov https://github.com/eustas/CafeUndZopfli
 * Brotli (c) by the Brotli Authors https://github.com/google/brotli
 * Themes (c) by Brett Schwarz https://github.com/bschwarz/puml-themes
 * Twemoji (c) by Twitter at https://twemoji.twitter.com/
 *
 */
package net.sourceforge.plantuml.chronology;

import net.sourceforge.plantuml.klimt.creole.Display;
import net.sourceforge.plantuml.project.Load;
import net.sourceforge.plantuml.project.core.AbstractTask;
import net.sourceforge.plantuml.project.core.Resource;
import net.sourceforge.plantuml.project.core.Task;
import net.sourceforge.plantuml.project.core.TaskCode;
import net.sourceforge.plantuml.project.lang.CenterBorderColor;
import net.sourceforge.plantuml.project.time.Day;
import net.sourceforge.plantuml.project.time.DayOfWeek;
import net.sourceforge.plantuml.style.StyleBuilder;
import net.sourceforge.plantuml.url.Url;

public class TaskChronology extends AbstractTask implements Task {

	private Display note;

	private Url url;
	private CenterBorderColor[] colors;

	private Day start;
	private Day end;

	public void setUrl(Url url) {
		this.url = url;
	}

	public TaskChronology(StyleBuilder styleBuilder, TaskCode code) {
		super(styleBuilder, code);
	}

	@Override
	public void setStart(Day start) {
		this.start = start;

	}

	@Override
	public Day getStart() {
		return this.start;
	}

	@Override
	public void setEnd(Day end) {
		this.end = end;
	}

	@Override
	public Day getEnd() {
		return this.end;
	}

	@Override
	public Load getLoad() {
		throw new UnsupportedOperationException();
	}

	@Override
	public void setLoad(Load load) {
		throw new UnsupportedOperationException();
	}

	@Override
	public void addResource(Resource resource, int percentage) {
		throw new UnsupportedOperationException();
	}

	@Override
	public void setDiamond(boolean diamond) {
		throw new UnsupportedOperationException();
	}

	@Override
	public boolean isDiamond() {
		return false;
	}

	@Override
	public void setCompletion(int completion) {
		throw new UnsupportedOperationException();
	}

	@Override
	public void addPause(Day pause) {
		throw new UnsupportedOperationException();
	}

	@Override
	public void addPause(DayOfWeek pause) {
		throw new UnsupportedOperationException();
	}

	@Override
	public boolean isAssignedTo(Resource res) {
		throw new UnsupportedOperationException();
	}

//	@Override
//	public int getLoadAt(Day instant) {
//		if (isPaused(instant))
//			return 0;
//
//		LoadPlanable result = defaultPlan;
//		if (resources.size() > 0)
//			result = PlanUtils.multiply(defaultPlan, getResourcePlan());
//
//		return result.getLoadAt(instant);
//	}
//
//	private boolean isPaused(Day instant) {
//		if (pausedDay.contains(instant))
//			return true;
//
//		if (pausedDayOfWeek(instant))
//			return true;
//
//		return false;
//	}
//
//	private boolean pausedDayOfWeek(Day instant) {
//		for (DayOfWeek dayOfWeek : pausedDayOfWeek)
//			if (instant.getDayOfWeek() == dayOfWeek)
//				return true;
//
//		return false;
//	}
//
//	public int loadForResource(Resource res, Day instant) {
//		if (resources.keySet().contains(res) && instant.compareTo(getStart()) >= 0
//				&& instant.compareTo(getEnd()) <= 0) {
//			if (isPaused(instant))
//				return 0;
//
//			if (res.isClosedAt(instant))
//				return 0;
//
//			return resources.get(res);
//		}
//		return 0;
//	}
//
//	@Override
//	public void addPause(Day pause) {
//		this.pausedDay.add(pause);
//	}
//
//	@Override
//	public void addPause(DayOfWeek pause) {
//		this.pausedDayOfWeek.add(pause);
//	}
//
//	private LoadPlanable getResourcePlan() {
//		if (resources.size() == 0)
//			throw new IllegalStateException();
//
//		return new LoadPlanable() {
//			public int getLoadAt(Day instant) {
//				int result = 0;
//				for (Map.Entry ent : resources.entrySet()) {
//					final Resource res = ent.getKey();
//					if (res.isClosedAt(instant))
//						continue;
//
//					final int percentage = ent.getValue();
//					result += percentage;
//				}
//				return result;
//			}
//
//			@Override
//			public Day getLastDayIfAny() {
//				return TaskChronology.this.getLastDayIfAny();
//			}
//		};
//	}
//
//	@Override
//	public Day getLastDayIfAny() {
//		Day result = null;
//
//		for (Resource res : resources.keySet()) {
//			if (res.getLastDayIfAny() == null)
//				return null;
//
//			if (result == null || result.compareTo(res.getLastDayIfAny()) < 0)
//				result = res.getLastDayIfAny();
//		}
//
//		return result;
//	}
//
//	public String getPrettyDisplay() {
//		if (resources.size() > 0) {
//			final StringBuilder result = new StringBuilder(getCode().getSimpleDisplay());
//			result.append(" ");
//			for (Iterator> it = resources.entrySet().iterator(); it.hasNext();) {
//				final Map.Entry ent = it.next();
//				result.append("{");
//				result.append(ent.getKey().getName());
//				final int percentage = ent.getValue();
//				if (percentage != 100)
//					result.append(":" + percentage + "%");
//
//				result.append("}");
//				if (it.hasNext())
//					result.append(" ");
//
//			}
//			return result.toString();
//		}
//		return getCode().getSimpleDisplay();
//	}
//
//	@Override
//	public String toString() {
//		return getCode().toString();
//	}
//
//	public String debug() {
//		return "" + getStart() + " ---> " + getEnd() + "   [" + getLoad() + "]";
//	}
//
//	@Override
//	public Day getStart() {
//		Day result = (Day) solver.getData(TaskAttribute.START);
//		if (diamond == false)
//			while (getLoadAt(result) == 0)
//				result = result.increment();
//
//		return result;
//	}
//
//	@Override
//	public Day getEnd() {
//		return (Day) solver.getData(TaskAttribute.END);
//	}
//
//	@Override
//	public Load getLoad() {
//		return (Load) solver.getData(TaskAttribute.LOAD);
//	}
//
//	@Override
//	public void setLoad(Load load) {
//		solver.setData(TaskAttribute.LOAD, load);
//	}
//
//	@Override
//	public void setStart(Day start) {
//		solver.setData(TaskAttribute.START, start);
//	}
//
//	@Override
//	public void setEnd(Day end) {
//		solver.setData(TaskAttribute.END, end);
//	}

	@Override
	public void setColors(CenterBorderColor... colors) {
		this.colors = colors;
	}

//	@Override
//	public void addResource(Resource resource, int percentage) {
//		this.resources.put(resource, percentage);
//	}
//
//	@Override
//	public void setDiamond(boolean diamond) {
//		this.diamond = diamond;
//	}
//
//	@Override
//	public boolean isDiamond() {
//		return this.diamond;
//	}
//
//	@Override
//	public void setCompletion(int completion) {
//		this.completion = completion;
//	}
//
//	public final Url getUrl() {
//		return url;
//	}
//
//	public final CenterBorderColor getColors() {
//		if (colors == null)
//			return null;
//
//		if (colors.length == 1)
//			return colors[0];
//
//		return colors[0].unlinearTo(colors[1], completion);
//	}
//
//	public final int getCompletion() {
//		return completion;
//	}
//
//	public final Collection getAllPaused() {
//		final SortedSet result = new TreeSet<>(pausedDay);
//		for (DayOfWeek dayOfWeek : pausedDayOfWeek)
//			addAll(result, dayOfWeek);
//
//		return Collections.unmodifiableCollection(result);
//	}
//
//	private void addAll(SortedSet result, DayOfWeek dayOfWeek) {
//		final Day start = getStart();
//		final Day end = getEnd();
//		for (Day current = start; current.compareTo(end) <= 0; current = current.increment())
//			if (current.getDayOfWeek() == dayOfWeek)
//				result.add(current);
//
//	}

	@Override
	public void setNote(Display note) {
		this.note = note;
	}

	public Display getNote() {
		return note;
	}

//	public LoadPlanable getDefaultPlan() {
//		return defaultPlan;
//	}
//
//	@Override
//	public boolean isAssignedTo(Resource res) {
//		return resources.containsKey(res);
//	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy